NAME

Juno::Check::HTTP - An HTTP check for Juno

VERSION

version 0.002

DESCRIPTION

my $juno = Juno->new(
    checks => {
        HTTP => {
            hosts => [ 'tom', 'jerry' ],
            path  => '/my/custom/path',
        },
    }
);

ATTRIBUTES

path

The path that is checked.

Default: /.

headers

A hashref or additional headers to send to the server. This is useful if you want to run a request to a server requesting a specific website (i.e., VirtualHost).

hosts

An arrayref of hosts to check, overriding the default given to Juno.pm.

my $juno = Juno->new(
    hosts  => [ 'Tom', 'Jerry' ],
    checks => {
        HTTP => {
            hosts => [ 'Micky', 'Mini' ], # this overrides tom and jerry
        },
    },
);

Now the HTTP check will not check Tom and Jerry, but rather Micky and Mini.

This attribute derives from Juno::Role::Check.

interval

An integer of seconds between each check (nor per-host).

This attribute derives from Juno::Role::Check.

on_success

A coderef to run when making a successful request. This is done by checking the HTTP response header has a status code starting with 200 (which is by HTTP RFC a successful response).

This attribute derives from Juno::Role::Check.

on_fail

A coderef to run when making an unsuccessful request. This is the opposite of on_success described above.

This attribute derives from Juno::Role::Check.

on_result

A coderef to run when getting a response - any response. This is what you use in case you want more control over what's going on.

This attribute derives from Juno::Role::Check.

on_before

A coderef to run before making a request. A useful example of this is timing the request.

use Juno;
use AnyEvent;

my $cv   = AnyEvent->condvar;
my %time = (
    tom => AnyEvent->now,
);

my $juno = Juno->new(
    checks => {
        HTTP => {
            on_before => sub {
                my $host = $_[1];
                $time{$host} = AnyEvent->now;
            },

            on_result => sub {
                my $host = $_[1];
                my $time = AnyEvent->now - $time{'tom'};
                print "It took $time to run the request to $host\n";
            },
        },
    },
);

watcher

Holds the watcher for the HTTP check timer.

This attribute derives from Juno::Role::Check.

METHODS

check

Juno will call this method for you. You should not call it yourself.

run

Juno will call this method for you. You should not call it yourself.

AUTHORS

  • Sawyer X <xsawyerx@cpan.org>

  • Adam Balali <adamba@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2012 by Sawyer X.

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