.\" Automatically generated by Pod::Man v1.37, Pod::Parser v1.32 .\" .\" Standard preamble: .\" ======================================================================== .de Sh \" Subsection heading .br .if t .Sp .ne 5 .PP \fB\\$1\fR .PP .. .de Sp \" Vertical space (when we can't use .PP) .if t .sp .5v .if n .sp .. .de Vb \" Begin verbatim text .ft CW .nf .ne \\$1 .. .de Ve \" End verbatim text .ft R .fi .. .\" Set up some character translations and predefined strings. \*(-- will .\" give an unbreakable dash, \*(PI will give pi, \*(L" will give a left .\" double quote, and \*(R" will give a right double quote. | will give a .\" real vertical bar. \*(C+ will give a nicer C++. Capital omega is used to .\" do unbreakable dashes and therefore won't be available. \*(C` and \*(C' .\" expand to `' in nroff, nothing in troff, for use with C<>. .tr \(*W-|\(bv\*(Tr .ds C+ C\v'-.1v'\h'-1p'\s-2+\h'-1p'+\s0\v'.1v'\h'-1p' .ie n \{\ . ds -- \(*W- . ds PI pi . if (\n(.H=4u)&(1m=24u) .ds -- \(*W\h'-12u'\(*W\h'-12u'-\" diablo 10 pitch . if (\n(.H=4u)&(1m=20u) .ds -- \(*W\h'-12u'\(*W\h'-8u'-\" diablo 12 pitch . ds L" "" . ds R" "" . ds C` "" . ds C' "" 'br\} .el\{\ . ds -- \|\(em\| . ds PI \(*p . ds L" `` . ds R" '' 'br\} .\" .\" If the F register is turned on, we'll generate index entries on stderr for .\" titles (.TH), headers (.SH), subsections (.Sh), items (.Ip), and index .\" entries marked with X<> in POD. Of course, you'll have to process the .\" output yourself in some meaningful fashion. .if \nF \{\ . de IX . tm Index:\\$1\t\\n%\t"\\$2" .. . nr % 0 . rr F .\} .\" .\" For nroff, turn off justification. Always turn off hyphenation; it makes .\" way too many mistakes in technical documents. .hy 0 .if n .na .\" .\" Accent mark definitions (@(#)ms.acc 1.5 88/02/08 SMI; from UCB 4.2). .\" Fear. Run. Save yourself. No user-serviceable parts. . \" fudge factors for nroff and troff .if n \{\ . ds #H 0 . ds #V .8m . ds #F .3m . ds #[ \f1 . ds #] \fP .\} .if t \{\ . ds #H ((1u-(\\\\n(.fu%2u))*.13m) . ds #V .6m . ds #F 0 . ds #[ \& . ds #] \& .\} . \" simple accents for nroff and troff .if n \{\ . ds ' \& . ds ` \& . ds ^ \& . ds , \& . ds ~ ~ . ds / .\} .if t \{\ . ds ' \\k:\h'-(\\n(.wu*8/10-\*(#H)'\'\h"|\\n:u" . ds ` \\k:\h'-(\\n(.wu*8/10-\*(#H)'\`\h'|\\n:u' . ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'^\h'|\\n:u' . ds , \\k:\h'-(\\n(.wu*8/10)',\h'|\\n:u' . ds ~ \\k:\h'-(\\n(.wu-\*(#H-.1m)'~\h'|\\n:u' . ds / \\k:\h'-(\\n(.wu*8/10-\*(#H)'\z\(sl\h'|\\n:u' .\} . \" troff and (daisy-wheel) nroff accents .ds : \\k:\h'-(\\n(.wu*8/10-\*(#H+.1m+\*(#F)'\v'-\*(#V'\z.\h'.2m+\*(#F'.\h'|\\n:u'\v'\*(#V' .ds 8 \h'\*(#H'\(*b\h'-\*(#H' .ds o \\k:\h'-(\\n(.wu+\w'\(de'u-\*(#H)/2u'\v'-.3n'\*(#[\z\(de\v'.3n'\h'|\\n:u'\*(#] .ds d- \h'\*(#H'\(pd\h'-\w'~'u'\v'-.25m'\f2\(hy\fP\v'.25m'\h'-\*(#H' .ds D- D\\k:\h'-\w'D'u'\v'-.11m'\z\(hy\v'.11m'\h'|\\n:u' .ds th \*(#[\v'.3m'\s+1I\s-1\v'-.3m'\h'-(\w'I'u*2/3)'\s-1o\s+1\*(#] .ds Th \*(#[\s+2I\s-2\h'-\w'I'u*3/5'\v'-.3m'o\v'.3m'\*(#] .ds ae a\h'-(\w'a'u*4/10)'e .ds Ae A\h'-(\w'A'u*4/10)'E . \" corrections for vroff .if v .ds ~ \\k:\h'-(\\n(.wu*9/10-\*(#H)'\s-2\u~\d\s+2\h'|\\n:u' .if v .ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'\v'-.4m'^\v'.4m'\h'|\\n:u' . \" for low resolution devices (crt and lpr) .if \n(.H>23 .if \n(.V>19 \ \{\ . ds : e . ds 8 ss . ds o a . ds d- d\h'-1'\(ga . ds D- D\h'-1'\(hy . ds th \o'bp' . ds Th \o'LP' . ds ae ae . ds Ae AE .\} .rm #[ #] #H #V #F C .\" ======================================================================== .\" .IX Title "Net::Flickr::Backup 3" .TH Net::Flickr::Backup 3 "2008-01-18" "perl v5.8.8" "User Contributed Perl Documentation" .SH "NAME" Net::Flickr::Backup \- OOP for backing up your Flickr photos locally .SH "SYNOPSIS" .IX Header "SYNOPSIS" .Vb 2 \& use Net::Flickr::Backup; \& use Log::Dispatch::Screen; .Ve .PP .Vb 1 \& my $flickr = Net::Flickr::Backup->new($cfg); .Ve .PP .Vb 2 \& my $feedback = Log::Dispatch::Screen->new('name' => 'info', \& 'min_level' => 'info'); .Ve .PP .Vb 2 \& $flickr->log()->add($feedback); \& $flickr->backup(); .Ve .SH "DESCRIPTION" .IX Header "DESCRIPTION" \&\s-1OOP\s0 for backing up your Flickr photos locally. .SH "OPTIONS" .IX Header "OPTIONS" Options are passed to Net::Flickr::Backup using a Config::Simple object or a valid Config::Simple config file. Options are grouped by \*(L"block\*(R". .Sh "flickr" .IX Subsection "flickr" .IP "* \fBapi_key\fR" 4 .IX Item "api_key" String. \fIrequired\fR .Sp A valid Flickr \s-1API\s0 key. .IP "* \fBapi_secret\fR" 4 .IX Item "api_secret" String. \fIrequired\fR .Sp A valid Flickr Auth \s-1API\s0 secret key. .IP "* \fBauth_token\fR" 4 .IX Item "auth_token" String. \fIrequired\fR .Sp A valid Flickr Auth \s-1API\s0 token. .Sp The \fBapi_handler\fR defines which XML/XPath handler to use to process \s-1API\s0 responses. .RS 4 .IP "* \fBLibXML\fR" 4 .IX Item "LibXML" Use XML::LibXML. .IP "* \fBXPath\fR" 4 .IX Item "XPath" Use XML::XPath. .RE .RS 4 .RE .Sh "backup" .IX Subsection "backup" .IP "* \fBphotos_root\fR" 4 .IX Item "photos_root" String. \fIrequired\fR .Sp The root folder where you want photographs to be stored. Individual files are named using the following pattern : .Sp .Vb 1 \& B/B/B/B
/B-B-B_B.jpg .Ve .Sp Where the various components are : .RS 4 .IP "* \fB\s-1YYYYMMDD\s0\fR" 4 .IX Item "YYYYMMDD" .Vb 1 \& photo[@id=123]/dates/@taken .Ve .IP "* \fBphoto_id\fR" 4 .IX Item "photo_id" photo/@id .IP "* \fBclean_title\fR" 4 .IX Item "clean_title" .Vb 1 \& photo[@id=123]/title .Ve .Sp Unicode characters translated in to \s-1ASCII\s0 (using Text::Unidecode) and the entire string is stripped anything that is not an alphanumeric, underbar, dash or a square bracket. .IP "* \fBsize\fR" 4 .IX Item "size" Net::Flickr::Backup will attempt to fetch not only the original file uploaded to Flickr but also, depending on your config options, the medium and square versions. Filenames will be modified as follows : .RS 4 .IP "* \fBoriginal\fR" 4 .IX Item "original" The original photo you uploaded to the Flickr servers. No extension is added. .IP "* \fBmedium\fR" 4 .IX Item "medium" These photos are scaled to 500 pixels at the longest dimension. A \fB_m\fR extension is added. .IP "* \fBsquare\fR" 4 .IX Item "square" These photos are to cropped to 75 x 75 pixels at the center. A \fB_s\fR extension is added. .RE .RS 4 .RE .RE .RS 4 .RE .IP "* \fBfetch_original\fR" 4 .IX Item "fetch_original" Boolean. .Sp Retrieve the \*(L"original\*(R" version of a photo from the Flickr servers. .Sp Default is true. .IP "* \fBfetch_medium\fR" 4 .IX Item "fetch_medium" Boolean. .Sp Retrieve the \*(L"medium\*(R" version of a photo from the Flickr servers; these photos have been scaled to 500 pixels at the longest dimension. .Sp Default is false. .IP "* \fBfetch_square\fR" 4 .IX Item "fetch_square" Boolean. .Sp Retrieve the \*(L"square\*(R" version of a photo from the Flickr servers; these photos have been cropped to 75 x 75 pixels at the center. .Sp Default is false. .IP "* \fBscrub_backups\fR" 4 .IX Item "scrub_backups" Boolean. .Sp If true then, for each Flickr photo \s-1ID\s0 backed up, the library will check \&\fBbackup.photos_root\fR for images (and metadata files) with a matching \s-1ID\s0 but a different name. Matches will be deleted. .IP "* \fBforce\fR" 4 .IX Item "force" Boolean. .Sp Force a photograph to be backed up even if it has not changed. .Sp Default is false. .Sh "rdf" .IX Subsection "rdf" .IP "* \fBdo_dump\fR" 4 .IX Item "do_dump" Boolean. .Sp Generate an \s-1RDF\s0 description for each photograph. Descriptions are written to disk in separate files. .Sp Default is false. .IP "* \fBrdfdump_root\fR" 4 .IX Item "rdfdump_root" String. .Sp The path where \s-1RDF\s0 data dumps for a photo should be written. The default is the same path as \fBbackup.photos_root\fR. .Sp File names are generated with the same pattern used to name photographs. .IP "* \fBrdfdump_inline\fR" 4 .IX Item "rdfdump_inline" Boolean. .Sp Set to true if you want the \s-1RDF\s0 dump for a photo to be stored in the file's \&\s-1JPEG\s0 \s-1COM\s0 block. \s-1RDF\s0 data will only be stored (for the time being) in the original image file and not any of the scaled versions. .Sp This option will only work for \s-1JPEG\s0 files and is still \fBexperimental\fR. It may change or, you know, not always work. Using Adobe's \s-1XMP\s0 spec is on the list of things to poke at so if you've got any suggestions on the subject, they'd be welcome. .Sp Default is false. .IP "* \fBphotos_alias\fR" 4 .IX Item "photos_alias" String. .Sp If defined this string is applied as regular expression substitution to \&\fBbackup.photos_root\fR. .Sp Default is to append the \fBfile:/\fR \s-1URI\s0 protocol to a path. .IP "* \fBquery_geonames\fR" 4 .IX Item "query_geonames" Boolean. .Sp If true and a photo has geodata (latitude, longitude) associated with it, then the geonames.org database will be queried for a corresponding match. Data will be added as properties of the photo's geo:Point description. For example : .Sp .Vb 8 \& \& -122.025151 \& 16 \& visbility \& 37.417839 \& public \& \& .Ve .Sp .Vb 8 \& \& PPLX \& US \& CA \& California \& Santa Clara \& 2 \& .Ve .IP "* " 4 .IX Item "" Boolean. .Sp If true, the trynt colour extraction web service will be queried with the \s-1URL\s0 for the \*(L"medium\*(R" sized photo. Each colour will be added as it's own description, referenced from the photo's principal description. For example : .Sp .Vb 3 \& \& \& .Ve .Sp .Vb 4 \& \& c0c0c0 \& 654 \& .Ve .Sp Default is false. .Sh "iptc" .IX Subsection "iptc" .IP "* \fBdo_dump\fR" 4 .IX Item "do_dump" Boolean. .Sp If true, then a limited set of metadata associated with a photo will be stored as \s-1IPTC\s0 information. .Sp A photo's title is stored as the \s-1IPTC\s0 \fBHeadline\fR, description as \fBCaption/Abstract\fR and tags are stored in one or more \fBKeyword\fR headers. Per the \s-1IPTC\s0 7901 spec, all text is converted to the \s-1ISO\-8859\-1\s0 character encoding. .Sp For example : .Sp .Vb 8 \& exiv2 -pi /home/asc/photos/2006/06/20/20060620-171674319-mie.jpg \& Iptc.Application2.RecordVersion Short 1 2 \& Iptc.Application2.Keywords String 11 cameraphone \& Iptc.Application2.Keywords String 15 "san francisco" \& Iptc.Application2.Keywords String 5 filtr \& Iptc.Application2.Keywords String 3 mie \& Iptc.Application2.Keywords String 20 upcoming:event=77752 \& Iptc.Application2.Headline String 3 Mie .Ve .Sp Default is false. .Sh "search" .IX Subsection "search" Any valid parameter that can be passed to the \fIflickr.photos.search\fR method \fBexcept\fR 'user_id' which is pre-filled with the user_id that corresponds to the \fBflickr.auth_token\fR token. .Sh "modified_since" .IX Subsection "modified_since" String. .PP This specifies a time-based limiting criteria for fetching photos. .PP The syntax is \fB(n)(modifier)\fR where \fB(n)\fR is a positive integer and \fB(modifier)\fR may be one of the following : .IP "* \fBh\fR" 4 .IX Item "h" Fetch photos that have been modified in the last \fB(n)\fR hours. .IP "* \fBd\fR" 4 .IX Item "d" Fetch photos that have been modified in the last \fB(n)\fR days. .IP "* \fBw\fR" 4 .IX Item "w" Fetch photos that have been modified in the last \fB(n)\fR weeks. .IP "* \fBM\fR" 4 .IX Item "M" Fetch photos that have been modified in the last \fB(n)\fR months. .SH "PACKAGE METHODS" .IX Header "PACKAGE METHODS" .Sh "_\|_PACKAGE_\|_\->new($cfg)" .IX Subsection "__PACKAGE__->new($cfg)" Returns a \fINet::Flickr::Backup\fR object. .SH "OBJECTS METHODS YOU SHOULD CARE ABOUT" .IX Header "OBJECTS METHODS YOU SHOULD CARE ABOUT" .Sh "$obj\->\fIbackup()\fP" .IX Subsection "$obj->backup()" Returns true or false. .SH "OBJECT METHODS YOU MAY CARE ABOUT" .IX Header "OBJECT METHODS YOU MAY CARE ABOUT" .Sh "$obj\->backup_photo($id,$secret)" .IX Subsection "$obj->backup_photo($id,$secret)" Backup an individual photo. This method is called internally by \&\fIbackup\fR. .Sh "$obj\->\fIscrub()\fP" .IX Subsection "$obj->scrub()" Returns true or false. .Sh "$obj\->\fIcancel_backup()\fP" .IX Subsection "$obj->cancel_backup()" Cancel the backup process as soon as the current photo backup is complete. .Sh "$obj\->register_callback($name, \e&func)" .IX Subsection "$obj->register_callback($name, &func)" \&\fBThis method is still considered experimental and may be removed.\fR .PP Valid callback triggers are : .IP "* \fBstart_backup_queue\fR" 4 .IX Item "start_backup_queue" The list of photos to be backed up is pulled from the Flickr servers is done in batches. This trigger is invoked for the first successful result set. .Sp The callback function will be passed a \fIXML::XPath\fR representation of the result document returned by the Flickr \s-1API\s0. .IP "* \fBfinish_backup_queue\fR" 4 .IX Item "finish_backup_queue" This trigger is invoked after the last photo has been backed up. .IP "* \fBstart_backup_photo\fR" 4 .IX Item "start_backup_photo" This trigger is invoked before the object's \fBbackup_photo\fR method is called. .Sp The callback function will be passed a \fIXML::XPath\fR representation of the current photo, as returned by the Flickr \s-1API\s0. .IP "* \fBfinish_backup_photo\fR" 4 .IX Item "finish_backup_photo" This trigger is invoked after the object's \fBbackup_photo\fR method is called. .Sp The callback function will be passed a \fIXML::XPath\fR representation of the current photo, as returned by the Flickr \s-1API\s0, followed by a boolean indicating whether or not the backup was successful. .PP Returns true or false, if \fI$func\fR is not a valid code reference. .Sh "$obj\->\fInamespaces()\fP" .IX Subsection "$obj->namespaces()" Returns a hash ref of the prefixes and namespaces used by \fINet::Flickr::RDF\fR .PP The default key/value pairs are : .IP "\fBa\fR" 4 .IX Item "a" http://www.w3.org/2000/10/annotation\-ns .IP "\fBacl\fR" 4 .IX Item "acl" http://www.w3.org/2001/02/acls# .IP "\fBdc\fR" 4 .IX Item "dc" http://purl.org/dc/elements/1.1/ .IP "\fBdcterms\fR" 4 .IX Item "dcterms" http://purl.org/dc/terms/ .IP "\fBexif\fR" 4 .IX Item "exif" http://nwalsh.com/rdf/exif# .IP "\fBexifi\fR" 4 .IX Item "exifi" http://nwalsh.com/rdf/exif\-intrinsic# .IP "\fBflickr\fR" 4 .IX Item "flickr" x\-urn:flickr: .IP "\fBfoaf\fR" 4 .IX Item "foaf" http://xmlns.com/foaf/0.1/# .IP "\fBgeo\fR" 4 .IX Item "geo" http://www.w3.org/2003/01/geo/wgs84_pos# .IP "\fBi\fR" 4 .IX Item "i" http://www.w3.org/2004/02/image\-regions# .IP "\fBrdf\fR" 4 .IX Item "rdf" http://www.w3.org/1999/02/22\-rdf\-syntax\-ns# .IP "\fBrdfs\fR" 4 .IX Item "rdfs" http://www.w3.org/2000/01/rdf\-schema# .IP "\fBskos\fR" 4 .IX Item "skos" http://www.w3.org/2004/02/skos/core# .IP "\fBtrynt\fR" 4 .IX Item "trynt" http://www.trynt.com# .PP \&\fINet::Flickr::Backup\fR adds the following namespaces : .IP "\fBcomputer\fR" 4 .IX Item "computer" x\-urn:\fB$OSNAME\fR: (where \f(CW$OSNAME\fR is the value of the English.pm \&\f(CW$OSNAME\fR variable. .Sh "$obj\->namespace_prefix($uri)" .IX Subsection "$obj->namespace_prefix($uri)" Return the namespace prefix for \fI$uri\fR .Sh "$obj\->uri_shortform($prefix,$name)" .IX Subsection "$obj->uri_shortform($prefix,$name)" Returns a string in the form of \fIprefix\fR:\fIproperty\fR. The property is the value of \f(CW$name\fR. 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. .PP The prefix passed to the method is assumed to be one of prefixes in the \&\fBdefault\fR list of namespaces. .Sh "$obj\->make_photo_triples(\e%data)" .IX Subsection "$obj->make_photo_triples(%data)" Returns an array ref of array refs of the meta data associated with a photo (\fI%data\fR). .PP If any errors are unencounter an error is recorded via the \fBlog\fR method and the method returns undef. .Sh "$obj\->namespace_prefix($uri)" .IX Subsection "$obj->namespace_prefix($uri)" Return the namespace prefix for \fI$uri\fR .Sh "$obj\->uri_shortform($prefix,$name)" .IX Subsection "$obj->uri_shortform($prefix,$name)" Returns a string in the form of \fIprefix\fR:\fIproperty\fR. The property is the value of \f(CW$name\fR. 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. .PP The prefix passed to the method is assumed to be one of prefixes in the \&\fBdefault\fR list of namespaces. .Sh "$obj\->api_call(\e%args)" .IX Subsection "$obj->api_call(%args)" Valid args are : .IP "* \fBmethod\fR" 4 .IX Item "method" A string containing the name of the Flickr \s-1API\s0 method you are calling. .IP "* \fBargs\fR" 4 .IX Item "args" A hash ref containing the key value pairs you are passing to \&\fImethod\fR .PP If the method encounters any errors calling the \s-1API\s0, receives an \s-1API\s0 error or can not parse the response it will log an error event, via the \fBlog\fR method, and return undef. .PP Otherwise it will return a \fIXML::LibXML::Document\fR object (if XML::LibXML is installed) or a \fIXML::XPath\fR object. .Sh "$obj\->\fIlog()\fP" .IX Subsection "$obj->log()" Returns a \fILog::Dispatch\fR object. .SH "EXAMPLES" .IX Header "EXAMPLES" .Sh "\s-1CONFIG\s0 \s-1FILES\s0" .IX Subsection "CONFIG FILES" This is an example of a Config::Simple file used to back up photos tagged with 'cameraphone' from Flickr .PP .Vb 5 \& [flickr] \& api_key=asd6234kjhdmbzcxi6e323 \& api_secret=s00p3rs3k3t \& auth_token=123-omgwtf4u \& api_handler=LibXML .Ve .PP .Vb 3 \& [search] \& tags=cameraphone \& per_page=500 .Ve .PP .Vb 6 \& [backup] \& photos_root=/home/asc/photos \& scrub_backups=1 \& fetch_medium=1 \& fetch_square=1 \& force=0 .Ve .PP .Vb 3 \& [rdf] \& do_dump=1 \& rdfdump_root=/home/asc/photos .Ve .Sh "\s-1RDF\s0" .IX Subsection "RDF" This is an example of an \s-1RDF\s0 dump for a photograph backed up from Flickr (using Net::Flickr::RDF) : .PP .Vb 23 \& \& .Ve .PP .Vb 5 \& \& 2fc2c76d7634d1a6446b1898bf5471205ed3d0cb \& \& thincvox \& .Ve .PP .Vb 6 \& \& filtr \& \& \& \& .Ve .PP .Vb 9 \& \& PPLX \& US \& CA \& 58 \& State of California \& San Francisco County \& \& .Ve .PP .Vb 5 \& \& feature \& geonames \& \& .Ve .PP .Vb 7 \& \& Original \& 1944 \& 2592 \& \& \& .Ve .PP .Vb 3 \& \& cameraphone \& .Ve .PP .Vb 5 \& \& filtr \& \& \& .Ve .PP .Vb 15 \& \& Flash did not fire, auto mode \& 100/100 \& 100 \& 2592 \& 297/100 \& 1944 \& 5.6 mm \& 2007-05-30T15:10:01PDT \& sRGB \& f/2.8 \& 2007-05-30T15:10:01PDT \& 4351/1000 \& 0.049 sec (49/1000) \& .Ve .PP .Vb 4 \& \& 604040 \& 472 \& .Ve .PP .Vb 3 \& \& \& .Ve .PP .Vb 4 \& \& 000000 \& 4841 \& .Ve .PP .Vb 6 \& \& san francisco \& sanfrancisco \& \& \& .Ve .PP .Vb 3 \& \& sanfrancisco \& .Ve .PP .Vb 8 \& \& Medium \& 375 \& 500 \& \& \& \& .Ve .PP .Vb 5 \& \& 5405296 \& \& \& .Ve .PP .Vb 5 \& \& cameraphone \& \& \& .Ve .PP .Vb 5 \& \& \& LOG (2007) \& \& .Ve .PP .Vb 7 \& \& 6065-522214395-72157600293655654 \& 2007-05-31T14:54:25 \& Kittens! \& \& \& .Ve .PP .Vb 5 \& \& 587a68f90c4030a9b0c7d8ca6ff8549a8b40e5cd \& Aaron Straup Cope \& straup \& .Ve .PP .Vb 6 \& \& n95 \& \& \& \& .Ve .PP .Vb 3 \& \& \& .Ve .PP .Vb 7 \& \& 6065-522214395-72157600295486776 \& 2007-06-01T00:19:05 \& here kitty, kitty, <a href="http://thincvox.com/audio_recordings/meow.mp3">meow</a> \& \& \& .Ve .PP .Vb 6 \& \& 5405296 \& \& \& \& .Ve .PP .Vb 5 \& \& process \& filtr \& \& .Ve .PP .Vb 5 \& \& debug \& geo \& \& .Ve .PP .Vb 35 \& \& filtr \& namespace test \& visbility \& Untitled #1180563722 \& n95 \& All rights reserved. \& public \& \& 2007-05-30T15:10:01-0700 \& 2007-05-30T15:18:39-0700 \& 5405296 \& \& \& \& \& \& \& \& \& \& \& \& \& \& \& \& \& \& \& \& \& \& \& .Ve .PP .Vb 8 \& \& Thumbnail \& 75 \& 100 \& \& \& \& .Ve .PP .Vb 3 \& \& \& .Ve .PP .Vb 9 \& \& -122.401937 \& visbility \& 37.794694 \& 16 \& public \& \& \& .Ve .PP .Vb 5 \& \& filtr \& \& \& .Ve .PP .Vb 4 \& \& 808080 \& 726 \& .Ve .PP .Vb 4 \& \& a08080 \& 575 \& .Ve .PP .Vb 4 \& \& 000020 \& 499 \& .Ve .PP .Vb 4 \& \& 402020 \& 749 \& .Ve .PP .Vb 5 \& \& n95 \& \& \& .Ve .PP .Vb 6 \& \& 2.0:1180823550 \& 2007-06-02T15:32:30-0700 \& \& \& .Ve .PP .Vb 3 \& \& filtr \& .Ve .PP .Vb 7 \& \& namespace test \& \& \& \& \& .Ve .PP .Vb 4 \& \& 200000 \& 841 \& .Ve .PP .Vb 8 \& \& Small \& 180 \& 240 \& \& \& \& .Ve .PP .Vb 3 \& \& \& .Ve .PP .Vb 4 \& \& 806060 \& 464 \& .Ve .PP .Vb 5 \& \& camera \& ph \& \& .Ve .PP .Vb 8 \& \& Square \& 75 \& 75 \& \& \& \& .Ve .PP .Vb 8 \& \& Large \& 768 \& 1024 \& \& \& \& .Ve .PP .Vb 4 \& \& c0a0a0 \& 488 \& .Ve .PP .Vb 7 \& \& San Francisco \& United States \& California \& San Francisco \& \& .Ve .PP .Vb 4 \& \& c0c0c0 \& 1475 \& .Ve .PP .Vb 5 \& \& namespace test \& \& \& .Ve .PP .Vb 1 \& .Ve .SH "VERSION" .IX Header "VERSION" 2.97 .SH "DATE" .IX Header "DATE" $Date: 2007/06/06 05:16:09 $ .SH "AUTHOR" .IX Header "AUTHOR" Aaron Straup Cope .SH "SEE ALSO" .IX Header "SEE ALSO" Net::Flickr::API .PP Net::Flickr::RDF .PP Config::Simple .PP http://www.flickr.com/services/api/misc.userauth.html .SH "BUGS" .IX Header "BUGS" Please report all bugs via http://rt.cpan.org .SH "LICENSE" .IX Header "LICENSE" Copyright (c) 2005\-2007 Aaron Straup Cope. All Rights Reserved. .PP This is free software. You may redistribute it and/or modify it under the same terms as Perl itself.