From 1fd95956c702ea6e9373da70200a89c7943e8d1b Mon Sep 17 00:00:00 2001 From: Quentin Garnier Date: Fri, 16 May 2014 10:15:49 +0200 Subject: [PATCH] Refs #5542 --- .../powershell/exchange/2010/databases.pm | 31 ++++++++++++++++--- 1 file changed, 26 insertions(+), 5 deletions(-) diff --git a/centreon/common/powershell/exchange/2010/databases.pm b/centreon/common/powershell/exchange/2010/databases.pm index b89970ec0..c6624d4bf 100644 --- a/centreon/common/powershell/exchange/2010/databases.pm +++ b/centreon/common/powershell/exchange/2010/databases.pm @@ -91,7 +91,7 @@ try { exit 1 } Foreach ($DB in $MountedDB) { - Write-Host "[name=" $DB.Name "][server=" $DB.Server "][mounted=" $DB.Mounted "]" -NoNewline + Write-Host "[name=" $DB.Name "][server=" $DB.Server "][mounted=" $DB.Mounted "][size=" $DB.DatabaseSize "][asize=" $DB.AvailableNewMailboxSpace "]" -NoNewline '; @@ -212,7 +212,7 @@ sub check { # options: stdout # Following output: - #[name= Mailbox Database 0975194476 ][server= SRVI-WIN-TEST ][mounted= True ][mapi= Success ][mailflow= Success ][latency= 50,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 ] #... $self->{output}->output_add(severity => 'OK', @@ -228,12 +228,33 @@ sub check { my $checked = 0; foreach my $line (split /\n/, $options{stdout}) { - next if ($line !~ /^\[name=(.*?)\]\[server=(.*?)\]\[mounted=(.*?)\]/); + next if ($line !~ /^\[name=(.*?)\]\[server=(.*?)\]\[mounted=(.*?)\]\[size=(.*?)\]\[asize=(.*?)\]/); $checked++; - my ($database, $server, $mounted) = (centreon::plugins::misc::trim($1), centreon::plugins::misc::trim($2), centreon::plugins::misc::trim($3)); + 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)); - # Check mounted $self->{output}->output_add(long_msg => sprintf("Test database '%s' server '%s':", $database, $server)); + 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 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',