]> iEval git - webservice-strike.git/blobdiff - lib/WebService/Strike.pm
Bump version and update Changes
[webservice-strike.git] / lib / WebService / Strike.pm
index 56d1c474d5dafe04de1ae05c4f2ef954d5126494..070a2a5d2f875f710eb5a6e2f9f2653cda64a1df 100644 (file)
@@ -5,33 +5,62 @@ use strict;
 use warnings;
 use parent qw/Exporter/;
 
-our @EXPORT    = qw/strike/; ## no critic (ProhibitAutomaticExportation)
-our @EXPORT_OK = qw/strike_query strike/;
-our $VERSION = '0.001002';
-our $BASE_URL = 'http://getstrike.net/api/torrents/';
+our @EXPORT    = qw/strike strike_search strike_imdb/;
+our @EXPORT_OK = (@EXPORT, 'strike_query');
+our $VERSION = '0.006';
+our $BASE_URL = 'https://getstrike.net/api/v2';
 
 use JSON::MaybeXS qw/decode_json/;
 use HTTP::Tiny;
 use Sort::ByExample qw/sbe/;
 use WebService::Strike::Torrent;
 
-sub _ht { HTTP::Tiny->new(agent => "WebService-Strike/$VERSION") }
+sub _ht { HTTP::Tiny->new(agent => "WebService-Strike/$VERSION", verify_SSL => 1) }
+
+sub _query {
+       my ($url) = @_;
 
-sub strike_query {
-       my (@hashes) = @_;
-       my $url = "$BASE_URL/info/?hashes=" . join ',', map { uc } @hashes;
        my $ht = _ht;
        my $response = $ht->get($url);
        die $response unless $response->{success}; ## no critic (RequireCarping)
        $response = decode_json $response->{content};
 
-       die $response unless ref $response eq 'ARRAY'; ## no critic (RequireCarping)
+       map { WebService::Strike::Torrent->new($_) } @{$response->{torrents}};
+}
+
+sub strike_query {
+       my (@hashes) = @_;
+       if (@hashes > 50) {
+               return strike_query (@hashes[0 .. 49]), strike_query (@hashes[50 .. $#hashes]);
+       }
+       my $url = "$BASE_URL/torrents/info/?hashes=" . join ',', map { uc } @hashes;
+
        my $sorter = sbe(\@hashes, {xform => sub { $_[0]->hash }});
-       my @torrents = map { WebService::Strike::Torrent->new($_) } @{$response->[1]};
-       @torrents = $sorter->(@torrents);
+       my @torrents = $sorter->(_query $url);
+       wantarray ? @torrents : $torrents[0]
+}
+
+sub strike_search {
+       my ($query, $full, %args) = @_;
+       $args{phrase} = $query;
+       my $url = "$BASE_URL/torrents/search/?" . HTTP::Tiny->www_form_urlencode(\%args);
+
+       my @torrents = _query $url;
+       @torrents = $torrents[0] unless wantarray;
+       @torrents = strike_query map { $_->hash } @torrents if $full;
        wantarray ? @torrents : $torrents[0]
 }
 
+sub strike_imdb {
+       my ($id) = @_;
+       my $url = "$BASE_URL/media/imdb/?imdbid=$id";
+       my $response = _ht->get($url);
+       return unless $response->{success};
+       my %imdb = %{decode_json $response->{content}};
+       $imdb{lc $_} = delete $imdb{$_} for keys %imdb; ## no critic (ProhibitUselessTopic)
+       \%imdb
+}
+
 BEGIN { *strike = \&strike_query }
 
 1;
@@ -41,7 +70,7 @@ __END__
 
 =head1 NAME
 
-WebService::Strike - Get torrent info from getstrike.net API
+WebService::Strike - [OBSOLETE] Get torrent info from the now-discontinued getstrike.net API
 
 =head1 SYNOPSIS
 
@@ -52,8 +81,23 @@ WebService::Strike - Get torrent info from getstrike.net API
   my $torrent = $t->torrent;   # Returns the torrent file
   $t->torrent('file.torrent'); # Downloads the torrent file to 'file.torrent'
 
+  my @debian = strike_search 'Debian';
+  say 'Found ' . @debian . ' torrents matching "Debian"';
+  say 'First torrent has info hash ' . $debian[0]->hash;
+
+  my $mp = strike_search 'Modern perl', 1, category => 'Books';
+  say 'Torrent has ' . $mp->count . ' files. They are:';
+  say join ' ', @{$mp->file_names};
+
+  my $info = strike_imdb 'tt1520211';
+  say 'IMDB ID ', $info->{imdbid}, ' is ', $info->{title}, ' (', $info->{year}, ')';
+  say 'Plot (short): ', $info->{shortplot};
+
 =head1 DESCRIPTION
 
+B<The API was discontinued. The code in this module remains, but it
+does not achieve any useful purpose.>
+
 Strike API is a service for getting information about a torrent given
 its info hash. WebService::Strike is a wrapper for this service.
 
@@ -61,19 +105,42 @@ its info hash. WebService::Strike is a wrapper for this service.
 
 =item B<strike>(I<@info_hashes>)
 
-Returns a list of hashrefs, one for each info hash. The hashrefs are
-blessed into the L<WebService::Strike::Torrent> package. Dies in case
-of error.
+Returns a list of L<WebService::Strike::Torrent> objects in list
+context or the first such object in scalar context. Dies in case of
+error.
 
 =item B<strike_query>
 
 Alias for B<strike>. Not exported by default.
 
+=item B<strike_search>(I<$phrase>, [I<$full>, [ key => value ... ]])
+
+Searches for torrents given a phrase. Returns a list of
+L<WebService::Strike::Torrent> objects in list context or the first
+such object in scalar context.
+
+If I<$full> is false (default), the returned objects will be
+incomplete: their B<file_names> and B<file_lengths> accessors will
+return undef.
+
+If I<$full> is true, B<strike> will be called with the info hashes of
+the found torrents, thus obtaining complete objects.
+
+You can filter the search by appending key => value pairs to the call.
+For example:
+
+  strike_search 'windows', 0, category => 'Applications', sub_category => 'Windows';
+
+=item B<strike_imdb>(I<$imdb_id>)
+
+Get informaton about a movie from IMDB. Takes an IMDB ID and returns a
+hashref of unspecified format. All keys are lowercased.
+
 =back
 
 =head1 SEE ALSO
 
-L<WebService::Strike::Torrent>, L<http://getstrike.net/api/>, L<WWW::Search::Torrentz>
+L<WebService::Strike::Torrent>, L<https://getstrike.net/api/>, L<WWW::Search::Torrentz>
 
 =head1 AUTHOR
 
@@ -81,7 +148,7 @@ Marius Gavrilescu, E<lt>marius@ieval.roE<gt>
 
 =head1 COPYRIGHT AND LICENSE
 
-Copyright (C) 2015 by Marius Gavrilescu
+Copyright (C) 2015-2016 by Marius Gavrilescu
 
 This library is free software; you can redistribute it and/or modify
 it under the same terms as Perl itself, either Perl version 5.20.2 or,
This page took 0.030552 seconds and 4 git commands to generate.