2014-05-13 17:07:28 +02:00
|
|
|
#
|
2015-07-21 11:51:02 +02:00
|
|
|
# Copyright 2015 Centreon (http://www.centreon.com/)
|
|
|
|
#
|
|
|
|
# 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.
|
|
|
|
#
|
2014-05-13 17:07:28 +02:00
|
|
|
|
|
|
|
package centreon::common::powershell::exchange::2010::databases;
|
|
|
|
|
|
|
|
use strict;
|
|
|
|
use warnings;
|
|
|
|
use centreon::plugins::misc;
|
2014-08-28 16:55:00 +02:00
|
|
|
use centreon::common::powershell::exchange::2010::powershell;
|
2014-05-13 17:07:28 +02:00
|
|
|
|
|
|
|
sub get_powershell {
|
2014-05-15 14:41:49 +02:00
|
|
|
my (%options) = @_;
|
|
|
|
# options: no_ps, no_mailflow, no_mapi
|
|
|
|
my $no_mailflow = (defined($options{no_mailflow})) ? 1 : 0;
|
|
|
|
my $no_ps = (defined($options{no_ps})) ? 1 : 0;
|
|
|
|
my $no_mapi = (defined($options{no_mapi})) ? 1 : 0;
|
|
|
|
|
|
|
|
return '' if ($no_ps == 1);
|
|
|
|
|
2014-08-28 16:55:00 +02:00
|
|
|
my $ps = centreon::common::powershell::exchange::2010::powershell::powershell_init(%options);
|
|
|
|
|
|
|
|
$ps .= '
|
2014-05-13 17:07:28 +02:00
|
|
|
# Check to make sure all databases are mounted
|
2014-05-15 14:41:49 +02:00
|
|
|
try {
|
|
|
|
$ErrorActionPreference = "Stop"
|
|
|
|
';
|
|
|
|
|
|
|
|
if (defined($options{filter_database})) {
|
|
|
|
$ps .= '
|
|
|
|
$MountedDB = Get-MailboxDatabase -Identity "' . $options{filter_database} . '" -Status
|
|
|
|
';
|
|
|
|
} else {
|
|
|
|
$ps .= '
|
|
|
|
$MountedDB = Get-MailboxDatabase -Status
|
|
|
|
';
|
|
|
|
}
|
2014-05-13 17:07:28 +02:00
|
|
|
|
2014-05-15 14:41:49 +02:00
|
|
|
$ps .= '
|
|
|
|
} catch {
|
|
|
|
Write-Host $Error[0].Exception
|
|
|
|
exit 1
|
|
|
|
}
|
2014-05-13 17:07:28 +02:00
|
|
|
Foreach ($DB in $MountedDB) {
|
2014-05-16 10:15:49 +02:00
|
|
|
Write-Host "[name=" $DB.Name "][server=" $DB.Server "][mounted=" $DB.Mounted "][size=" $DB.DatabaseSize "][asize=" $DB.AvailableNewMailboxSpace "]" -NoNewline
|
2014-05-15 14:41:49 +02:00
|
|
|
|
|
|
|
';
|
|
|
|
|
|
|
|
if (defined($options{filter_database_test}) && $options{filter_database_test} ne '') {
|
|
|
|
$ps .= '
|
|
|
|
if (!($DB.Name -match "' . $options{filter_database_test} . '")) {
|
|
|
|
Write-Host "[Skip extra test]"
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
';
|
|
|
|
}
|
|
|
|
|
|
|
|
$ps .= '
|
|
|
|
If ($DB.Mounted -eq $true) {
|
2014-05-13 17:07:28 +02:00
|
|
|
';
|
|
|
|
|
2014-05-15 14:41:49 +02:00
|
|
|
if ($no_mapi == 0) {
|
|
|
|
$ps .= '
|
|
|
|
# Test Mapi Connectivity
|
|
|
|
$MapiResult = test-mapiconnectivity -Database $DB.Name
|
|
|
|
Write-Host "[mapi=" $MapiResult.Result "]" -NoNewline
|
2014-05-13 17:07:28 +02:00
|
|
|
';
|
2014-05-15 14:41:49 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($no_mailflow == 0) {
|
|
|
|
$ps .= '
|
|
|
|
# Test Mailflow
|
|
|
|
$MailflowResult = Test-mailflow -Targetdatabase $DB.Name
|
2014-05-15 16:40:41 +02:00
|
|
|
Write-Host "[mailflow=" $MailflowResult.testmailflowresult "][latency=" $MailflowResult.MessageLatencyTime.TotalMilliseconds "]" -NoNewline
|
2014-05-13 17:07:28 +02:00
|
|
|
';
|
2014-05-15 14:41:49 +02:00
|
|
|
}
|
2014-05-13 17:07:28 +02:00
|
|
|
|
2014-05-15 14:41:49 +02:00
|
|
|
$ps .= '
|
|
|
|
}
|
|
|
|
Write-Host ""
|
2014-05-13 17:07:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
exit 0
|
|
|
|
';
|
|
|
|
|
2014-05-15 14:41:49 +02:00
|
|
|
return centreon::plugins::misc::powershell_encoded($ps);
|
|
|
|
}
|
|
|
|
|
|
|
|
sub check_mapi {
|
|
|
|
my ($self, %options) = @_;
|
|
|
|
|
|
|
|
if (defined($self->{option_results}->{no_mapi})) {
|
|
|
|
$self->{output}->output_add(long_msg => ' Skip MAPI test connectivity');
|
|
|
|
return ;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($options{line} !~ /\[mapi=(.*?)\]/) {
|
|
|
|
$self->{output}->output_add(long_msg => ' Skip MAPI test connectivity (information not found)');
|
|
|
|
return ;
|
|
|
|
}
|
|
|
|
|
|
|
|
my $mapi_result = centreon::plugins::misc::trim($1);
|
|
|
|
|
|
|
|
$self->{output}->output_add(long_msg => " MAPI Test connectivity: " . $mapi_result);
|
|
|
|
foreach my $th (('critical_mapi', 'warning_mapi')) {
|
|
|
|
next if (!defined($self->{thresholds}->{$th}));
|
|
|
|
|
|
|
|
if ($self->{thresholds}->{$th}->{operator} eq '=' &&
|
|
|
|
$mapi_result =~ /$self->{thresholds}->{$th}->{state}/) {
|
|
|
|
$self->{output}->output_add(severity => $self->{thresholds}->{$th}->{out},
|
|
|
|
short_msg => sprintf("Server '%s' Database '%s' MAPI connectivity is %s",
|
|
|
|
$options{server}, $options{database}, $mapi_result));
|
|
|
|
} elsif ($self->{thresholds}->{$th}->{operator} eq '!=' &&
|
|
|
|
$mapi_result !~ /$self->{thresholds}->{$th}->{state}/) {
|
|
|
|
$self->{output}->output_add(severity => $self->{thresholds}->{$th}->{out},
|
|
|
|
short_msg => sprintf("Server '%s' Database '%s' MAPI connectivity is %s",
|
|
|
|
$options{server}, $options{database}, $mapi_result));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
sub check_mailflow {
|
|
|
|
my ($self, %options) = @_;
|
|
|
|
|
|
|
|
if (defined($self->{option_results}->{no_mailflow})) {
|
|
|
|
$self->{output}->output_add(long_msg => ' Skip Mailflow test');
|
|
|
|
return ;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($options{line} !~ /\[mailflow=(.*?)\]\[latency=(.*?)\]/) {
|
|
|
|
$self->{output}->output_add(long_msg => ' Skip Mailflow test (information not found)');
|
|
|
|
return ;
|
|
|
|
}
|
|
|
|
|
|
|
|
my ($mailflow_result, $latency) = (centreon::plugins::misc::trim($1), centreon::plugins::misc::trim($2));
|
|
|
|
|
|
|
|
$self->{output}->output_add(long_msg => " Mailflow Test: " . $mailflow_result);
|
|
|
|
foreach my $th (('critical_mailflow', 'warning_mailflow')) {
|
|
|
|
next if (!defined($self->{thresholds}->{$th}));
|
|
|
|
|
|
|
|
if ($self->{thresholds}->{$th}->{operator} eq '=' &&
|
|
|
|
$mailflow_result =~ /$self->{thresholds}->{$th}->{state}/) {
|
|
|
|
$self->{output}->output_add(severity => $self->{thresholds}->{$th}->{out},
|
|
|
|
short_msg => sprintf("Server '%s' Database '%s' Mailflow test is %s",
|
|
|
|
$options{server}, $options{database}, $mailflow_result));
|
|
|
|
} elsif ($self->{thresholds}->{$th}->{operator} eq '!=' &&
|
|
|
|
$mailflow_result !~ /$self->{thresholds}->{$th}->{state}/) {
|
|
|
|
$self->{output}->output_add(severity => $self->{thresholds}->{$th}->{out},
|
|
|
|
short_msg => sprintf("Server '%s' Database '%s' Mailflow test is %s",
|
|
|
|
$options{server}, $options{database}, $mailflow_result));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-05-15 16:40:41 +02:00
|
|
|
if ($latency =~ /^(\d+)/) {
|
2014-05-15 14:41:49 +02:00
|
|
|
$self->{output}->perfdata_add(label => 'latency_' . $options{database}, unit => 's',
|
2014-05-15 16:40:41 +02:00
|
|
|
value => sprintf("%.3f", $1 / 1000),
|
2014-05-15 14:41:49 +02:00
|
|
|
min => 0);
|
|
|
|
}
|
2014-05-13 17:07:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
sub check {
|
2014-05-15 14:41:49 +02:00
|
|
|
my ($self, %options) = @_;
|
|
|
|
# options: stdout
|
|
|
|
|
|
|
|
# Following output:
|
2014-05-16 10:15:49 +02:00
|
|
|
#[name= Mailbox Database 0975194476 ][server= SRVI-WIN-TEST ][mounted= True ][size= 136.1 MB (142,671,872 bytes) ][asize= 124.4 MB (130,482,176 bytes) ][mapi= Success ][mailflow= Success ][latency= 50,00 ]
|
2014-05-15 14:41:49 +02:00
|
|
|
#...
|
|
|
|
|
|
|
|
$self->{output}->output_add(severity => 'OK',
|
|
|
|
short_msg => 'Databases are mounted');
|
|
|
|
if (!defined($self->{option_results}->{no_mapi})) {
|
|
|
|
$self->{output}->output_add(severity => 'OK',
|
|
|
|
short_msg => 'MAPI Connectivities are ok');
|
|
|
|
}
|
|
|
|
if (!defined($self->{option_results}->{no_mailflow})) {
|
|
|
|
$self->{output}->output_add(severity => 'OK',
|
|
|
|
short_msg => 'Mailflow test are ok');
|
|
|
|
}
|
|
|
|
|
|
|
|
my $checked = 0;
|
|
|
|
foreach my $line (split /\n/, $options{stdout}) {
|
2014-05-16 10:15:49 +02:00
|
|
|
next if ($line !~ /^\[name=(.*?)\]\[server=(.*?)\]\[mounted=(.*?)\]\[size=(.*?)\]\[asize=(.*?)\]/);
|
2014-05-15 14:41:49 +02:00
|
|
|
$checked++;
|
2014-05-16 10:15:49 +02:00
|
|
|
my ($database, $server, $mounted, $size, $asize) = (centreon::plugins::misc::trim($1), centreon::plugins::misc::trim($2),
|
|
|
|
centreon::plugins::misc::trim($3), centreon::plugins::misc::trim($4), centreon::plugins::misc::trim($5));
|
2014-05-15 14:41:49 +02:00
|
|
|
|
|
|
|
$self->{output}->output_add(long_msg => sprintf("Test database '%s' server '%s':", $database, $server));
|
2014-05-16 10:15:49 +02:00
|
|
|
if ($size =~ /\((.*?)\s*bytes/) {
|
|
|
|
my $total_bytes = $1;
|
|
|
|
$total_bytes =~ s/[.,]//g;
|
|
|
|
$self->{output}->perfdata_add(label => 'size_' . $database, unit => 'B',
|
|
|
|
value => $total_bytes,
|
|
|
|
min => 0);
|
|
|
|
my ($total_value, $total_unit) = $self->{perfdata}->change_bytes(value => $total_bytes);
|
|
|
|
$self->{output}->output_add(long_msg => sprintf(" Size %s", $total_value . ' ' . $total_unit));
|
|
|
|
}
|
|
|
|
if ($asize =~ /\((.*?)\s*bytes/) {
|
|
|
|
my $total_bytes = $1;
|
|
|
|
$total_bytes =~ s/[.,]//g;
|
|
|
|
$self->{output}->perfdata_add(label => 'asize_' . $database, unit => 'B',
|
|
|
|
value => $total_bytes,
|
|
|
|
min => 0);
|
|
|
|
my ($total_value, $total_unit) = $self->{perfdata}->change_bytes(value => $total_bytes);
|
|
|
|
$self->{output}->output_add(long_msg => sprintf(" Available Size %s", $total_value . ' ' . $total_unit));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
# Check mounted
|
2014-05-15 14:41:49 +02:00
|
|
|
if ($mounted =~ /False/i) {
|
|
|
|
$self->{output}->output_add(long_msg => sprintf(" not mounted\n Skip mapi/mailflow test"));
|
|
|
|
$self->{output}->output_add(short_msg => 'CRITICAL',
|
|
|
|
long_msg => sprintf("Database '%s' server '%s' is not mounted", $database, $server));
|
|
|
|
next;
|
|
|
|
}
|
|
|
|
$self->{output}->output_add(long_msg => sprintf(" mounted"));
|
|
|
|
|
|
|
|
check_mapi($self, database => $database, server => $server, line => $line);
|
|
|
|
check_mailflow($self, database => $database, server => $server, line => $line);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($checked == 0) {
|
|
|
|
$self->{output}->output_add(severity => 'UNKNOWN',
|
|
|
|
short_msg => 'Cannot find informations');
|
|
|
|
}
|
2014-05-13 17:07:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
1;
|
|
|
|
|
|
|
|
__END__
|
|
|
|
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
|
|
|
|
Method to check Exchange 2010 databases.
|
|
|
|
|
|
|
|
=cut
|