Sophie

Sophie

distrib > Fedora > 14 > x86_64 > media > updates > by-pkgid > 392532c57231dafb162b8d60346f9f12 > files > 9

perl-Collectd-4.9.5-2.fc14.x86_64.rpm

package Collectd::Graph::Type::GenericStacked;

# Copyright (C) 2008,2009  Florian octo Forster <octo at verplant.org>
#
# 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; only version 2 of the License is applicable.
#
# 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.,
# 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.

use strict;
use warnings;
use base ('Collectd::Graph::Type');

use Collectd::Graph::Common (qw($ColorCanvas $ColorFullBlue $ColorHalfBlue
  group_files_by_plugin_instance ident_to_filename sanitize_type_instance
  get_faded_color sort_idents_by_type_instance));

return (1);

sub getGraphsNum
{
  my $obj = shift;
  my $group = group_files_by_plugin_instance (@{$obj->{'files'}});

  return (scalar (keys %$group));
}

sub getRRDArgs
{
  my $obj = shift;
  my $index = shift;

  my $group = group_files_by_plugin_instance (@{$obj->{'files'}});
  my @group = sort (keys %$group);

  my $rrd_opts = $obj->{'rrd_opts'} || [];
  my $format = $obj->{'rrd_format'} || '%5.1lf';

  my $idents = $group->{$group[$index]};
  my $ds_name_len = 0;

  my $ds = $obj->getDataSources ();
  if (!$ds)
  {
    confess ("obj->getDataSources failed.");
  }
  if (@$ds != 1)
  {
    confess ("I can only work with RRD files that have "
      . "exactly one data source!");
  }
  my $data_source = $ds->[0];

  my $rrd_title = $obj->getTitle ($idents->[0]);

  my $colors = $obj->{'rrd_colors'} || {};
  my @ret = ('-t', $rrd_title, @$rrd_opts);

  my $ignore_unknown = $obj->{'ignore_unknown'} || 0;
  if ($ignore_unknown)
  {
    if ($ignore_unknown =~ m/^(yes|true|on)$/i)
    {
      $ignore_unknown = 1;
    }
    else
    {
      $ignore_unknown = 0;
    }
  }

  my $stacking = $obj->{'stacking'};
  if ($stacking)
  {
    if ($stacking =~ m/^(no|false|off|none)$/i)
    {
      $stacking = 0;
    }
    else
    {
      $stacking = 1;
    }
  }
  else # if (!$stacking)
  {
    $stacking = 1;
  }

  if (defined $obj->{'rrd_vertical'})
  {
    push (@ret, '-v', $obj->{'rrd_vertical'});
  }

  if ($obj->{'custom_order'})
  {
    sort_idents_by_type_instance ($idents, $obj->{'custom_order'});
  }

  if ($ignore_unknown)
  {
    my $new_idents = [];
    for (@$idents)
    {
      if (exists ($obj->{'ds_names'}{$_->{'type_instance'}}))
      {
	push (@$new_idents, $_);
      }
    }

    if (@$new_idents)
    {
      $idents = $new_idents;
    }
  }

  $obj->{'ds_names'} ||= {};
  my @names = map { $obj->{'ds_names'}{$_->{'type_instance'}} || $_->{'type_instance'} } (@$idents);

  for (my $i = 0; $i < @$idents; $i++)
  {
    my $ident = $idents->[$i];
    my $filename = ident_to_filename ($ident);

    if ($ds_name_len < length ($names[$i]))
    {
      $ds_name_len = length ($names[$i]);
    }

    # Escape colons _after_ the length has been checked.
    $names[$i] =~ s/:/\\:/g;

    push (@ret,
      "DEF:min${i}=${filename}:${data_source}:MIN",
      "DEF:avg${i}=${filename}:${data_source}:AVERAGE",
      "DEF:max${i}=${filename}:${data_source}:MAX");
  }

  if ($stacking)
  {
    for (my $i = @$idents - 1; $i >= 0; $i--)
    {
      if ($i == (@$idents - 1))
      {
        push (@ret,
	  "CDEF:cdef${i}=avg${i},UN,0,avg${i},IF");
      }
      else
      {
        my $j = $i + 1;
        push (@ret,
          "CDEF:cdef${i}=avg${i},UN,0,avg${i},IF,cdef${j},+");
      }
    }

    for (my $i = 0; $i < @$idents; $i++)
    {
      my $type_instance = $idents->[$i]{'type_instance'};
      my $color = '000000';
      if (exists $colors->{$type_instance})
      {
        $color = $colors->{$type_instance};
      }

      $color = get_faded_color ($color);

      push (@ret,
        "AREA:cdef${i}#${color}");
    }
  }
  else # if (!$stacking)
  {
    for (my $i = @$idents - 1; $i >= 0; $i--)
    {
      push (@ret,
        "CDEF:cdef${i}=avg${i}");
    }
  }

  for (my $i = 0; $i < @$idents; $i++)
  {
    my $type_instance = $idents->[$i]{'type_instance'};
    my $ds_name = sprintf ("%-*s", $ds_name_len, $names[$i]);
    my $color = '000000';
    if (exists $colors->{$type_instance})
    {
      $color = $colors->{$type_instance};
    }
    push (@ret,
      "LINE1:cdef${i}#${color}:${ds_name}",
      "GPRINT:min${i}:MIN:${format} Min,",
      "GPRINT:avg${i}:AVERAGE:${format} Avg,",
      "GPRINT:max${i}:MAX:${format} Max,",
      "GPRINT:avg${i}:LAST:${format} Last\\l");
  }

  return (\@ret);
}

sub getGraphArgs
{
  my $obj = shift;
  my $index = shift;

  my $group = group_files_by_plugin_instance (@{$obj->{'files'}});
  my @group = sort (keys %$group);

  my $idents = $group->{$group[$index]};

  my @args = ();
  for (qw(hostname plugin plugin_instance type))
  {
    if (defined ($idents->[0]{$_}))
    {
      push (@args, $_ . '=' . $idents->[0]{$_});
    }
  }

  return (join (';', @args));
} # getGraphArgs


# vim: set shiftwidth=2 softtabstop=2 tabstop=8 :