NAME
WWW::PAUSE::RecentUploads - get the list of the recent uploads to PAUSE
SYNOPSIS
use strict;
use warnings;
use WWW::PAUSE::RecentUploads;
my $pause = WWW::PAUSE::RecentUploads->new(
login => 'LOGIN', # mandatory
pass => 'pass-o-word', # also mandatory
ua_args => { timeout => 10, }, # optional args to LWP::UserAgent
);
my $data = $pause->get_recent
or die "Failed to fetch data: " . $pause->error;
foreach my $dist ( @$data ) {
print "$dist->{dist} by $dist->{name} (size: $dist->{size})\n";
}
DESCRIPTION
Fetch the list of recent uploads on http://pause.perl.org and retrieve the dist's name, author's name and dist's size.
CONSTRUCTOR
new
my $pause = WWW::PAUSE::RecentUploads->new(
login => 'LOGIN', # mandatory
pass => 'pass-o-word', # also mandatory
ua_args => { timeout => 10, }, # optional args to LWP::UserAgent
);
Returns a WWW::PAUSE::RecentUploads object. Takes two mandatory and one optional arguments:
login
->new( login => 'YOUR_PAUSE_LOGIN' );
Mandatory. Module requires you to have an account on http://pause.perl.org. The login
argument's value must be your PAUSE login.
pass
->new( pass => 'secret_pass-o-word' );
Mandatory. Module requires you to have an account on http://pause.perl.org. The pass
argument's value must be your PAUSE password.
ua_args
->new(
ua_args => {
timeout => 10,
agent => 'PauseGrabber3000',
# the rest of LWP::UserAgent options can go here.
},
);
Optional. Using ua_args
argument you may specify arguments to pass on to LWP::UserAgent constructor. Note: by default LWP::UserAgent object is constructed with its default options with the exception of the timeout
argument which is set to 30
seconds.
METHODS
get_recent
my $data = $pause->get_recent
or die "Failed to fetch data: " . $pause->error;
Takes no arguments. Returns an arrayref or undef
in case of an error. If an error occured the content of it will be available via error()
method (see below). If succeeded returns an arrayref of hashrefs. Each of those hashref will contain three keys, which are as follows:
name
{ 'name' => 'ZOFFIX', }
The name
key will contain the name, or rather a PAUSE ID of the upload author.
dist
{ 'dist' => 'POE-Component-WebService-Validator-HTML-W3C-0.04' }
The dist
key will contain the name of the distro.
size
{ 'size' => '11467b' }
The size
key will contain the size of the distro. Note that this won't be "just a number" it will also be postfixed with a unit (which, probably will not always be b
for bytes).
error
my $data = $pause->get_recent
or die "Failed to fetch data: " . $pause->error;
If an error occured during fetching of data, the get_recent()
method (see above) will return undef
and you will be able to get sensible error with error()
method.
ACCESSORS/MUTATORS
login
my $current_login = $pause->login;
$pause->login( 'new_login' );
Take zero or one argument which is the PAUSE login (see login
argument for the constructor). Returns currently set login (which will be the argument if you provided one).
pass
my $current_pass = $pause->pass;
$pause->pass( 'new_pass0rwords' );
Take zero or one argument which is the PAUSE password (see pass
argument for the constructor). Returns currently set password (which will be the argument if you provided one).
ua_args
my $current_ua_args = $pause->ua_args;
$pause->ua_args( {
timeout => 60,
agent => 'Unknown',
# other LWP::UserAgent arguments can go here
}
);
Takes zero or one argument which must be a hashref of options to pass to LWP::UserAgent constructor (see ua_args
argument for the constructor as well as documentation for LWP::UserAgent). Returns currently set arguments (which will be the argument if you provided one).
BE HUMAN
PAUSE is a free service from which we all benifit and by means of which you are even reading this text. Please do not abuse it.
SEE ALSO
LWP::UserAgent, http://pause.perl.org
BUGS AND CAVEATS
No bugs known so far. Note that if the upload doesn't have a name of the author it will not be present in the results. This is not a bug, names usually appear a bit later than the dist name which is the reason for this.
PREREQUISITES
This module requires: Carp, LWP::UserAgent, HTML::TokeParser::Simple and URI modules as well as Test::More module for make test
AUTHOR
Zoffix Znet, <zoffix@cpan.org>
COPYRIGHT AND LICENSE
Copyright (C) 2008 by Zoffix Znet
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.8.8 or, at your option, any later version of Perl 5 you may have available.