WWW::Opentracker::Stats::Mode::Scrape - WWW::Opentracker::Stats::Mode::Scrape documentation


WWW-Opentracker-Stats documentation Contained in the WWW-Opentracker-Stats distribution.

Index


Code Index:

NAME

Top

WWW::Opentracker::Stats::Mode::Scrape

DESCRIPTION

Top

Parses the scrape statistics from opentracker.

METHODS

Top

parse_stats

 Args: $self, $payload

Decodes the plain text data retrieved from the scrape statistics of opentracker.

The payload looks like this (no indentation): 19 0 33275 seconds (9 hours) opentracker scrape stats, 1 scrape/s (tcp and udp)

SEE ALSO

Top

WWW::Opentracker::Stats::Mode

AUTHOR

Top

Knut-Olav Hoven, <knutolav@gmail.com>

COPYRIGHT AND LICENSE

Top


WWW-Opentracker-Stats documentation Contained in the WWW-Opentracker-Stats distribution.
package WWW::Opentracker::Stats::Mode::Scrape;

use strict;
use warnings;

use parent qw/
    WWW::Opentracker::Stats::Mode
    Class::Accessor::Fast
/;


__PACKAGE__->_format('txt');
__PACKAGE__->_mode('scrp');

__PACKAGE__->mk_accessors(qw/_stats/);


sub parse_stats {
    my ($self, $payload) = @_;

    my ($tcp_scrapes, $udp_scrapes, $seconds, $scrapes_per_sec)
        = $payload =~ m{\A
                        (\d+) \s
                        (\d+) \s
                        (\d+) \s seconds \s \( \d+ \s hours \) \s
                        opentracker \s scrape \s stats , \s
                                (\d+) \s scrape/s \s
                }xms
        or die "Unable to parse payload: $payload";

    my %stats = (
        'tcp_scrapes'       => $tcp_scrapes,
        'udp_scrapes'       => $udp_scrapes,
        'uptime'            => $seconds,
        'scrapes_per_sec'   => $scrapes_per_sec,
    );

    return \%stats;
}


1;