2015-05-07 13:24:58 +02:00
|
|
|
#
|
2017-01-09 17:12:12 +01:00
|
|
|
# Copyright 2017 Centreon (http://www.centreon.com/)
|
2015-07-21 11:51:02 +02:00
|
|
|
#
|
|
|
|
# Centreon is a full-fledged industry-strength solution that meets
|
|
|
|
# the needs in IT infrastructure and application monitoring for
|
|
|
|
# service performance.
|
|
|
|
#
|
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
# you may not use this file except in compliance with the License.
|
|
|
|
# You may obtain a copy of the License at
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
# See the License for the specific language governing permissions and
|
|
|
|
# limitations under the License.
|
|
|
|
#
|
2015-05-07 13:24:58 +02:00
|
|
|
|
|
|
|
package centreon::common::airespace::snmp::mode::apusers;
|
|
|
|
|
2016-01-06 16:14:44 +01:00
|
|
|
use base qw(centreon::plugins::templates::counter);
|
2015-05-07 13:24:58 +02:00
|
|
|
|
|
|
|
use strict;
|
|
|
|
use warnings;
|
|
|
|
|
2016-01-06 16:14:44 +01:00
|
|
|
sub set_counters {
|
|
|
|
my ($self, %options) = @_;
|
|
|
|
|
|
|
|
$self->{maps_counters_type} = [
|
|
|
|
{ name => 'global', type => 0 },
|
2016-05-24 14:41:09 +02:00
|
|
|
{ name => 'ssid', type => 1, cb_prefix_output => 'prefix_ssid_output', message_multiple => 'All users by SSID are ok' },
|
|
|
|
{ name => 'ap', type => 1, cb_prefix_output => 'prefix_ap_output', message_multiple => 'All users by AP are ok' },
|
2016-01-06 16:14:44 +01:00
|
|
|
];
|
|
|
|
$self->{maps_counters}->{global} = [
|
|
|
|
{ label => 'total', set => {
|
|
|
|
key_values => [ { name => 'total' } ],
|
|
|
|
output_template => 'Total Users : %s',
|
|
|
|
perfdatas => [
|
|
|
|
{ label => 'total', value => 'total_absolute', template => '%s',
|
|
|
|
unit => 'users', min => 0 },
|
|
|
|
],
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{ label => 'total-idle', set => {
|
|
|
|
key_values => [ { name => 'total_idle' } ],
|
|
|
|
output_template => 'Total Idle Users : %s',
|
|
|
|
perfdatas => [
|
|
|
|
{ label => 'total_idle', value => 'total_idle_absolute', template => '%s',
|
|
|
|
unit => 'users', min => 0 },
|
|
|
|
],
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{ label => 'total-aaapending', set => {
|
|
|
|
key_values => [ { name => 'total_aaapending' } ],
|
|
|
|
output_template => 'Total AaaPending Users : %s',
|
|
|
|
perfdatas => [
|
|
|
|
{ label => 'total_aaapending', value => 'total_aaapending_absolute', template => '%s',
|
|
|
|
unit => 'users', min => 0 },
|
|
|
|
],
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{ label => 'total-authenticated', set => {
|
|
|
|
key_values => [ { name => 'total_authenticated' } ],
|
|
|
|
output_template => 'Total Authenticated Users : %s',
|
|
|
|
perfdatas => [
|
|
|
|
{ label => 'total_authenticated', value => 'total_authenticated_absolute', template => '%s',
|
|
|
|
unit => 'users', min => 0 },
|
|
|
|
],
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{ label => 'total-associated', set => {
|
2016-12-01 17:32:33 +01:00
|
|
|
key_values => [ { name => 'total_associated' } ],
|
|
|
|
output_template => 'Total Associated Users : %s',
|
2016-01-06 16:14:44 +01:00
|
|
|
perfdatas => [
|
2016-12-01 17:32:33 +01:00
|
|
|
{ label => 'total_associated', value => 'total_associated_absolute', template => '%s',
|
2016-01-06 16:14:44 +01:00
|
|
|
unit => 'users', min => 0 },
|
|
|
|
],
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{ label => 'total-powersave', set => {
|
|
|
|
key_values => [ { name => 'total_powersave' } ],
|
|
|
|
output_template => 'Total Powersave Users : %s',
|
|
|
|
perfdatas => [
|
|
|
|
{ label => 'total_powersave', value => 'total_powersave_absolute', template => '%s',
|
|
|
|
unit => 'users', min => 0 },
|
|
|
|
],
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{ label => 'total-disassociated', set => {
|
|
|
|
key_values => [ { name => 'total_disassociated' } ],
|
|
|
|
output_template => 'Total Disassociated Users : %s',
|
|
|
|
perfdatas => [
|
|
|
|
{ label => 'total_disassociated', value => 'total_disassociated_absolute', template => '%s',
|
|
|
|
unit => 'users', min => 0 },
|
|
|
|
],
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{ label => 'total-tobedeleted', set => {
|
|
|
|
key_values => [ { name => 'total_tobedeleted' } ],
|
|
|
|
output_template => 'Total ToBeDeleted Users : %s',
|
|
|
|
perfdatas => [
|
|
|
|
{ label => 'total_tobedeleted', value => 'total_tobedeleted_absolute', template => '%s',
|
|
|
|
unit => 'users', min => 0 },
|
|
|
|
],
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{ label => 'total-probing', set => {
|
|
|
|
key_values => [ { name => 'total_probing' } ],
|
|
|
|
output_template => 'Total Probing Users : %s',
|
|
|
|
perfdatas => [
|
|
|
|
{ label => 'total_probing', value => 'total_probing_absolute', template => '%s',
|
|
|
|
unit => 'users', min => 0 },
|
|
|
|
],
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{ label => 'total-blacklisted', set => {
|
|
|
|
key_values => [ { name => 'total_blacklisted' } ],
|
|
|
|
output_template => 'Total Blacklisted Users : %s',
|
|
|
|
perfdatas => [
|
|
|
|
{ label => 'total_blacklisted', value => 'total_blacklisted_absolute', template => '%s',
|
|
|
|
unit => 'users', min => 0 },
|
|
|
|
],
|
|
|
|
}
|
|
|
|
},
|
|
|
|
];
|
2016-01-12 15:10:39 +01:00
|
|
|
|
|
|
|
$self->{maps_counters}->{ssid} = [
|
|
|
|
{ label => 'ssid', set => {
|
|
|
|
key_values => [ { name => 'total' }, { name => 'display' } ],
|
|
|
|
output_template => 'users : %s',
|
|
|
|
perfdatas => [
|
|
|
|
{ label => 'ssid', value => 'total_absolute', template => '%s',
|
|
|
|
unit => 'users', min => 0, label_extra_instance => 1, instance_use => 'display_absolute' },
|
|
|
|
],
|
|
|
|
}
|
|
|
|
},
|
|
|
|
];
|
2016-05-24 14:41:09 +02:00
|
|
|
|
|
|
|
$self->{maps_counters}->{ap} = [
|
|
|
|
{ label => 'ap', set => {
|
|
|
|
key_values => [ { name => 'total' }, { name => 'display' } ],
|
|
|
|
output_template => 'users : %s',
|
|
|
|
perfdatas => [
|
|
|
|
{ label => 'ap', value => 'total_absolute', template => '%s',
|
|
|
|
unit => 'users', min => 0, label_extra_instance => 1, instance_use => 'display_absolute' },
|
|
|
|
],
|
|
|
|
}
|
|
|
|
},
|
|
|
|
];
|
2016-01-12 15:10:39 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
sub prefix_ssid_output {
|
|
|
|
my ($self, %options) = @_;
|
|
|
|
|
|
|
|
return "SSID '" . $options{instance_value}->{display} . "' ";
|
2016-01-06 16:14:44 +01:00
|
|
|
}
|
2015-05-07 13:24:58 +02:00
|
|
|
|
2016-05-24 14:41:09 +02:00
|
|
|
sub prefix_ap_output {
|
|
|
|
my ($self, %options) = @_;
|
|
|
|
|
|
|
|
return "AP '" . $options{instance_value}->{display} . "' ";
|
|
|
|
}
|
|
|
|
|
2015-05-07 13:24:58 +02:00
|
|
|
sub new {
|
|
|
|
my ($class, %options) = @_;
|
|
|
|
my $self = $class->SUPER::new(package => __PACKAGE__, %options);
|
|
|
|
bless $self, $class;
|
|
|
|
|
|
|
|
$self->{version} = '1.0';
|
|
|
|
$options{options}->add_options(arguments =>
|
|
|
|
{
|
2016-05-24 14:41:09 +02:00
|
|
|
"filter-ssid:s" => { name => 'filter_ssid' },
|
|
|
|
"filter-ap:s" => { name => 'filter_ap' },
|
2015-05-07 13:24:58 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
return $self;
|
|
|
|
}
|
|
|
|
|
|
|
|
my %map_station_status = (
|
|
|
|
0 => 'idle',
|
|
|
|
1 => 'aaapending',
|
|
|
|
2 => 'authenticated',
|
|
|
|
3 => 'associated',
|
|
|
|
4 => 'powersave',
|
|
|
|
5 => 'disassociated',
|
|
|
|
6 => 'tobedeleted',
|
|
|
|
7 => 'probing',
|
|
|
|
8 => 'blacklisted',
|
|
|
|
);
|
|
|
|
my $mapping = {
|
|
|
|
bsnMobileStationStatus => { oid => '.1.3.6.1.4.1.14179.2.1.4.1.9', map => \%map_station_status },
|
|
|
|
};
|
|
|
|
my $mapping2 = {
|
|
|
|
bsnMobileStationSsid => { oid => '.1.3.6.1.4.1.14179.2.1.4.1.7' },
|
|
|
|
};
|
2016-01-12 15:10:39 +01:00
|
|
|
my $mapping3 = {
|
|
|
|
bsnDot11EssNumberOfMobileStations => { oid => '.1.3.6.1.4.1.14179.2.1.1.1.38' },
|
|
|
|
};
|
2015-05-07 13:24:58 +02:00
|
|
|
|
2015-11-04 11:12:52 +01:00
|
|
|
my $oid_agentInventoryMachineModel = '.1.3.6.1.4.1.14179.1.1.1.3';
|
2016-01-12 15:10:39 +01:00
|
|
|
my $oid_bsnDot11EssSsid = '.1.3.6.1.4.1.14179.2.1.1.1.2';
|
2016-06-01 16:15:53 +02:00
|
|
|
my $oid_bsnAPName = '.1.3.6.1.4.1.14179.2.2.1.1.3';
|
2016-05-24 14:41:09 +02:00
|
|
|
my $oid_bsnAPIfLoadNumOfClients = '.1.3.6.1.4.1.14179.2.2.13.1.4';
|
2015-11-04 11:12:52 +01:00
|
|
|
|
2015-05-07 13:24:58 +02:00
|
|
|
sub manage_selection {
|
|
|
|
my ($self, %options) = @_;
|
|
|
|
|
2015-05-07 14:43:45 +02:00
|
|
|
$self->{global} = { total => 0, total_idle => 0, total_aaapending => 0, total_authenticated => 0,
|
|
|
|
total_associated => 0, total_powersave => 0, total_disassociated => 0,
|
|
|
|
total_tobedeleted => 0, total_probing => 0, total_blacklisted => 0};
|
2016-01-06 16:14:44 +01:00
|
|
|
$self->{results} = $options{snmp}->get_multiple_table(oids => [ { oid => $oid_agentInventoryMachineModel },
|
2015-11-04 11:12:52 +01:00
|
|
|
{ oid => $mapping->{bsnMobileStationStatus}->{oid} },
|
2015-05-07 13:24:58 +02:00
|
|
|
{ oid => $mapping2->{bsnMobileStationSsid}->{oid} },
|
2016-01-12 15:10:39 +01:00
|
|
|
{ oid => $oid_bsnDot11EssSsid },
|
|
|
|
{ oid => $mapping3->{bsnDot11EssNumberOfMobileStations}->{oid} },
|
2016-05-24 14:41:09 +02:00
|
|
|
{ oid => $oid_bsnAPName },
|
|
|
|
{ oid => $oid_bsnAPIfLoadNumOfClients },
|
2015-05-07 13:24:58 +02:00
|
|
|
],
|
|
|
|
nothing_quit => 1);
|
2015-11-04 11:12:52 +01:00
|
|
|
$self->{output}->output_add(long_msg => "Model: " . $self->{results}->{$oid_agentInventoryMachineModel}->{$oid_agentInventoryMachineModel . '.0'});
|
2015-05-07 13:24:58 +02:00
|
|
|
foreach my $oid (keys %{$self->{results}->{ $mapping->{bsnMobileStationStatus}->{oid} }}) {
|
|
|
|
$oid =~ /^$mapping->{bsnMobileStationStatus}->{oid}\.(.*)$/;
|
|
|
|
my $instance = $1;
|
2016-01-06 16:14:44 +01:00
|
|
|
my $result = $options{snmp}->map_instance(mapping => $mapping, results => $self->{results}->{ $mapping->{bsnMobileStationStatus}->{oid} }, instance => $instance);
|
|
|
|
my $result2 = $options{snmp}->map_instance(mapping => $mapping2, results => $self->{results}->{ $mapping2->{bsnMobileStationSsid}->{oid} }, instance => $instance);
|
2015-05-07 13:24:58 +02:00
|
|
|
if (defined($self->{option_results}->{filter_ssid}) && $self->{option_results}->{filter_ssid} ne '' &&
|
|
|
|
$result2->{bsnMobileStationSsid} !~ /$self->{option_results}->{filter_ssid}/) {
|
2016-01-12 15:10:39 +01:00
|
|
|
$self->{output}->output_add(long_msg => "Skipping '" . $result2->{bsnMobileStationSsid} . "': no matching filter.", debug => 1);
|
2015-05-07 13:24:58 +02:00
|
|
|
next;
|
|
|
|
}
|
|
|
|
$self->{global}->{total}++;
|
2015-05-07 14:43:45 +02:00
|
|
|
$self->{global}->{'total_' . $result->{bsnMobileStationStatus}}++;
|
2015-05-07 13:24:58 +02:00
|
|
|
}
|
2016-01-12 15:10:39 +01:00
|
|
|
|
|
|
|
# check by ssid
|
|
|
|
$self->{ssid} = {};
|
|
|
|
foreach my $oid (keys %{$self->{results}->{ $oid_bsnDot11EssSsid }}) {
|
|
|
|
$oid =~ /^$oid_bsnDot11EssSsid\.(.*)$/;
|
|
|
|
my $instance = $1;
|
|
|
|
my $ssid_name = $self->{results}->{ $oid_bsnDot11EssSsid }->{$oid};
|
|
|
|
my $result = $options{snmp}->map_instance(mapping => $mapping3, results => $self->{results}->{ $mapping3->{bsnDot11EssNumberOfMobileStations}->{oid} }, instance => $instance);
|
|
|
|
if (defined($self->{option_results}->{filter_ssid}) && $self->{option_results}->{filter_ssid} ne '' &&
|
|
|
|
$ssid_name !~ /$self->{option_results}->{filter_ssid}/) {
|
2016-05-24 14:41:09 +02:00
|
|
|
$self->{output}->output_add(long_msg => "skipping ssid '" . $ssid_name . "': no matching filter.", debug => 1);
|
2016-01-12 15:10:39 +01:00
|
|
|
next;
|
|
|
|
}
|
|
|
|
|
|
|
|
$self->{ssid}->{$ssid_name} = { display => $ssid_name, total => 0 } if (!defined($self->{ssid}->{$ssid_name}));
|
|
|
|
$self->{ssid}->{$ssid_name}->{total} += $result->{bsnDot11EssNumberOfMobileStations};
|
|
|
|
}
|
2016-05-24 14:41:09 +02:00
|
|
|
|
|
|
|
# check by ap
|
|
|
|
$self->{ap} = {};
|
|
|
|
foreach my $oid (keys %{$self->{results}->{ $oid_bsnAPName }}) {
|
|
|
|
$oid =~ /^$oid_bsnAPName\.(.*)/;
|
|
|
|
my $instance = $1;
|
|
|
|
my $ap_name = $self->{results}->{$oid_bsnAPName}->{$oid};
|
|
|
|
if (defined($self->{option_results}->{filter_ap}) && $self->{option_results}->{filter_ap} ne '' &&
|
|
|
|
$ap_name !~ /$self->{option_results}->{filter_ap}/) {
|
|
|
|
$self->{output}->output_add(long_msg => "skipping ap '" . $ap_name . "': no matching filter.", debug => 1);
|
|
|
|
next;
|
|
|
|
}
|
|
|
|
|
|
|
|
foreach my $oid2 (keys %{$self->{results}->{ $oid_bsnAPIfLoadNumOfClients }}) {
|
|
|
|
next if ($oid2 !~ /^$oid_bsnAPIfLoadNumOfClients\.$instance\./);
|
|
|
|
$self->{ap}->{$instance} = { display => $ap_name, total => 0 } if (!defined($self->{ap}->{$instance}));
|
2016-06-01 16:15:53 +02:00
|
|
|
$self->{ap}->{$instance}->{total} += $self->{results}->{$oid_bsnAPIfLoadNumOfClients}->{$oid2};
|
2016-05-24 14:41:09 +02:00
|
|
|
}
|
|
|
|
}
|
2015-05-07 13:24:58 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
1;
|
|
|
|
|
|
|
|
__END__
|
|
|
|
|
|
|
|
=head1 MODE
|
|
|
|
|
2016-05-24 14:41:09 +02:00
|
|
|
Check users connected (total, by SSID, by AP).
|
2015-05-07 13:24:58 +02:00
|
|
|
|
|
|
|
=over 8
|
|
|
|
|
2016-01-06 16:14:44 +01:00
|
|
|
=item B<--filter-counters>
|
|
|
|
|
|
|
|
Only display some counters (regexp can be used).
|
2016-01-07 14:00:10 +01:00
|
|
|
Example: --filter-counters='^total|total-idle$'
|
2016-01-06 16:14:44 +01:00
|
|
|
|
2015-05-07 13:24:58 +02:00
|
|
|
=item B<--warning-*>
|
|
|
|
|
|
|
|
Threshold warning.
|
|
|
|
Can be: 'total', 'total-idle', 'total-aaapending', 'total-authenticated',
|
|
|
|
'total-associated', 'total-powersave', 'total-disassociated', 'total-tobedeleted',
|
2016-05-24 14:41:09 +02:00
|
|
|
'total-probing', 'total-blacklisted', 'ssid', 'ap'.
|
2015-05-07 13:24:58 +02:00
|
|
|
|
|
|
|
=item B<--critical-*>
|
|
|
|
|
|
|
|
Threshold critical.
|
|
|
|
Can be: 'total', 'total-idle', 'total-aaapending', 'total-authenticated',
|
|
|
|
'total-associated', 'total-powersave', 'total-disassociated', 'total-tobedeleted',
|
2016-05-24 14:41:09 +02:00
|
|
|
'total-probing', 'total-blacklisted', 'ssid', 'ap'.
|
2015-05-07 13:24:58 +02:00
|
|
|
|
|
|
|
=item B<--filter-ssid>
|
|
|
|
|
|
|
|
Filter by SSID (can be a regexp).
|
|
|
|
|
2016-05-24 14:41:09 +02:00
|
|
|
=item B<--filter-ap>
|
|
|
|
|
|
|
|
Filter by AP (can be a regexp).
|
|
|
|
|
2015-05-07 13:24:58 +02:00
|
|
|
=back
|
|
|
|
|
|
|
|
=cut
|