NAME

Bot::Webalert - IRC bot watches Web sites and reports changes to IRC channels

SYNOPSIS

use Bot::Webalert;
use HTTP::Request::Common;

my $bot = Bot::Webalert->new(
    server      => 'irc.example.com',
    channels    => ["#friends_of_webalert"],
    ua_request  => GET("http://somewhere/changes.rss"),
);

$bot->run();

DESCRIPTION

Bot::Webalert implements an IRC bot that periodically checks the content of a web page and sends a message to an IRC channel if there are interesting changes.

Changes are determined by a user-defined callback function that gets called by the bot with the HTTP response object and either returns undef or a string with the message it wants the bot to send to the IRC channel. Typically, this is some explanatory text and the URL of the watched web page, so channel users can click on the link to see what's new.

The easiest way to write a web-watching bot is to let Bot::Webalert use its default response handler, which posts a message whenever the watched web page changes:

use Bot::Webalert;
use HTTP::Request::Common;

my $bot = Bot::Webalert->new(
    server      => 'irc.example.com',
    channels    => ["#friends_of_webalert"],
    ua_request  => GET("http://somewhere/changes.rss"),
);

$bot->run();

This will fetch the URL specified once per hour and call Bot::Webalert's default response handler, which triggers a message to the IRC channel the first time it is run and then whenever the web server's response is different from the previous one. The message sent by the default handler looks like

webalert-bot says: http://foobar.com has changed!

and will be sent to all channels specified in the channels option. If you'd like to customize the message or have better control over what kind of changes are reported, write your own response handler:

use Bot::Webalert;
use HTTP::Request::Common;

my $bot = Bot::Webalert->new(
        server   => 'irc.freenode.net',
        channels => ["#friends_of_webalert"],
        ua_request  => GET("http://somewhere/changes.rss"),
        ua_fetch_interval => 60, # check every minute
        ua_callback       => \&response_handler,
);

my $old_content = "";

sub response_handler {
    my($resp) = @_;

    if( $resp->is_success() ) {
        my $new_content = $resp->content();
        if($old_content ne $new_content) {
            $old_content = $new_content;
            return "Ladies and Gentlemen, new content on " .
                $resp->request->url->as_string() . " !";
        }
    }
    return undef;
}

$bot->run();

The response handler above returns a customized message if the fetch was successful and the web content has changed since the last call. Bot::Webalert will send the string returned by the response handler to the channel. If the response handler returns undef, no message will be sent.

Bot::BasicBot

Bot::Webalert ist a subclass of Tom Insam's excellent Bot-BasicBot package on CPAN. It uses POE under the hood, and Bot::Webalert adds further POE components like the POE::Component::Client::HTTP component to fetch web pages.

Logging

Bot::Webalert is Log4perl-enabled, so you can enable its embedded logging statements simply by initializing Log4perl:

use Log::Log4perl qw(:easy);
Log::Log4perl->easy_init($DEBUG);

As usual with Log4perl, you can enable logging in different parts of the system by initializing it differently, check log4perl.com for details.

LEGALESE

Copyright 2009 by Mike Schilli, all rights reserved. This program is free software, you can redistribute it and/or modify it under the same terms as Perl itself.

AUTHOR

2009, Mike Schilli <cpan@perlmeister.com>