summaryrefslogtreecommitdiffstats
path: root/lib/Smokeping/sorters/base.pm
blob: 73d9551bae1c42aa847b0f38eb73cd67008f6b27 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
package Smokeping::sorters::base;

=head1 NAME

Smokeping::sorters::base - Base Class for implementing SmokePing Sorters

=head1 OVERVIEW
 
Sorters are at the core of the SmokePing Charts feature, where the most
interesting graphs are presented on a single page. The Sorter decides which
graphs are considerd interesting.

Every sorter must inherit from the base class and provide it's own
methods for the 'business' logic.

In order to maintain a decent performance the sorters activity is split into
two parts.

The first part is active while the smokeping daemon gathers its data.
Whenever data is received, the sorter is called to calculate a 'value' for
the present data. On every 'query round' this information is stored in the
sorter store directory. Each smokeping process stores it's own information.
Since smokeping can run in multiple instances at the same time, the data may
be split over several files

The second part of the sorter is called from smokeping.cgi. It loads all the
information from the sorter store and integrates it into a single 'tree'. It
then calls each sorter with the pre-calculated data to get it sorted and to
and to select the interesting information.

=head1 DESCRIPTION

Every sorter must provide the following methods:

=cut

use vars qw($VERSION);
use Carp;

$VERSION = 1.0;

use strict;

=head2 new

The new method expects hash elements as an argument
eg new({x=>'\d+',y=>'\d+'},x=>1,y=>2). The first part is
a syntax rule for the arguments it should expect and the second part
are the arguments itself. The first part will be supplied
by the child class as it calls the parent method.

=cut

sub new(@)
{
    my $this   = shift;
    my $class   = ref($this) || $this;
    my $rules = shift;
    my $self = { param => { @_ } };
    foreach my $key (keys %{$self->{param}}){
	my $regex = $rules->{$key};
	croak "key '$key' is not known by this sorter" unless defined $rules->{$key};	
	croak "key '$key' contains invalid data: '$self->{param}{$key}'" unless $self->{param}{$key} =~ m/^$regex$/;
    }
    bless $self, $class;
    return $self;
}

=head2 Desc

Simply return the description of the function. This method must
be overwritten by a children of the base class.

=cut

sub Desc ($) {
    croak "Sorter::Desc must be overridden by the subclass";
}    

=head2 SortTree

Returns an array of 'targets'. It is up to the sorter to decide how many
entries the list should contain. If the list is empty, the whole entry will
be supressed in the webfrontend. 

The methode gets access to all the targets in the system, together with the
last data set acquired for each target.

=cut

sub SortTree($$) {
    my $self = shift;
    my $target = shift @{$self->{targets}};
    my $cache = shift;
    my $entries = $self->{param}{entries} || 3;
    my $sorted = [
        map { $entries-- > 0 ? { open => [ split '/', $_ ], value => $cache->{$_} } : () }
           sort { $cache->{$b} <=> $cache->{$a} } keys %$cache ];
    return $sorted;
}

=head2 CalcValues

Figure out the curent sorting value using te following input.

 $info = { uptime => w,
  	   loss   => x,
           median => y,
    	   alert  => z, # (0/1)
           pings  => [qw(a b c d)] }

The output can have any structure you want. It will be returned to the
sorter method for further processng.

=cut

sub CalcValue($) {
    my $self = shift;
    my $info = shift;
    croak "CalcValue must be overridden by the subclass";
    return ( { any=>'structure' } );
}


=head1 COPYRIGHT

Copyright (c) 2007 by OETIKER+PARTNER AG. All rights reserved.

=head1 LICENSE

This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.

=head1 AUTHOR

Tobias Oetiker <tobi@oetiker.ch>

=cut