[BACK]Return to API.pm CVS log [TXT][DIR] Up to [local] / todotxt / Text-Todo-REST-API / lib / Text / Todo / REST

Diff for /todotxt/Text-Todo-REST-API/lib/Text/Todo/REST/API.pm between version 1.9 and 1.19

version 1.9, 2010/01/23 07:15:40 version 1.19, 2010/02/16 06:12:26
Line 1 
Line 1 
 package Text::Todo::REST::API;  package Text::Todo::REST::API;
   
 # $AFresh1: API.pm,v 1.8 2010/01/19 03:18:34 andrew Exp $  # $AFresh1: API.pm,v 1.18 2010/02/13 21:48:28 andrew Exp $
   
 use warnings;  use warnings;
 use strict;  use strict;
 use Carp;  use Carp;
   
 use Text::Todo;  use Text::Todo;
   use Text::Todo::REST::API::Response;
   
   use Module::Pluggable
       instantiate => 'new',
       search_path => 'Text::Todo::REST::API::Actions',
       sub_name    => 'actions';
   
 use Class::Std::Utils;  use Class::Std::Utils;
 use Digest::MD5 qw/ md5_hex /;  
   
 use version; our $VERSION = qv('0.0.1');  use version; our $VERSION = qv('0.0.1');
   
Line 61 
Line 66 
     }      }
   
     sub _parse_options {      sub _parse_options {
         my ( $self, $method, @args ) = @_;          my ( $self, $method, @options) = @_;
   
         my %options = (          my %options = (
             method => lc $method,              method => lc $method,
             list   => '',              list   => '',
             action => 'files',              action => 'files',
             args   => [],              args   => {},
   
               suffix     => $self->_suffix,
               file_regex => $self->_file_regex,
               format     => $self->_format,
         );          );
   
         if (@args) {          if (@options) {
             if ( !ref $args[0] ) {              if ( !ref $options[0] ) {
                 $options{path} = shift @args;                  $options{path} = shift @options;
             }              }
   
             if ( ref $args[0] eq 'HASH' ) {              if ( ref $options[0] eq 'HASH' ) {
                 my $opts = shift @args;                  my $opts = shift @options;
                 foreach my $o ( keys %{$opts} ) {                  foreach my $o ( keys %{$opts} ) {
                     $options{$o} = $opts->{$o};                      $options{$o} = $opts->{$o};
                 }                  }
Line 94 
Line 103 
             }              }
         }          }
   
         if ($options{action} eq 'entry' && @{ $options{args} }) {          if ( $options{action} eq 'entry' && @{ $options{extra} } ) {
             $options{entry} = shift @{ $options{args} };              $options{action} .= q{_} . lc shift @{ $options{extra} };
             if (@{ $options{args} }) {  
                 $options{action} = lc shift @{ $options{args} };  
             }  
         }          }
   
           push @{ $options{extra} }, @options;
   
         push @{ $options{args} }, @args;          my $list = $self->_todo->file( $options{list} );
   
         $options{list} = defined $options{list} ? $options{list} : 'todo_file';          my $suffix = $self->_suffix || q{};
           if ( $list !~ / \Q$suffix\E $/ixms ) {
               $list .= $suffix;
           }
   
           $options{list} = $list;
   
         if ( $options{format} ) {          if ( $options{format} ) {
             $format_of{ ident $self } = $options{format};              $format_of{ ident $self } = $options{format};
             delete $options{format};              delete $options{format};
Line 124 
Line 137 
     sub _handle_action {      sub _handle_action {
         my ( $self, @args ) = @_;          my ( $self, @args ) = @_;
   
         my ($method, %options) = $self->_parse_options(@args);          my ( $method, %options ) = $self->_parse_options(@args);
   
         my $todo = $self->_todo;          my $todo = $self->_todo;
         $todo->load( $options{list} );          $todo->load( $options{list} );
   
         foreach my $class ( $self ) {          foreach my $class ( $self->actions ) {
             if ($class->can($method) ) {              if ( $class->can($method) ) {
                 return $class->$method( $todo, \%options );                  return Text::Todo::REST::API::Response->new(
                       {   type   => $options{action},
                           format => $self->_format,
                           data   => $class->$method( $todo, \%options ),
                       }
                   );
             }              }
         }          }
   
Line 142 
Line 160 
         my ( $self, $path ) = @_;          my ( $self, $path ) = @_;
   
         my %options = (          my %options = (
             list   => undef,  
             action => undef,              action => undef,
             args   => [],              list   => undef,
               entry  => undef,
               extra  => [],
         );          );
   
         $path = defined $path ? $path : q{};          $path = defined $path ? $path : q{};
Line 154 
Line 173 
             $options{format} = $1;              $options{format} = $1;
         }          }
   
         ( $options{list}, $options{action}, @{ $options{args} } ) = split '/',          ( $options{list}, $options{action},
             $path;            @{ $options{extra} } ) = split '/', $path;
   
         if ( $options{list} ) {          if (!defined $options{action}) {
             $options{action} ||= 'list';              if ( $options{list} ) {
                   $options{action} = 'list';
             my $suffix = $self->_suffix;  
   
             if (( lc $options{list} ) eq 'files') {  
                 $options{action} = lc $options{list};  
                 $options{list} = q{};  
             }              }
             elsif ($self->_todo->file( $options{list} )) {              else {
                $options{list} = $self->_todo->file( $options{list} );                  $options{action} = 'files';
             }              }
         }          }
   
         if ( @{ $options{args} } && ( lc $options{args}[0] ) eq 'entry' ) {          $options{action} = lc( $options{action} );
             $options{action} = lc shift @{ $options{args} };  
           if ($options{action} eq 'entry'
            || $options{action} eq 'tags'
           ) {
               $options{ $options{action} } = shift @{ $options{extra} };
         }          }
   
         return %options;          return %options;
Line 181 
Line 199 
     sub GET {      sub GET {
         my ( $self, @args ) = @_;          my ( $self, @args ) = @_;
         return $self->_handle_action( 'GET', @args );          return $self->_handle_action( 'GET', @args );
     }  
   
     sub get_entry {  
         my ( $self, $todo, $key ) = @_;  
   
         if ( !$key ) {  
             return $self->fail("get_entry requires arguments");  
         }  
         elsif ( ref $key eq 'ARRAY' ) {  
             my @entries;  
             foreach ( @{$key} ) {  
                 push @entries, $self->get_entry($_);  
             }  
             return @entries;  
         }  
         elsif ( ref $key eq 'HASH' ) {  
             if (exists $key->{entry}) {  
                $key = $key->{entry};  
             }  
             else {  
                 return $self->fail('get_entry requires key [entry]');  
             }  
         }  
   
         my @list = $self->get_list($todo);  
   
         my $entry;  
         if ( $key =~ /^[[:xdigit:]]{32}$/xms ) {  
             my $search = lc $key;  
   
         ENTRY: foreach my $e (@list) {  
                 if ( $search eq $e->{md5} ) {  
                     $entry = $e;  
                     last ENTRY;  
                 }  
             }  
         }  
         elsif ( $key =~ /^\d+$/xms ) {  
             $entry = $list[ $key - 1 ];  
         }  
   
         if ( !$entry ) {  
             return $self->fail("Unable to find entry!");  
         }  
   
         return $entry;  
     }  
   
     sub get_list {  
         my ($self, $todo) = @_;  
   
         my $line = 1;  
         return map ( {  
                 line => $line++,  
                 md5  => md5_hex( $_->text ),  
                 text => $_->text,  
             },  
             $todo->list );  
     }  
   
     sub get_files {  
         my ($self, $todo) = @_;  
         my $dir = $todo->file('todo_dir');  
   
         if ( !$dir ) {  
             return $self->fail('Unable to find todo_dir');  
         }  
   
         my $file_regex = $self->_file_regex;  
   
         opendir my $dh, $dir or croak "Couldn't opendir: $!";  
         my @files = grep {m/$file_regex/xms} readdir $dh;  
         closedir $dh;  
   
         return @files;  
     }  
   
     sub get_tags {  
         my ( $self, $todo, $tag ) = @_;  
         return $todo->listtag($tag);  
     }      }
   
     sub POST {      sub POST {

Legend:
Removed from v.1.9  
changed lines
  Added in v.1.19

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>