NAME

WWW::Crawler::Mojo - A web crawling framework for Perl

SYNOPSIS

use strict;
use warnings;
use WWW::Crawler::Mojo;

my $bot = WWW::Crawler::Mojo->new;

$bot->on(res => sub {
    my ($bot, $scrape, $job, $res) = @_;
    
    $scrape->();
});

$bot->on(refer => sub {
    my ($bot, $enqueue, $job, $context) = @_;
    
    $enqueue->();
});

$bot->enqueue('http://example.com/');
$bot->crawl;

DESCRIPTION

WWW::Crawler::Mojo is a web crawling framework for those who familier with Mojo::* APIs.

Note that the module is aimed at trivial use cases of crawling within a moderate range of web pages so DO NOT use it for persistent crawler jobs.

ATTRIBUTES

WWW::Crawler::Mojo inherits all attributes from Mojo::EventEmitter and implements the following new ones.

element_handlers

HTML element handler on scraping.

my $handlers = $bot->element_handlers;
$bot->element_handlers->{img} = sub {
    my $dom = shift;
    return $dom->{src};
};

clock_speed

A number of millisecond for main event loop interval. Defaults to 0.25.

$bot->clock_speed(2);
my $clock = $bot->clock_speed; # 2

max_conn

A number of max connections.

$bot->max_conn(5);
say $bot->max_conn; # 5

max_conn_per_host

A number of max connections per host.

$bot->max_conn_per_host(5);
say $bot->max_conn_per_host; # 5

queue

WWW::Crawler::Mojo::Queue::Memory object for default.

$bot->queue(WWW::Crawler::Mojo::Queue::Memory->new);
$bot->queue->enqueue($job);

shuffle

An interval in seconds to shuffle the job queue. It also evalutated as boolean for disabling/enabling the feature. Defaults to undef, meaning disable.

$bot->shuffle(5);
say $bot->shuffle; # 5

ua

A Mojo::UserAgent instance.

my $ua = $bot->ua;
$bot->ua(Mojo::UserAgent->new);

ua_name

Name of crawler for User-Agent header.

$bot->ua_name('my-bot/0.01 (+https://example.com/)');
say $bot->ua_name; # 'my-bot/0.01 (+https://example.com/)'

EVENTS

WWW::Crawler::Mojo inherits all events from Mojo::EventEmitter and implements the following new ones.

res

Emitted when crawler got response from server. The callback takes 4 arguments.

$bot->on(res => sub {
    my ($bot, $scrape, $job, $res) = @_;
    if (...) {
        $scrape->(sub {
            # called when URL found
        });
    } else {
        # DO NOTHING
    }
});

$bot

WWW::Crawler::Mojo instance.

$scrape

Scraper code reference for current document. The code takes a callback for argument in case a URL found.

$scrape(sub {
    my ($bot, $enqueue, $job, $context) = @_;
    ...
});
$bot

WWW::Crawler::Mojo instance.

$enqueue

Enqueue code reference for current URL. This is a shorthand of..

$bot->enqueue($job)
$job

WWW::Crawler::Mojo::Job instance.

$context

Either Mojo::DOM or Mojo::URL instance.

$job

WWW::Crawler::Mojo::Job instance.

$res

Mojo::Message::Response instance.

empty

Emitted when queue length got zero. The length is checked every 5 seconds.

$bot->on(empty => sub {
    my ($bot) = @_;
    say "Queue is drained out.";
});

error

Emitted when user agent returns no status code for request. Possibly caused by network errors or un-responsible servers.

$bot->on(error => sub {
    my ($bot, $error, $job) = @_;
    say "error: $_[1]";
    if (...) { # until failur occures 3 times
        $bot->requeue($job);
    }
});

Note that server errors such as 404 or 500 cannot be catched with the event. Consider res event for the use case instead of this.

start

Emitted right before crawl is started.

$bot->on(start => sub {
    my $self = shift;
    ...
});

METHODS

WWW::Crawler::Mojo inherits all methods from Mojo::EventEmitter and implements the following new ones.

crawl

Start crawling loop.

$bot->crawl;

init

Initialize crawler settings.

$bot->init;

process_job

Process a job.

$bot->process_job;

say_start

Displays starting messages to STDOUT

$bot->say_start;

scrape

Parses and discovers links in a web page. Each links are appended to FIFO array. This performs scraping.

$bot->scrape($res, $job, $cb);

enqueue

Append one or more URLs or WWW::Crawler::Mojo::Job objects.

$bot->enqueue('http://example.com/index1.html');

OR

$bot->enqueue($job1, $job2);

OR

$bot->enqueue(
    'http://example.com/index1.html',
    'http://example.com/index2.html',
    'http://example.com/index3.html',
);

requeue

Append one or more URLs or jobs for re-try. This accepts same arguments as enqueue method.

$self->on(error => sub {
    my ($self, $msg, $job) = @_;
    if (...) { # until failur occures 3 times
        $bot->requeue($job);
    }
});

collect_urls_html

Collects URLs out of HTML.

$bot->collect_urls_html($dom, sub {
    my ($uri, $dom) = @_;
});

collect_urls_css

Collects URLs out of CSS.

@urls = collect_urls_css($dom);

EXAMPLE

https://github.com/jamadam/WWW-Flatten

AUTHOR

Sugama Keita, <sugama@jamadam.com>

COPYRIGHT AND LICENSE

Copyright (C) jamadam

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.