X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=lib%2FWebService%2FStrike%2FTorrent.pm;h=1f0dae5e359b9c883dc31fba5738a4b43fc8ced5;hb=95b1c120488fa6a756ab596060099f85921dae73;hp=8c8a894badfe1622594f04b95d50a506279ada08;hpb=27da1d36f6be05af35e74a57848cabf138cf3fc3;p=webservice-strike.git diff --git a/lib/WebService/Strike/Torrent.pm b/lib/WebService/Strike/Torrent.pm index 8c8a894..1f0dae5 100644 --- a/lib/WebService/Strike/Torrent.pm +++ b/lib/WebService/Strike/Torrent.pm @@ -5,14 +5,13 @@ use strict; use warnings; use parent qw/Class::Accessor::Fast/; -our $VERSION = '0.001'; +our $VERSION = '0.002'; use Date::Parse qw/str2time/; use JSON::MaybeXS qw/decode_json/; -use URI::Escape qw/uri_escape/; use WebService::Strike; -__PACKAGE__->mk_ro_accessors(qw/torrent_hash torrent_title torrent_category sub_category seeds leeches file_count size upload_date uploader_username file_info file_names file_lengths/); +__PACKAGE__->mk_ro_accessors(qw/torrent_hash torrent_title torrent_category sub_category seeds leeches file_count size upload_date uploader_username file_info file_names file_lengths magnet_uri/); BEGIN { *hash = *torrent_hash; @@ -23,26 +22,24 @@ BEGIN { *uploader = *uploader_username; *names = *file_names; *lengths = *file_lengths; + *magnet = *magnet_uri; }; sub new{ my ($self, @args) = @_; $self = $self->SUPER::new(@args); $self->{torrent_hash} = uc $self->hash; - $self->{upload_date} = str2time $self->date; - $self->{file_names} = $self->file_info->[0]->{file_names}; - $self->{file_lengths} = $self->file_info->[0]->{file_lengths}; + $self->{upload_date} = str2time $self->date, 'UTC'; + if ($self->file_info) { + $self->{file_names} = $self->file_info->{file_names}; + $self->{file_lengths} = $self->file_info->{file_lengths}; + } $self } -sub magnet{ - my ($self) = @_; - 'magnet:?xt=urn:btih:' . $self->hash . '&dn=' . uri_escape $self->title -} - sub torrent{ my ($self, $file) = @_; - my $url = $WebService::Strike::BASE_URL . '/downloads/?hash=' . $self->hash; + my $url = $WebService::Strike::BASE_URL . '/download/?hash=' . $self->hash; my $ht = WebService::Strike::_ht(); ## no critic (ProtectPrivate) my $response = $ht->get($url); return unless $response->{success}; @@ -78,8 +75,8 @@ WebService::Strike::Torrent - Class representing information about a torrent say $t->seeds; say $t->leeches; say $t->count; # 1 - say $t->size; # 587 MB - say $t->date; # 1420495200 + say $t->size; # 615514112 + say $t->date; # 1420502400 say $t->uploader; # The_Doctor- say @{$t->names}; # archlinux-2015.01.01-dual.iso say @{$t->lengths}; # 615514112 @@ -126,8 +123,7 @@ The number of files contained in the torrent. =item B -The total size of the files in the torrent as a human-readable string. -See B for exact sizes. +The total size of the files in the torrent in bytes. =item B, B @@ -145,7 +141,7 @@ Arrayref of paths of files in the torrent. Arrayref of lengths of files in the torrent, in bytes. -=item B +=item B, B Magnet link for the torrent.