NAME
   Net::Flickr::RDF - a.k.a RDF::Describes::Flickr

SYNOPSIS
    use Net::Flickr::RDF;
    use IO::AtomicFile;

    my $fh  = IO::AtomicFile->open("/foo/bar.rdf","w");
    my $rdf = Net::Flickr::RDF->new(\%args);

    $rdf->describe_photo({photo_id => 123,
                          secret   => 567,
                          fh       => \*$fh});

    $fh->close();

DESCRIPTION
   Describe Flickr photos as RDF.

   This package inherits from *Net::Flickr::API*.

OPTIONS
   Options are passed to Net::Flickr::Backup using a Config::Simple object
   or a valid Config::Simple config file. Options are grouped by "block".

 flick
   * api_key
       String. *required*

       A valid Flickr API key.

   * api_secret
       String. *required*

       A valid Flickr Auth API secret key.

   * auth_token
       String. *required*

       A valid Flickr Auth API token.

PACKAGE METHODS
 __PACKAGE__->new($cfg)
   Where $cfg is either a valid *Config::Simple* object or the path to a
   file that can be parsed by *Config::Simple*.

   Returns a *Net::Flickr::RDF* object.

OBJECT METHODS YOU SHOULD CARE ABOUT
 $obj->describe_photo(\%args)
   Valid arguments are :

   * photo_id
       Int. *required*

   * secret
       String.

   * fh
       File-handle.

       Default is STDOUT.

   Returns true or false.

OBJECT METHODS YOU MAY CARE ABOUT
 $obj->collect_photo_data($photo_id,$secret)
   Returns a hash ref of the meta data associated with a photo.

   If any errors are unencounter an error is recorded via the log method
   and the method returns undef.

 $pgk->collect_group_data($group_id)
   Returns a hash ref of the meta data associated with a group.

   If any errors are unencounter an error is recorded via the log method
   and the method returns undef.

 $pkg->collect_user_data($user_id)
   Returns a hash ref of the meta data associated with a user.

   If any errors are unencounter an error is recorded via the log method
   and the method returns undef.

 $obj->collect_photoset_data($photoset_id)
   Returns a hash ref of the meta data associated with a photoset.

   If any errors are unencounter an error is recorded via the log method
   and the method returns undef.

 $obj->collect_cc_data()
   Returns a hash ref of the Creative Commons licenses used by Flickr.

   If any errors are unencounter an error is recorded via the log method
   and the method returns undef.

 $obj->make_photo_triples(\%data)
   Returns an array ref of array refs of the meta data associated with a
   photo (*%data*).

   If any errors are unencounter an error is recorded via the log method
   and the method returns undef.

 $obj->namespaces()
   Returns a hash ref of the prefixes and namespaces used by
   *Net::Flickr::RDF*

   The default key/value pairs are :

   a   http://www.w3.org/2000/10/annotation-ns

   acl http://www.w3.org/2001/02/acls#

   dc  http://purl.org/dc/elements/1.1/

   dcterms
       http://purl.org/dc/terms/

   exif
       http://nwalsh.com/rdf/exif#

   exifi
       http://nwalsh.com/rdf/exif-intrinsic#

   flickr
       x-urn:flickr:

   foaf
       http://xmlns.com/foaf/0.1/#

   geo http://www.w3.org/2003/01/geo/wgs84_pos#

   i   http://www.w3.org/2004/02/image-regions#

   rdf http://www.w3.org/1999/02/22-rdf-syntax-ns#

   rdfs
       http://www.w3.org/2000/01/rdf-schema#

   skos
       http://www.w3.org/2004/02/skos/core#

 $obj->namespace_prefix($uri)
   Return the namespace prefix for *$uri*

 $obj->uri_shortform($prefix,$name)
   Returns a string in the form of *prefix*:*property*. The property is the
   value of $name. The prefix passed may or may be the same as the prefix
   returned depending on whether or not the user has defined or redefined
   their own list of namespaces.

   The prefix passed to the method is assumed to be one of prefixes in the
   default list of namespaces.

 $obj->api_call(\%args)
   Valid args are :

   * method
       A string containing the name of the Flickr API method you are
       calling.

   * args
       A hash ref containing the key value pairs you are passing to
       *method*

   If the method encounters any errors calling the API, receives an API
   error or can not parse the response it will log an error event, via the
   log method, and return undef.

   Otherwise it will return a *XML::LibXML::Document* object (if
   XML::LibXML is installed) or a *XML::XPath* object.

 $obj->log()
   Returns a *Log::Dispatch* object.

VERSION
   1.0

DATE
   $Date: 2005/09/25 22:41:39 $

AUTHOR
   Aaron Straup Cope <[email protected]>

 CONFIG FILES
   This is an example of a Config::Simple file used to collect RDF data
   from Flickr

    [flickr]
    api_key=asd6234kjhdmbzcxi6e323
    api_secret=s00p3rs3k3t
    auth_token=123-omgwtf4u

 RDF
   This is an example of an RDF dump for a photograph backed up from Flickr
   :

    <?xml version='1.0'?>
    <rdf:RDF
     xmlns:dc="http://purl.org/dc/elements/1.1/"
     xmlns:a="http://www.w3.org/2000/10/annotation-ns"
     xmlns:acl="http://www.w3.org/2001/02/acls#"
     xmlns:exif="http://nwalsh.com/rdf/exif#"
     xmlns:skos="http://www.w3.org/2004/02/skos/core#"
     xmlns:foaf="http://xmlns.com/foaf/0.1/"
     xmlns:exifi="http://nwalsh.com/rdf/exif-intrinsic#"
     xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
     xmlns:rdfs="http://www.w3.org/2000/01/rdf-schema#"
     xmlns:computer="x-urn:freebsd:"
     xmlns:i="http://www.w3.org/2004/02/image-regions#"
     xmlns:flickr="x-urn:flickr:"
     xmlns:dcterms="http://purl.org/dc/terms/">

     <flickr:photo rdf:about="http://www.flickr.com/photos/35034348999@N01/30763528">
       <exif:isoSpeedRatings>1250</exif:isoSpeedRatings>
       <exif:apertureValue>336/100</exif:apertureValue>
       <exif:pixelYDimension>960</exif:pixelYDimension>
       <exif:focalLength>4.5 mm</exif:focalLength>
       <acl:access>visbility</acl:access>
       <exif:colorSpace>sRGB</exif:colorSpace>
       <exif:dateTimeOriginal>2005:08:02 18:12:19</exif:dateTimeOriginal>
       <dc:rights>All rights reserved.</dc:rights>
       <exif:shutterSpeedValue>4321/1000</exif:shutterSpeedValue>
       <dc:description></dc:description>
       <exif:exposureTime>0.05 sec (263/5260)</exif:exposureTime>
       <dc:created>2005-08-02T18:12:19-0700</dc:created>
       <dc:dateSubmitted>2005-08-02T18:16:20-0700</dc:dateSubmitted>
       <exif:gainControl>High gain up</exif:gainControl>
       <exif:flash>32</exif:flash>
       <exif:digitalZoomRatio>100/100</exif:digitalZoomRatio>
       <exif:pixelXDimension>1280</exif:pixelXDimension>
       <exif:dateTimeDigitized>2005:08:02 18:12:19</exif:dateTimeDigitized>
       <dc:title>20050802(007).jpg</dc:title>
       <exif:fNumber>f/3.2</exif:fNumber>
       <acl:accessor>public</acl:accessor>
       <dc:creator rdf:resource="http://www.flickr.com/people/35034348999@N01"/>
       <dc:subject rdf:resource="http://www.flickr.com/people/tags/usa"/>
       <dc:subject rdf:resource="http://www.flickr.com/people/tags/california"/>
       <dc:subject rdf:resource="http://www.flickr.com/people/tags/sanfrancisco"/>
       <dc:subject rdf:resource="http://www.flickr.com/people/tags/cameraphone"/>
       <a:hasAnnotation rdf:resource="http://www.flickr.com/photos/35034348999@N01/30763528#note-1140939"/>
       <a:hasAnnotation rdf:resource="http://www.flickr.com/photos/35034348999@N01/30763528#note-1140942"/>
       <a:hasAnnotation rdf:resource="http://www.flickr.com/photos/35034348999@N01/30763528#note-1140945"/>
       <a:hasAnnotation rdf:resource="http://www.flickr.com/photos/35034348999@N01/30763528#note-1140946"/>
       <a:hasAnnotation rdf:resource="http://www.flickr.com/photos/35034348999@N01/30763528#note-1140952"/>
       <a:hasAnnotation rdf:resource="http://www.flickr.com/photos/35034348999@N01/30763528#note-1142648"/>
       <a:hasAnnotation rdf:resource="http://www.flickr.com/photos/35034348999@N01/30763528#note-1142656"/>
       <a:hasAnnotation rdf:resource="http://www.flickr.com/photos/35034348999@N01/30763528#note-1143239"/>
       <a:hasAnnotation rdf:resource="http://www.flickr.com/photos/35034348999@N01/30763528#note-1148950"/>
     </flickr:photo>

     <flickr:note rdf:about="http://www.flickr.com/photos/35034348999@N01/30763528#note-1140942">
       <i:boundingBox>468 141 22 26</i:boundingBox>
       <a:body>*sigh*</a:body>
       <i:regionDepicts rdf:resource="http://static.flickr.com/23/30763528_a981fab285.jpg"/>
       <a:author rdf:resource="http://www.flickr.com/people/44124415257@N01"/>
       <a:annotates rdf:resource="http://www.flickr.com/photos/35034348999@N01/30763528"/>
     </flickr:note>

     <dcterms:StillImage rdf:about="http://static.flickr.com/23/30763528_a981fab285_s.jpg">
       <dcterms:relation>Square</dcterms:relation>
       <exifi:height>75</exifi:height>
       <exifi:width>75</exifi:width>
       <dcterms:isVersionOf rdf:resource="http://static.flickr.com/23/30763528_a981fab285_o.jpg"/>
       <rdfs:seeAlso rdf:resource="http://www.flickr.com/photos/35034348999@N01/30763528"/>
     </dcterms:StillImage>

     <flickr:note rdf:about="http://www.flickr.com/photos/35034348999@N01/30763528#note-1142656">
       <i:boundingBox>357 193 81 28</i:boundingBox>
       <a:body>eww!</a:body>
       <i:regionDepicts rdf:resource="http://static.flickr.com/23/30763528_a981fab285.jpg"/>
       <a:author rdf:resource="http://www.flickr.com/people/32373682187@N01"/>
       <a:annotates rdf:resource="http://www.flickr.com/photos/35034348999@N01/30763528"/>
     </flickr:note>

     <flickr:user rdf:about="http://www.flickr.com/people/44124415257@N01">
       <foaf:mbox_sha1sum>4f6f211958d5217ef0d10f7f5cd9a69cd66f217e</foaf:mbox_sha1sum>
       <foaf:name>Karl Dubost</foaf:name>
       <foaf:nick>karlcow</foaf:nick>
     </flickr:user>

     <flickr:note rdf:about="http://www.flickr.com/photos/35034348999@N01/30763528#note-1140939">
       <i:boundingBox>326 181 97 25</i:boundingBox>
       <a:body>Did you see that this shirt makes me a beautiful breast?</a:body>
       <i:regionDepicts rdf:resource="http://static.flickr.com/23/30763528_a981fab285.jpg"/>
       <a:author rdf:resource="http://www.flickr.com/people/44124415257@N01"/>
       <a:annotates rdf:resource="http://www.flickr.com/photos/35034348999@N01/30763528"/>
     </flickr:note>

     <flickr:tag rdf:about="http://www.flickr.com/people/tags/usa">
       <skos:prefLabel>usa</skos:prefLabel>
       <dc:creator rdf:resource="http://www.flickr.com/people/35034348999@N01"/>
       <dcterms:isPartOf rdf:resource="http://flickr.com/photos/tags/usa"/>
     </flickr:tag>

     <flickr:note rdf:about="http://www.flickr.com/photos/35034348999@N01/30763528#note-1140952">
       <i:boundingBox>9 205 145 55</i:boundingBox>
       <a:body>Do you want my opinion? There's a love affair going on here… Anyway. Talking non sense. We all know Heather is committed to Flickr. She even only dresses at FlickrApparel. Did they say &amp;quot;No Logo&amp;quot;. Doh Dude.</a:body>
       <i:regionDepicts rdf:resource="http://static.flickr.com/23/30763528_a981fab285.jpg"/>
       <a:author rdf:resource="http://www.flickr.com/people/44124415257@N01"/>
       <a:annotates rdf:resource="http://www.flickr.com/photos/35034348999@N01/30763528"/>
     </flickr:note>

     <dcterms:StillImage rdf:about="http://static.flickr.com/23/30763528_a981fab285_m.jpg">
       <dcterms:relation>Small</dcterms:relation>
       <exifi:height>180</exifi:height>
       <exifi:width>240</exifi:width>
       <dcterms:isVersionOf rdf:resource="http://static.flickr.com/23/30763528_a981fab285_o.jpg"/>
       <rdfs:seeAlso rdf:resource="http://www.flickr.com/photos/35034348999@N01/30763528"/>
     </dcterms:StillImage>

     <flickr:tag rdf:about="http://www.flickr.com/people/tags/cameraphone">
       <skos:prefLabel>cameraphone</skos:prefLabel>
       <dc:creator rdf:resource="http://www.flickr.com/people/35034348999@N01"/>
       <dcterms:isPartOf rdf:resource="http://flickr.com/photos/tags/cameraphone"/>
     </flickr:tag>

     <computer:user rdf:about="x-urn:dhclient#asc">
       <foaf:name>Aaron Straup Cope</foaf:name>
       <foaf:nick>asc</foaf:nick>
     </computer:user>

     <flickr:user rdf:about="http://www.flickr.com/people/34427469121@N01">
       <foaf:mbox_sha1sum>216d56f03517c68e527c5b970552a181980c4389</foaf:mbox_sha1sum>
       <foaf:name>George Oates</foaf:name>
       <foaf:nick>George</foaf:nick>
     </flickr:user>

     <flickr:note rdf:about="http://www.flickr.com/photos/35034348999@N01/30763528#note-1140946">
       <i:boundingBox>355 31 103 95</i:boundingBox>
       <a:body>(Yes… I love you heather, you are my dream star)</a:body>
       <i:regionDepicts rdf:resource="http://static.flickr.com/23/30763528_a981fab285.jpg"/>
       <a:author rdf:resource="http://www.flickr.com/people/44124415257@N01"/>
       <a:annotates rdf:resource="http://www.flickr.com/photos/35034348999@N01/30763528"/>
     </flickr:note>

     <rdf:Description rdf:about="x-urn:flickr:tag">
       <rdfs:subClassOf rdf:resource="http://www.w3.org/2004/02/skos/core#Concept"/>
     </rdf:Description>

     <rdf:Description rdf:about="file:///home/asc/photos/2005/08/02/20050802-30763528-20050802_007.jpg">
       <dcterms:created>2005-09-25T15:16:28Z</dcterms:created>
       <dc:creator rdf:resource="x-urn:dhclient#asc"/>
       <rdfs:seeAlso rdf:resource="http://www.flickr.com/photos/35034348999@N01/30763528"/>
     </rdf:Description>

     <rdf:Description rdf:about="file:///home/asc/photos/2005/08/02/20050802-30763528-20050802_007_m.jpg">
       <dcterms:created>2005-09-25T15:16:28Z</dcterms:created>
       <dc:creator rdf:resource="x-urn:dhclient#asc"/>
       <rdfs:seeAlso rdf:resource="http://www.flickr.com/photos/35034348999@N01/30763528"/>
     </rdf:Description>

     <rdf:Description rdf:about="x-urn:freebsd:user">
       <rdfs:subClassOf rdf:resource="http://xmlns.com/foaf/0.1/Person"/>
     </rdf:Description>

     <flickr:note rdf:about="http://www.flickr.com/photos/35034348999@N01/30763528#note-1143239">
       <i:boundingBox>184 164 50 50</i:boundingBox>
       <a:body>Baaaaarp!</a:body>
       <i:regionDepicts rdf:resource="http://static.flickr.com/23/30763528_a981fab285.jpg"/>
       <a:author rdf:resource="http://www.flickr.com/people/34427469121@N01"/>
       <a:annotates rdf:resource="http://www.flickr.com/photos/35034348999@N01/30763528"/>
     </flickr:note>

     <rdf:Description rdf:about="file:///home/asc/photos/2005/08/02/20050802-30763528-20050802_007_s.jpg">
       <dcterms:created>2005-09-25T15:16:28Z</dcterms:created>
       <dc:creator rdf:resource="x-urn:dhclient#asc"/>
       <rdfs:seeAlso rdf:resource="http://www.flickr.com/photos/35034348999@N01/30763528"/>
     </rdf:Description>

     <dcterms:StillImage rdf:about="http://static.flickr.com/23/30763528_a981fab285_t.jpg">
       <dcterms:relation>Thumbnail</dcterms:relation>
       <exifi:height>75</exifi:height>
       <exifi:width>100</exifi:width>
       <dcterms:isVersionOf rdf:resource="http://static.flickr.com/23/30763528_a981fab285_o.jpg"/>
       <rdfs:seeAlso rdf:resource="http://www.flickr.com/photos/35034348999@N01/30763528"/>
     </dcterms:StillImage>

     <flickr:note rdf:about="http://www.flickr.com/photos/35034348999@N01/30763528#note-1140945">
       <i:boundingBox>433 103 50 50</i:boundingBox>
       <a:body>(fuck… fuck…)</a:body>
       <i:regionDepicts rdf:resource="http://static.flickr.com/23/30763528_a981fab285.jpg"/>
       <a:author rdf:resource="http://www.flickr.com/people/44124415257@N01"/>
       <a:annotates rdf:resource="http://www.flickr.com/photos/35034348999@N01/30763528"/>
     </flickr:note>

     <flickr:user rdf:about="http://www.flickr.com/people/32373682187@N01">
       <foaf:mbox_sha1sum>62bf10c8d5b56623226689b7be924c64dee5e94a</foaf:mbox_sha1sum>
       <foaf:name>heather powazek champ</foaf:name>
       <foaf:nick>heather</foaf:nick>
     </flickr:user>

     <rdf:Description rdf:about="x-urn:flickr:user">
       <rdfs:subClassOf rdf:resource="http://xmlns.com/foaf/0.1/Person"/>
     </rdf:Description>

     <flickr:tag rdf:about="http://www.flickr.com/people/tags/california">
       <skos:prefLabel>california</skos:prefLabel>
       <dc:creator rdf:resource="http://www.flickr.com/people/35034348999@N01"/>
       <dcterms:isPartOf rdf:resource="http://flickr.com/photos/tags/california"/>
     </flickr:tag>

     <dcterms:StillImage rdf:about="http://static.flickr.com/23/30763528_a981fab285.jpg">
       <dcterms:relation>Medium</dcterms:relation>
       <exifi:height>375</exifi:height>
       <exifi:width>500</exifi:width>
       <dcterms:isVersionOf rdf:resource="http://static.flickr.com/23/30763528_a981fab285_o.jpg"/>
       <rdfs:seeAlso rdf:resource="http://www.flickr.com/photos/35034348999@N01/30763528"/>
     </dcterms:StillImage>

     <flickr:note rdf:about="http://www.flickr.com/photos/35034348999@N01/30763528#note-1142648">
       <i:boundingBox>202 224 50 50</i:boundingBox>
       <a:body>dude! who did this?</a:body>
       <i:regionDepicts rdf:resource="http://static.flickr.com/23/30763528_a981fab285.jpg"/>
       <a:author rdf:resource="http://www.flickr.com/people/32373682187@N01"/>
       <a:annotates rdf:resource="http://www.flickr.com/photos/35034348999@N01/30763528"/>
     </flickr:note>

     <dcterms:StillImage rdf:about="http://static.flickr.com/23/30763528_a981fab285_o.jpg">
       <dcterms:relation>Original</dcterms:relation>
       <exifi:height>960</exifi:height>
       <exifi:width>1280</exifi:width>
       <rdfs:seeAlso rdf:resource="http://www.flickr.com/photos/35034348999@N01/30763528"/>
     </dcterms:StillImage>

     <flickr:user rdf:about="http://www.flickr.com/people/35034348999@N01">
       <foaf:mbox_sha1sum>a4d1b5e38db5e2ed4f847f9f09fd51cf59bc0d3f</foaf:mbox_sha1sum>
       <foaf:name>Aaron</foaf:name>
       <foaf:nick>straup</foaf:nick>
     </flickr:user>

     <flickr:note rdf:about="http://www.flickr.com/photos/35034348999@N01/30763528#note-1148950">
       <i:boundingBox>342 197 28 33</i:boundingBox>
       <a:body>Is that just one big boob, or...?</a:body>
       <i:regionDepicts rdf:resource="http://static.flickr.com/23/30763528_a981fab285.jpg"/>
       <a:author rdf:resource="http://www.flickr.com/people/34427469121@N01"/>
       <a:annotates rdf:resource="http://www.flickr.com/photos/35034348999@N01/30763528"/>
     </flickr:note>

     <rdf:Description rdf:about="x-urn:flickr:note">
       <rdfs:subClassOf rdf:resource="http://www.w3.org/2000/10/annotation-nsAnnotation"/>
     </rdf:Description>

     <flickr:tag rdf:about="http://www.flickr.com/people/tags/sanfrancisco">
       <skos:prefLabel>san francisco</skos:prefLabel>
       <skos:altLabel>sanfrancisco</skos:altLabel>
       <dc:creator rdf:resource="http://www.flickr.com/people/35034348999@N01"/>
       <dcterms:isPartOf rdf:resource="http://flickr.com/photos/tags/sanfrancisco"/>
     </flickr:tag>

    </rdf:RDF>

SEE ALSO
   Net::Flickr::API

   RDF::Simple

TO DO
   *   Methods for describing more than just a photo; groups, tags, etc.

   *   Proper Creative Commons RDF blobs

   *   Update bounding boxes to be relative to individual images

BUGS
   Please report all bugs via http://rt.cpan.org/

LICENSE
   Copyright (c) 2005 Aaron Straup Cope. All Rights Reserved.

   This is free software. You may redistribute it and/or modify it under
   the same terms as Perl itself.