WWW::Opentracker::Stats::Mode::Conn - WWW::Opentracker::Stats::Mode::Conn documentation


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

Index


Code Index:

NAME

Top

WWW::Opentracker::Stats::Mode::Conn

DESCRIPTION

Top

Parses the connection statistics from opentracker.

METHODS

Top

parse_stats

 Args: $self, $payload

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

The payload looks like this (no indentation): 107 36 30353 seconds (8 hours) opentracker connections, 0 conns/s :: 0 success/s.

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::Conn;

use strict;
use warnings;

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


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

__PACKAGE__->mk_accessors(qw/_stats/);


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

    my ($total, $announces, $seconds, $total_per_sec, $ann_per_sec)
        = $payload =~ m{\A
                        (\d+) \s+
                        (\d+) \s+
                        (\d+) \s+ seconds \s+ \( \d+ \s+ hours \) \s+
                        opentracker \s+ connections , \s+
                                (\d+) \s+ conns/s \s+ :: \s+ (\d+) \s+ success/s \.
                }xms
        or die "Unable to parse payload: $payload";

    my %stats = (
        'total'     => $total,
        'announces' => $announces,
        'uptime'    => $seconds,
        'total_per_sec'     => $total_per_sec,
        'announces_per_sec' => $ann_per_sec,
    );

    return \%stats;
}


1;