diff options
author | plegall <plg@piwigo.org> | 2009-11-22 23:59:14 +0000 |
---|---|---|
committer | plegall <plg@piwigo.org> | 2009-11-22 23:59:14 +0000 |
commit | f974668ef53c529ad4f44b594393ab04043696ad (patch) | |
tree | 489d64b152ed43ff8ea36f9143dd747a488c0254 /tools/piwigo_remote.pl | |
parent | 858b43e87a9911269505c1fbc9036b374e89a565 (diff) |
merge r4345 from branch 2.0 to trunk
feature 1051: ability to add/update a file for an existing photo. For example,
you can add the "high" later. Another example is to update the "web resized"
file (new dimensions is a common example). It also works for thumbnails.
Updating an existing file has no impact on the logical level (list of tags,
list of categories, title, description and so on).
git-svn-id: http://piwigo.org/svn/trunk@4348 68402e56-0260-453c-a942-63ccdbb3a9ee
Diffstat (limited to 'tools/piwigo_remote.pl')
-rw-r--r-- | tools/piwigo_remote.pl | 80 |
1 files changed, 78 insertions, 2 deletions
diff --git a/tools/piwigo_remote.pl b/tools/piwigo_remote.pl index 91b072aeb..8c8098daf 100644 --- a/tools/piwigo_remote.pl +++ b/tools/piwigo_remote.pl @@ -83,11 +83,10 @@ $result = $ua->post( # print "\n", $ua->cookie_jar->as_string, "\n"; if ($opt{action} eq 'pwg.images.add') { - use MIME::Base64 qw(encode_base64); use Digest::MD5::File qw/file_md5_hex/; $form = {}; - $form->{method} = 'pwg.images.add'; + $form->{method} = $opt{action}; my $original_sum = file_md5_hex($opt{original}); $form->{original_sum} = $original_sum; @@ -145,6 +144,70 @@ if ($opt{action} eq 'pwg.images.add') { } } +if ($opt{action} eq 'pwg.images.addFile') { + use Digest::MD5::File qw/file_md5_hex/; + + if (not defined $opt{define}{image_id}) { + die '--define image_id=1234 is missing'; + } + + # which file type are we going to add/update? + my $type = undef; + + foreach my $test_type (qw/thumbnail file high/) { + if (defined $opt{$test_type}) { + $type = $test_type; + last; + } + } + + if (not defined $type) { + die 'at least one of file/thumbnail/high parameters must be set'; + } + + my $type_code = typecode_from_typename($type); + + send_chunks( + filepath => $opt{$type}, + type => $type_code, + original_sum => file_md5_hex($opt{original}), + ); + + $form = {}; + $form->{method} = $opt{action}; + $form->{type} = $type_code; + $form->{sum} = file_md5_hex($opt{$type}); + + foreach my $key (keys %{ $opt{define} }) { + $form->{$key} = $opt{define}{$key}; + } + + my $response = $ua->post( + $conf{base_url}.'/ws.php?format=json', + $form + ); + + print "-" x 50, "\n"; + printf("response code : %u\n", $response->code); + printf("response message : %s\n", $response->message); + print "-" x 50, "\n"; + print "\n"; + +# use Data::Dumper; +# print Dumper($response->content); +# print Dumper(from_json($response->content)); + + if ($response->is_success) { + print "upload successful\n"; + } + else { + print Dumper($response); + warn 'A problem has occured during upload', "\n"; + warn $response->decoded_content, "\n"; + die $response->status_line; + } +} + if ($opt{action} eq 'pwg.tags.list') { use Text::ASCIITable; @@ -333,6 +396,7 @@ sub pwg_ws_get_query { sub send_chunks { my %params = @_; + use MIME::Base64 qw(encode_base64); use File::Slurp; my $content = read_file($params{filepath}); @@ -375,3 +439,15 @@ sub send_chunks { $chunk_id++; } } + +sub typecode_from_typename { + my ($typename) = @_; + + my $typecode = $typename; + + if ('thumbnail' eq $typename) { + $typecode = 'thumb'; + } + + return $typecode; +} |