centreon-plugins/doc/en/developer/plugins_advanced.md

39 KiB

Plugins / Connectors advenced documentation

IV. List of shared libraries in centreon directory

This chapter describes Centreon libraries which you can use in your development.


Table of contents

  1. Output
  2. Perfdata
  3. SNMP
  4. Misc
  5. Statefile
  6. HTTP
  7. DBI
  8. Model Classes Usage

1. Output

This library allows you to build output of your plugin.

1.1 output_add

Description

This function adds a string to the output (it is printed when the display() method is called). If the status is different from 'ok', the output associated with 'ok' status is not printed.

Parameters

Parameter Type Default Description
severity String OK Status of the output. Accepted values: OK, WARNING, CRITICAL, UNKNOWN.
separator String - Separator between status and output string.
short_msg String Short output (first line).
long_msg String Long output (used with --verbose option).
debug Int If set to 1, the message is displayed only when --debug option is passed

Example

This is an example of how to manage output:

$self->{output}->output_add(severity  => 'OK',
                            short_msg => 'All is ok');
$self->{output}->output_add(severity  => 'Critical',
                            short_msg => 'There is a critical problem');
$self->{output}->output_add(long_msg  => 'Port 1 is disconnected');

$self->{output}->display();

The displayed output is:

CRITICAL - There is a critical problem
Port 1 is disconnected

1.2 perfdata_add

Description

Add performance data to output (print it with display method). Performance data are displayed after '|'.

Parameters

Parameter Type Default Description
label String [legacy] Label of the performance data.
nlabel String Label of the performance data in a more standard and explicit fashion.
value Int Value of the performance data.
unit String Unit of the performance data.
warning String Warning threshold.
critical String Critical threshold.
min Int Minimum value of the performance data.
max Int Maximum value of the performance data.

Example

This is an example of how to add performance data:


$self->{output}->output_add(severity  => 'OK',
                            short_msg => 'Memory is ok');
$self->{output}->perfdata_add(label    => 'memory_used',
                              value    => 30000000,
                              unit     => 'B',
                              warning  => '80000000',
                              critical => '90000000',
                              min      => 0,
                              max      => 100000000);

$self->{output}->display();

Output displays :

OK - Memory is ok | 'memory_used'=30000000B;80000000;90000000;0;100000000

2. Perfdata

This library allows you to manage performance data.

2.1 get_perfdata_for_output

Description Manage thresholds of performance data for output.

Parameters

Parameter Type Default Description
label String Threshold label.
total Int Percent threshold to transform in global.
cast_int Int (0 or 1) Cast absolute to int.
op String Operator to apply to start/end value (uses with 'value').
value Int Value to apply with 'op' option.

Example

This is an example of how to manage performance data for output:

my $format_warning_perfdata  = $self->{perfdata}->get_perfdata_for_output(label => 'warning', total => 1000000000, cast_int => 1);
my $format_critical_perfdata = $self->{perfdata}->get_perfdata_for_output(label => 'critical', total => 1000000000, cast_int => 1);

$self->{output}->perfdata_add(label    => 'memory_used',
                              value    => 30000000,
                              unit     => 'B',
                              warning  => $format_warning_perfdata,
                              critical => $format_critical_perfdata,
                              min      => 0,
                              max      => 1000000000);

tip In this example, instead of print warning and critical thresholds in 'percent', the function calculates and prints these in 'bytes'.

2.2 threshold_validate

Description

Validate and affect threshold to a label.

Parameters

Parameter Type Default Description
label String Threshold label.
value String Threshold value.

Example

This example checks if warning threshold is correct:


if (($self->{perfdata}->threshold_validate(label => 'warning', value => $self->{option_results}->{warning})) == 0) {
  $self->{output}->add_option_msg(short_msg => "Wrong warning threshold '" . $self->{option_results}->{warning} . "'.");
  $self->{output}->option_exit();
}

tip You can see the correct threshold format here: https://nagios-plugins.org/doc/guidelines.html#THRESHOLDFORMAT

2.3 threshold_check

Description

Compare performance data value with threshold to determine status.

Parameters

Parameter Type Default Description
value Int Performance data value to compare.
threshold String array Threshold label to compare and exit status if reached.

Example

This example checks if performance data reached thresholds:

$self->{perfdata}->threshold_validate(label => 'warning', value => 80);
$self->{perfdata}->threshold_validate(label => 'critical', value => 90);
my $prct_used = 85;

my $exit = $self->{perfdata}->threshold_check(value => $prct_used, threshold => [ { label => 'critical', 'exit_litteral' => 'critical' }, { label => 'warning', exit_litteral => 'warning' } ]);

$self->{output}->output_add(severity  => $exit,
                            short_msg => sprint("Used memory is %i%%", $prct_used));
$self->{output}->display();

Output displays :

  WARNING - Used memory is 85% |

2.4 change_bytes

Description

Convert bytes to human readable unit. Return value and unit.

Parameters

Parameter Type Default Description
value Int Performance data value to convert.
network 1024 Unit to divide (1000 if defined).

Example

This example change bytes to human readable unit:


my ($value, $unit) = $self->{perfdata}->change_bytes(value => 100000);

print $value.' '.$unit."\n";

Output displays :

  100 KB

3. SNMP

This library allows you to use SNMP protocol in your plugin. To use it, add the following line at the beginning of your plugin.pm:

use base qw(centreon::plugins::script_snmp);

3.1 get_leef

Description

Return hash table of SNMP values for multiple OIDs (do not work with SNMP table).

Parameters

Example

This is an example of how to get 2 SNMP values:


my $oid_hrSystemUptime = '.1.3.6.1.2.1.25.1.1.0';
my $oid_sysUpTime = '.1.3.6.1.2.1.1.3.0';

my $result = $self->{snmp}->get_leef(oids => [ $oid_hrSystemUptime, $oid_sysUpTime ], nothing_quit => 1);

print $result->{$oid_hrSystemUptime}."\n";
print $result->{$oid_sysUpTime}."\n";

3.2 load

Description

Load a range of OIDs to use with get_leef method.

Parameters

Parameter Type Default Description
oids String array Array of OIDs to check.
instances Int array Array of OID instances to check.
instance_regexp String Regular expression to get instances from instances option.
begin Int Instance to begin
end Int Instance to end

Example

This is an example of how to get 4 instances of a SNMP table by using load method:

my $oid_dskPath = '.1.3.6.1.4.1.2021.9.1.2';

$self->{snmp}->load(oids => [$oid_dskPercentNode], instances => [1,2,3,4]);

my $result = $self->{snmp}->get_leef(nothing_quit => 1);

use Data::Dumper;
print Dumper($result);

This is an example of how to get multiple instances dynamically (memory modules of Dell hardware) by using load method:

my $oid_memoryDeviceStatus = '.1.3.6.1.4.1.674.10892.1.1100.50.1.5';
my $oid_memoryDeviceLocationName = '.1.3.6.1.4.1.674.10892.1.1100.50.1.8';
my $oid_memoryDeviceSize = '.1.3.6.1.4.1.674.10892.1.1100.50.1.14';
my $oid_memoryDeviceFailureModes = '.1.3.6.1.4.1.674.10892.1.1100.50.1.20';

my $result = $self->{snmp}->get_table(oid => $oid_memoryDeviceStatus);
$self->{snmp}->load(oids => [$oid_memoryDeviceLocationName, $oid_memoryDeviceSize, $oid_memoryDeviceFailureModes],
                    instances => [keys %$result],
                    instance_regexp => '(\d+\.\d+)$');

my $result2 = $self->{snmp}->get_leef();

use Data::Dumper;
print Dumper($result2);

3.3 get_table

Description

Return hash table of SNMP values for SNMP table.

Parameters

Parameter Type Default Description
oid String OID of the snmp table to check.
start Int First OID to check.
end Int Last OID to check.
dont_quit Int (0 or 1) 0 Don't quit even if an SNMP error occured.
nothing_quit Int (0 or 1) 0 Quit if no value is returned.
return_type Int (0 or 1) 0 Return a hash table with one level instead of multiple.

Example

This is an example of how to get a SNMP table:

my $oid_rcDeviceError            = '.1.3.6.1.4.1.15004.4.2.1';
my $oid_rcDeviceErrWatchdogReset = '.1.3.6.1.4.1.15004.4.2.1.2.0';

my $results = $self->{snmp}->get_table(oid => $oid_rcDeviceError, start => $oid_rcDeviceErrWatchdogReset);

use Data::Dumper;
print Dumper($results);

3.4 get_multiple_table

Description

Return hash table of SNMP values for multiple SNMP tables.

Parameters

Parameter Type Default Description
oids Hash table - Hash table of OIDs to check (Can be set by 'load' method).
- - - Keys can be: "oid", "start", "end".
dont_quit Int (0 or 1) 0 Don't quit even if an SNMP error occured.
nothing_quit Int (0 or 1) 0 Quit if no value is returned.
return_type Int (0 or 1) 0 Return a hash table with one level instead of multiple.

Example

This is an example of how to get 2 SNMP tables:

my $oid_sysDescr        = ".1.3.6.1.2.1.1.1";
my $aix_swap_pool       = ".1.3.6.1.4.1.2.6.191.2.4.2.1";

my $results = $self->{snmp}->get_multiple_table(oids => [
                                                      { oid => $aix_swap_pool},
                                                      { oid => $oid_sysDescr },
                                                ]);

use Data::Dumper;
print Dumper($results);

3.5 get_hostname

Description

Get hostname parameter (useful to get hostname in mode).

Parameters

None.

Example

This is an example of how to get hostname parameter:

my $hostname = $self->{snmp}->get_hostname();

3.6 get_port

Description

Get port parameter (useful to get port in mode).

Parameters

None.

Example

This is an example of how to get port parameter:

my $port = $self->{snmp}->get_port();

3.7 oid_lex_sort

Description

Return sorted OIDs.

Parameters

Parameter Type Default Description
- String array Array of OIDs to sort.

Example

This example prints sorted OIDs:

foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{results}->{$my_oid}})) {
  print $oid;
}

4. Misc

This library provides a set of miscellaneous methods. To use it, you can directly use the path of the method:

centreon::plugins::misc::<my_method>;

4.1 trim

Description

Strip whitespace from the beginning and end of a string.

Parameters

Parameter Type Default Description
- String String to strip.

Example

This is an example of how to use trim method:

my $word = '  Hello world !  ';
my $trim_word =  centreon::plugins::misc::trim($word);

print $word."\n";
print $trim_word."\n";

Output displays :

Hello world !

4.2 change_seconds

Description

Convert seconds to human readable text.

Parameters

Parameter Type Default Description
- Int Number of seconds to convert.

Example

This is an example of how to use change_seconds method:

my $seconds = 3750;
my $human_readable_time =  centreon::plugins::misc::change_seconds($seconds);

print 'Human readable time : '.$human_readable_time."\n";

Output displays :

Human readable time : 1h 2m 30s

4.3 backtick

Description

Execute system command.

Parameters

Parameter Type Default Description
command String Command to execute.
arguments String array Command arguments.
timeout Int 30 Command timeout.
wait_exit Int (0 or 1) 0 Command process ignore SIGCHLD signals.
redirect_stderr Int (0 or 1) 0 Print errors in output.

Example

This is an example of how to use backtick method:

my ($error, $stdout, $exit_code) = centreon::plugins::misc::backtick(
                                    command => 'ls /home',
                                    timeout => 5,
                                    wait_exit => 1
                                    );

print $stdout."\n";

Output displays files in '/home' directory.

4.4 execute

Description

Execute command remotely.

Parameters

Parameter Type Default Description
output Object Plugin output ($self->{output}).
options Object Plugin options ($self->{option_results}) to get remote options.
sudo String Use sudo command.
command String Command to execute.
command_path String Command path.
command_options String Command arguments.

Example

This is an example of how to use execute method. We suppose --remote option is enabled:

my $stdout = centreon::plugins::misc::execute(output => $self->{output},
                                              options => $self->{option_results},
                                              sudo => 1,
                                              command => 'ls /home',
                                              command_path => '/bin/',
                                              command_options => '-l');

Output displays files in /home using ssh on a remote host.

4.5 windows_execute

Description

Execute command on Windows.

Parameters

Parameter Type Default Description
output Object Plugin output ($self->{output}).
command String Command to execute.
command_path String Command path.
command_options String Command arguments.
timeout Int Command timeout.
no_quit Int Don't quit even if an error occured.

Example

This is an example of how to use windows_execute method.

my $stdout = centreon::plugins::misc::windows_execute(output => $self->{output},
                                                      timeout => 10,
                                                      command => 'ipconfig',
                                                      command_path => '',
                                                      command_options => '/all');

Output displays IP configuration on a Windows host.

5.Statefile

This library provides a set of methods to use a cache file. To use it, add the following line at the beginning of your mode:

use centreon::plugins::statefile;

5.1 read

Description

Read cache file.

Parameters

Parameter Type Default Description
statefile String Name of the cache file.
statefile_dir String Directory of the cache file.
memcached String Memcached server to use.

Example

This is an example of how to use read method:

$self->{statefile_value} = centreon::plugins::statefile->new(%options);
$self->{statefile_value}->check_options(%options);
$self->{statefile_value}->read(statefile => 'my_cache_file',
                               statefile_dir => '/var/lib/centreon/centplugins'
                              );

use Data::Dumper;
print Dumper($self->{statefile_value});

Output displays cache file and its parameters.

5.2 get

Description

Get data from cache file.

Parameters

Parameter Type Default Description
name String Get a value from cache file.

Example

This is an example of how to use get method:

$self->{statefile_value} = centreon::plugins::statefile->new(%options);
$self->{statefile_value}->check_options(%options);
$self->{statefile_value}->read(statefile => 'my_cache_file',
                               statefile_dir => '/var/lib/centreon/centplugins'
                              );

my $value = $self->{statefile_value}->get(name => 'property1');
print $value."\n";

Output displays value for 'property1' of the cache file.

5.3 write

Description

Write data to cache file.

Parameters

Parameter Type Default Description
data String Data to write in cache file.

Example

This is an example of how to use write method:

$self->{statefile_value} = centreon::plugins::statefile->new(%options);
$self->{statefile_value}->check_options(%options);
$self->{statefile_value}->read(statefile => 'my_cache_file',
                               statefile_dir => '/var/lib/centreon/centplugins'
                              );

my $new_datas = {};
$new_datas->{last_timestamp} = time();
$self->{statefile_value}->write(data => $new_datas);

Then, you can read the result in '/var/lib/centreon/centplugins/my_cache_file', timestamp is written in it.

6. HTTP

This library provides a set of methodss to use HTTP protocol. To use it, add the following line at the beginning of your mode:

use centreon::plugins::http;

Some options must be set in plugin.pm:

Option Type Description
hostname String IP Addr/FQDN of the webserver host.
port String HTTP port.
proto String Used protocol ('http' or 'https').
credentials Use credentials.
ntlm Use NTLM authentication (if --credentials is used).
username String Username (if --credentials is used).
password String User password (if --credentials is used).
proxyurl String Proxy to use.
url_path String URL to connect (start to '/').

6.1 connect

Description

Test a connection to an HTTP url. Return content of the webpage.

Parameters

This method use plugin options previously defined.

Example

This is an example of how to use connect method.

We suppose these options are defined :

  • --hostname = 'google.com'
  • --urlpath = '/'
  • --proto = 'http'
  • --port = 80
$self->{http} = centreon::plugins::http->new(output => $self->{output}, options => $self->{options});
$self->{http}->set_options(%{$self->{option_results}});
my $webcontent = $self->{http}->request();
print $webcontent;

Output displays content of the webpage '\http://google.com/'.

7. DBI

This library allows you to connect to databases. To use it, add the following line at the beginning of your plugin.pm:

use base qw(centreon::plugins::script_sql);

7.1 connect

Description

Connect to databases.

Parameters

Parameter Type Default Description
dontquit Int (0 or 1) 0 Don't quit even if errors occured.

Example

This is an example of how to use connect method.

The format of the connection string can have the following forms:

    DriverName:database_name
    DriverName:database_name@hostname:port
    DriverName:database=database_name;host=hostname;port=port

In plugin.pm:

$self->{sqldefault}->{dbi} = ();
$self->{sqldefault}->{dbi} = { data_source => 'mysql:host=127.0.0.1;port=3306' };

In your mode:

$self->{sql} = $options{sql};
my ($exit, $msg_error) = $self->{sql}->connect(dontquit => 1);

Then, you are connected to the MySQL database.

7.2 query

Description

Send query to database.

Parameters

Parameter Type Default Description
query String SQL query to send.

Example

This is an example of how to use query method:

$self->{sql}->query(query => q{SHOW /*!50000 global */ STATUS LIKE 'Slow_queries'});
my ($name, $result) = $self->{sql}->fetchrow_array();

print 'Name : '.$name."\n";
print 'Value : '.$value."\n";

Output displays count of MySQL slow queries.

7.3 fetchrow_array

Description

Return Array from sql query.

Parameters

None.

Example

This is an example of how to use fetchrow_array method:

$self->{sql}->query(query => q{SHOW /*!50000 global */ STATUS LIKE 'Uptime'});
my ($dummy, $result) = $self->{sql}->fetchrow_array();

print 'Uptime : '.$result."\n";

Output displays MySQL uptime.

7.4 fetchall_arrayref

Description

Return Array from SQL query.

Parameters

None.

Example

This is an example of how to use fetchrow_array method:

$self->{sql}->query(query => q{
      SELECT SUM(DECODE(name, 'physical reads', value, 0)),
          SUM(DECODE(name, 'physical reads direct', value, 0)),
          SUM(DECODE(name, 'physical reads direct (lob)', value, 0)),
          SUM(DECODE(name, 'session logical reads', value, 0))
      FROM sys.v_$sysstat
});
my $result = $self->{sql}->fetchall_arrayref();

my $physical_reads = @$result[0]->[0];
my $physical_reads_direct = @$result[0]->[1];
my $physical_reads_direct_lob = @$result[0]->[2];
my $session_logical_reads = @$result[0]->[3];

print $physical_reads."\n";

Output displays physical reads on Oracle database.

7.5 fetchrow_hashref

Description

Return Hash table from SQL query.

Parameters

None.

Example

This is an example of how to use fetchrow_hashref method:

$self->{sql}->query(query => q{
  SELECT datname FROM pg_database
});

while ((my $row = $self->{sql}->fetchrow_hashref())) {
  print $row->{datname}."\n";
}

Output displays Postgres databases.

8. Model Classes Usage

Introduction

With the experience of plugin development, we have created two classes:

  • centreon::plugins::templates::counter
  • centreon::plugins::templates::hardware

It was developed to have a more consistent code and less redundant code. According to context, you should use one of two classes for modes. Following classes can be used for whatever plugin type (SNMP, Custom, DBI,...).

Class counter

When to use it ?

If you have some counters (CPU Usage, Memory, Session...), you should use that class. If you have only one global counter to check, it's maybe not useful to use it (but only for these case).

Class methods

List of methods:

  • new: class constructor. Overload if you need to add some specific options or to use a statefile.
  • check_options: overload if you need to check your specific options.
  • manage_selection: overload if mandatory. Method to get informations for the equipment.
  • set_counters: overload if mandatory. Method to configure counters.

Class hardware

TODO

Table of content (1)

8.1. Example 1

We want to develop the following SNMP plugin:

  • measure the current sessions and current SSL sessions usages.
  package my::module::name;
  
  use base qw(centreon::plugins::templates::counter);
  
  use strict;
  use warnings;
  
  sub set_counters {
    my ($self, %options) = @_;
    
    $self->{maps_counters_type} = [
        { name => 'global', type => 0, message_separator => ' - ' },
    ];
    $self->{maps_counters}->{global} = [
        { label => 'sessions', set => {
                key_values => [ { name => 'sessions' } ],
                output_template => 'Current sessions : %s',
                perfdatas => [
                    { label => 'sessions', template => '%s', min => 0 },
                ],
            }
        },
        { label => 'sessions-ssl', set => {
                key_values => [ { name => 'sessions_ssl' } ],
                output_template => 'Current ssl sessions : %s',
                perfdatas => [
                    { label => 'sessions_ssl', template => '%s', min => 0 },
                ],
            }
        },
    ];
  }
  
  sub manage_selection {
    my ($self, %options) = @_;

    # OIDs are fake. Only for the example.
    my ($oid_sessions, $oid_sessions_ssl) = ('.1.2.3.4.0', '.1.2.3.5.0');
    
    my $result = $options{snmp}->get_leef(
      oids => [ $oid_sessions, $oid_sessions_ssl ],
      nothing_quit => 1
    );
    $self->{global} = {
      sessions => $result->{$oid_sessions},
      sessions_ssl => $result->{$oid_sessions_ssl}
    };
  }

Output may display:

  OK: Current sessions : 24 - Current ssl sessions : 150 | sessions=24;;;0; sessions_ssl=150;;;0;

As you can see, we create two arrays of hash tables in set_counters method. We use arrays to order the output.

  • maps_counters_type: global configuration. Attributes list:

    • name: the name is really important. It will be used in hash map_counters and also in manage_selection as you can see.
    • type: 0 or 1. With 0 value, the output will be written in the short output. With the value 1, it depends if we have one or multiple instances.
    • message_multiple: only useful with type 1 value. The message will be displayed in short ouput if we have multiple instances selected.
    • message_separator: the string displayed between counters (Default: ', ').
    • cb_prefix_output, cb_suffix_output: name of a method (in a string) to callback. Methods will return a string to be displayed before or after all counters.
    • cb_init: name of a method (in a string) to callback. Method will return 0 or 1. With 1 value, counters are not checked.
  • maps_counters: complex structure to configure counters. Attributes list:

    • label: name used for threshold options.

    • type: depend of data dimensions

      • 0 : global
      • 1 : instance
      • 2 : group
      • 3 : multiple
    • threshold: if we set the value to 0. There is no threshold check options (can be used if you want to set and check option yourself).

    • set: hash table:

      • keys_values: array of hashes. Set values used for the counter. Order is important (by default, the first value is used to check).

        • name: attribute name. Need to match with attributes in manage_selection method!
        • diff: if we set the value to 1, we'll have the difference between two checks (need a statefile!).
        • per_second: if we set the value to 1, the diff values will be calculated per seconds (need a statefile!). No need to add diff attribute.
      • output_template: string to display. '%s' will be replaced by the first value of keys_values.

      • output_use: which value to be used in output_template (If not set, we use the first value of keys_values).

      • output_change_bytes: if we set the value to 1 or 2, we can use a second '%s' in output_template to display the unit. 1 = divide by 1024 (Bytes), 2 = divide by 1000 (bits).

      • perfdata: array of hashes. To configure perfdatas

        • label: name displayed.
        • value: value to used. It's the name from keys_values.
        • template: value format (could be for example: '%.3f').
        • unit: unit displayed.
        • min, max: min and max displayed. You can use a value from keys_values.
        • label_extra_instance: if we set the value to 1, perhaps we'll have a suffix concat with label.
        • instance_use: which value from keys_values to be used. To be used if label_extra_instance is 1.

8.2. Example 2

We want to add the current number of sessions by virtual servers.

  package my::module::name;
  
  use base qw(centreon::plugins::templates::counter);
  
  use strict;
  use warnings;
  
  sub set_counters {
    my ($self, %options) = @_;
    
    $self->{maps_counters_type} = [
        { name => 'global', type => 0, cb_prefix_output => 'prefix_global_output' },
        { name => 'vs', type => 1, cb_prefix_output => 'prefix_vs_output', message_multiple => 'All Virtual servers are ok' }
    ];
    $self->{maps_counters}->{global} = [
        { label => 'total-sessions', set => {
                key_values => [ { name => 'sessions' } ],
                output_template => 'current sessions : %s',
                perfdatas => [
                    { label => 'total_sessions', template => '%s', min => 0 },
                ],
            }
        },
        { label => 'total-sessions-ssl', set => {
                key_values => [ { name => 'sessions_ssl' } ],
                output_template => 'current ssl sessions : %s',
                perfdatas => [
                    { label => 'total_sessions_ssl', template => '%s', min => 0 },
                ],
            }
        },
    ];
    
    $self->{maps_counters}->{vs} = [
        { label => 'sessions', set => {
                key_values => [ { name => 'sessions' }, { name => 'display' } ],
                output_template => 'current sessions : %s',
                perfdatas => [
                    { label => 'sessions', template => '%s', 
                      min => 0, label_extra_instance => 1, instance_use => 'display' },
                ],
            }
        },
        { label => 'sessions-ssl', set => {
                key_values => [ { name => 'sessions_ssl' }, { name => 'display' } ],
                output_template => 'current ssl sessions : %s',
                perfdatas => [
                    { label => 'sessions_ssl', template => '%s', 
                      min => 0, label_extra_instance => 1, instance_use => 'display' },
                ],
            }
        },
    ];
  }
  
  sub prefix_vs_output {
    my ($self, %options) = @_;
    
    return "Virtual server '" . $options{instance_value}->{display} . "' ";
  }
  
  sub prefix_global_output {
    my ($self, %options) = @_;
    
    return "Total ";
  }
  
  sub manage_selection {
    my ($self, %options) = @_;

    # OIDs are fake. Only for the example.
    my ($oid_sessions, $oid_sessions_ssl) = ('.1.2.3.4.0', '.1.2.3.5.0');
    
    my $result = $options{snmp}->get_leef(oids => [ $oid_sessions, $oid_sessions_ssl ],
                                          nothing_quit => 1);
    $self->{global} = { sessions => $result->{$oid_sessions},
                        sessions_ssl => $result->{$oid_sessions_ssl}
                      };
    my $oid_table_vs = '.1.2.3.10';
    my $mapping = {
        vsName        => { oid => '.1.2.3.10.1' },
        vsSessions    => { oid => '.1.2.3.10.2' },
        vsSessionsSsl => { oid => '.1.2.3.10.3' },
    };
    
    $self->{vs} = {};
    $result = $options{snmp}->get_table(oid => $oid_table_vs,
                                        nothing_quit => 1);
    foreach my $oid (keys %{$result->{ $oid_table_vs }}) {
        next if ($oid !~ /^$mapping->{vsName}->{oid}\.(.*)$/;
        my $instance = $1;
        my $data = $options{snmp}->map_instance(mapping => $mapping, results => $result->{$oid_table_vs}, instance => $instance);
        
        $self->{vs}->{$instance} = { display => $data->{vsName}, 
                                     sessions => $data->{vsSessions}, sessions_ssl => $data->{vsSessionsSsl}};
    }
  }

If we have at least 2 virtual servers:

  OK: Total current sessions : 24, current ssl sessions : 150 - All Virtual servers are ok | total_sessions=24;;;0; total_sessions_ssl=150;;;0; sessions_foo1=11;;;0; sessions_ssl_foo1=70;;;0; sessions_foo2=13;;;0; sessions_ssl_foo2=80;;;0;
  Virtual server 'foo1' current sessions : 11, current ssl sessions : 70
  Virtual server 'foo2' current sessions : 13, current ssl sessions : 80

8.3. Example 3

The model can also be used to check strings (not only counters). So we want to check the status of a virtualserver.

  package my::module::name;
  
  use base qw(centreon::plugins::templates::counter);
  
  use strict;
  use warnings;
  
  sub set_counters {
    my ($self, %options) = @_;
    
    $self->{maps_counters_type} = [
        { name => 'vs', type => 1, cb_prefix_output => 'prefix_vs_output', message_multiple => 'All Virtual server status are ok' }
    ];    
    $self->{maps_counters}->{vs} = [
        { label => 'status', threshold => 0, set => {
                key_values => [ { name => 'status' }, { name => 'display' } ],
                closure_custom_calc => $self->can('custom_status_calc'),
                closure_custom_output => $self->can('custom_status_output'),
                closure_custom_perfdata => sub { return 0; },
                closure_custom_threshold_check => $self->can('custom_threshold_output')
            }
        }
    ];
  }
  
  sub custom_threshold_output {
    my ($self, %options) = @_; 
    my $status = 'ok';
    
    if ($self->{result_values}->{status} =~ /problem/) {
        $status = 'critical';
    }
    return $status;
  }
  
  sub custom_status_output {
    my ($self, %options) = @_;
    
    my $msg = sprintf("status is '%s'", $self->{result_values}->{status});
    return $msg;
  }
  
  sub custom_status_calc {
    my ($self, %options) = @_;
    
    $self->{result_values}->{status} = $options{new_datas}->{$self->{instance} . '_status'};
    $self->{result_values}->{display} = $options{new_datas}->{$self->{instance} . '_display'};
    return 0;
  }
  
  sub prefix_vs_output {
    my ($self, %options) = @_;
    
    return "Virtual server '" . $options{instance_value}->{display} . "' ";
  }
  
  sub check_options {
    my ($self, %options) = @_;
    $self->SUPER::check_options(%options);

  }
  
  sub manage_selection {
    my ($self, %options) = @_;

    my $oid_table_vs = '.1.2.3.10';
    my $mapping = {
        vsName        => { oid => '.1.2.3.10.1' },
        vsStatus      => { oid => '.1.2.3.10.4' },
    };
    
    $self->{vs} = {};
    my $result = $options{snmp}->get_table(oid => $oid_table_vs,
                                        nothing_quit => 1);
    foreach my $oid (keys %{$result->{ $oid_table_vs }}) {
        next if ($oid !~ /^$mapping->{vsName}->{oid}\.(.*)$/;
        my $instance = $1;
        my $data = $options{snmp}->map_instance(mapping => $mapping, results => $result->{$oid_table_vs}, instance => $instance);
        
        $self->{vs}->{$instance} = { display => $data->{vsName}, 
                                     status => $data->{vsStatus} };
    }
  }

The following example show 4 new attributes:

  • closure_custom_calc: should be used to do more complex calculation.
  • closure_custom_output: should be used to have a more complex output (An example: want to display the total, free and used value at the same time).
  • closure_custom_perfdata: should be used to manage yourself the perfdata.
  • closure_custom_threshold_check: should be used to manage yourself the threshold check.

Table of content (1)