2014-02-17 14:37:45 +01:00
|
|
|
#
|
2020-01-06 15:19:23 +01:00
|
|
|
# Copyright 2020 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.
|
|
|
|
#
|
2014-02-17 14:37:45 +01:00
|
|
|
|
|
|
|
package apps::activedirectory::local::mode::dcdiag;
|
|
|
|
|
|
|
|
use base qw(centreon::plugins::mode);
|
|
|
|
|
|
|
|
use strict;
|
|
|
|
use warnings;
|
2014-09-05 11:57:45 +02:00
|
|
|
use centreon::plugins::misc;
|
2014-02-17 14:37:45 +01:00
|
|
|
use File::Basename;
|
2020-09-22 10:28:34 +02:00
|
|
|
use XML::Simple;
|
2014-02-17 14:37:45 +01:00
|
|
|
use Win32;
|
|
|
|
|
|
|
|
sub new {
|
|
|
|
my ($class, %options) = @_;
|
|
|
|
my $self = $class->SUPER::new(package => __PACKAGE__, %options);
|
|
|
|
bless $self, $class;
|
|
|
|
|
2019-08-01 15:48:47 +02:00
|
|
|
$options{options}->add_options(arguments => {
|
2020-09-22 10:28:34 +02:00
|
|
|
'config:s' => { name => 'config' },
|
|
|
|
'language:s' => { name => 'language', default => 'en' },
|
|
|
|
'dfsr' => { name => 'dfsr' },
|
|
|
|
'noeventlog' => { name => 'noeventlog' },
|
|
|
|
'nomachineaccount' => { name => 'nomachineaccount' },
|
|
|
|
'timeout:s' => { name => 'timeout', default => 30 }
|
2019-08-01 15:48:47 +02:00
|
|
|
});
|
|
|
|
|
2014-02-17 14:37:45 +01:00
|
|
|
$self->{os_is2003} = 0;
|
|
|
|
$self->{os_is2008} = 0;
|
|
|
|
$self->{os_is2012} = 0;
|
2019-08-01 15:48:47 +02:00
|
|
|
$self->{os_is2016} = 0;
|
2020-09-22 10:28:34 +02:00
|
|
|
|
2014-02-17 14:37:45 +01:00
|
|
|
return $self;
|
|
|
|
}
|
|
|
|
|
|
|
|
sub check_options {
|
|
|
|
my ($self, %options) = @_;
|
|
|
|
$self->SUPER::init(%options);
|
|
|
|
}
|
|
|
|
|
|
|
|
sub check_version {
|
|
|
|
my ($self, %options) = @_;
|
|
|
|
|
|
|
|
our ($ver_string, $ver_major, $ver_minor, $ver_build, $ver_id) = Win32::GetOSVersion();
|
|
|
|
#"Operating system is " . "$ver_string - ($ver_id.$ver_major.$ver_minor.$ver_build)\n";
|
|
|
|
|
|
|
|
# 5.1, 5.2 => XP/2003
|
|
|
|
# 6.0, 6.1 => Vista/7/2008
|
|
|
|
# 6.2, 6.3 => 2012
|
2019-08-01 15:48:47 +02:00
|
|
|
# 10.0 => 2016, 2019
|
2014-02-17 14:37:45 +01:00
|
|
|
if ($ver_major == 5 && ($ver_minor == 1 || $ver_minor == 2)) {
|
|
|
|
$self->{os_is2003} = 1;
|
|
|
|
} elsif ($ver_major == 6 && ($ver_minor == 0 || $ver_minor == 1)) {
|
|
|
|
$self->{os_is2008} = 1;
|
|
|
|
} elsif ($ver_major == 6 && ($ver_minor == 2 || $ver_minor == 3)) {
|
|
|
|
$self->{os_is2012} = 1;
|
2019-08-01 15:48:47 +02:00
|
|
|
} elsif ($ver_major == 10 && $ver_minor == 0) {
|
|
|
|
$self->{os_is2016} = 1;
|
2014-02-17 14:37:45 +01:00
|
|
|
} else {
|
2020-09-22 10:28:34 +02:00
|
|
|
$self->{output}->output_add(
|
|
|
|
severity => 'UNKNOWN',
|
|
|
|
short_msg => 'OS version ' . $ver_major . '.' . $ver_minor . ' not managed.'
|
|
|
|
);
|
2014-02-17 14:37:45 +01:00
|
|
|
return 1;
|
|
|
|
}
|
2020-09-22 10:28:34 +02:00
|
|
|
|
2014-02-17 14:37:45 +01:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2020-09-22 10:28:34 +02:00
|
|
|
sub read_config {
|
2014-02-17 14:37:45 +01:00
|
|
|
my ($self, %options) = @_;
|
|
|
|
|
2020-09-22 12:52:41 +02:00
|
|
|
my $content_file = <<'END_FILE';
|
2020-09-22 10:28:34 +02:00
|
|
|
<?xml version="1.0" encoding="UTF-8"?>
|
|
|
|
<root>
|
|
|
|
<dcdiag language="en">
|
|
|
|
<messages>
|
|
|
|
<global>Starting test.*?:\s+(.*?)\n.*?(passed|warning|failed)</global>
|
|
|
|
<ok>passed</ok>
|
|
|
|
<warning>warning</warning>
|
|
|
|
<critical>failed</critical>
|
|
|
|
</messages>
|
|
|
|
</dcdiag>
|
|
|
|
<dcdiag language="fr">
|
|
|
|
<messages>
|
|
|
|
<global>D.*?marrage du test.*?:\s+(.*?)\n.*?(a r.*?ussi|a .*?chou.|warning)</global>
|
|
|
|
<ok>a r.*?ussi</ok>
|
|
|
|
<warning>warning</warning>
|
|
|
|
<critical>a .*?chou.</critical>
|
|
|
|
</messages>
|
|
|
|
</dcdiag>
|
|
|
|
</root>
|
|
|
|
END_FILE
|
|
|
|
|
|
|
|
if (defined($self->{option_results}->{config}) && $self->{option_results}->{config} ne '') {
|
|
|
|
$content_file = do {
|
|
|
|
local $/ = undef;
|
|
|
|
if (!open my $fh, "<", $self->{option_results}->{config}) {
|
|
|
|
$self->{output}->add_option_msg(short_msg => "Could not open file $self->{option_results}->{config} : $!");
|
|
|
|
$self->{output}->option_exit();
|
2014-02-17 14:37:45 +01:00
|
|
|
}
|
2020-09-22 10:28:34 +02:00
|
|
|
<$fh>;
|
|
|
|
};
|
2014-02-17 14:37:45 +01:00
|
|
|
}
|
2020-09-22 10:28:34 +02:00
|
|
|
|
|
|
|
my $content;
|
|
|
|
eval {
|
|
|
|
$content = XMLin($content_file, ForceArray => ['dcdiag'], KeyAttr => ['language']);
|
|
|
|
};
|
|
|
|
if ($@) {
|
|
|
|
$self->{output}->add_option_msg(short_msg => "Cannot decode xml response: $@");
|
|
|
|
$self->{output}->option_exit();
|
2014-02-17 14:37:45 +01:00
|
|
|
}
|
2020-09-22 10:28:34 +02:00
|
|
|
|
|
|
|
if (!defined($content->{dcdiag}->{$self->{option_results}->{language}})) {
|
|
|
|
$self->{output}->add_option_msg(short_msg => "Cannot find language '$self->{option_results}->{language}' in config file");
|
|
|
|
$self->{output}->option_exit();
|
2014-02-17 14:37:45 +01:00
|
|
|
}
|
2020-09-22 10:28:34 +02:00
|
|
|
|
|
|
|
return $content->{dcdiag}->{ $self->{option_results}->{language} };
|
2014-02-17 14:37:45 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
sub dcdiag {
|
|
|
|
my ($self, %options) = @_;
|
|
|
|
|
2017-09-07 15:16:51 +02:00
|
|
|
my $dcdiag_cmd = 'dcdiag /test:services /test:replications /test:advertising /test:fsmocheck /test:ridmanager';
|
2018-03-09 17:12:54 +01:00
|
|
|
$dcdiag_cmd .= ' /test:machineaccount' if (!defined($self->{option_results}->{nomachineaccount}));
|
2014-02-17 14:37:45 +01:00
|
|
|
$dcdiag_cmd .= ' /test:frssysvol' if ($self->{os_is2003} == 1);
|
2019-08-01 15:48:47 +02:00
|
|
|
$dcdiag_cmd .= ' /test:sysvolcheck' if ($self->{os_is2008} == 1 || $self->{os_is2012} == 1 || $self->{os_is2016} == 1);
|
2020-09-22 10:28:34 +02:00
|
|
|
|
2014-02-17 14:37:45 +01:00
|
|
|
if (!defined($self->{option_results}->{noeventlog})) {
|
|
|
|
$dcdiag_cmd .= ' /test:frsevent /test:kccevent' if ($self->{os_is2003} == 1);
|
2019-08-01 15:48:47 +02:00
|
|
|
$dcdiag_cmd .= ' /test:frsevent /test:kccevent' if (($self->{os_is2008} == 1 || $self->{os_is2012} == 1 || $self->{os_is2016} == 1) && !defined($self->{option_results}->{dfsr}));
|
|
|
|
$dcdiag_cmd .= ' /test:dfsrevent /test:kccevent' if (($self->{os_is2008} == 1 || $self->{os_is2012} == 1 || $self->{os_is2016} == 1) && defined($self->{option_results}->{dfsr}));
|
2014-02-17 14:37:45 +01:00
|
|
|
}
|
2020-09-22 10:28:34 +02:00
|
|
|
|
2019-08-01 15:48:47 +02:00
|
|
|
my ($stdout) = centreon::plugins::misc::windows_execute(
|
|
|
|
output => $self->{output},
|
|
|
|
timeout => $self->{option_results}->{timeout},
|
|
|
|
command => $dcdiag_cmd,
|
|
|
|
command_path => undef,
|
|
|
|
command_options => undef
|
|
|
|
);
|
2020-09-22 10:28:34 +02:00
|
|
|
|
2014-02-17 14:37:45 +01:00
|
|
|
my $match = 0;
|
2020-09-22 10:28:34 +02:00
|
|
|
while ($stdout =~ /$options{config}->{messages}->{global}/imsg) {
|
2014-02-20 15:57:30 +01:00
|
|
|
my ($test_name, $pattern) = ($1, lc($2));
|
2020-09-22 10:28:34 +02:00
|
|
|
|
|
|
|
if ($pattern =~ /$options{config}->{messages}->{ok}/i) {
|
2014-02-17 14:37:45 +01:00
|
|
|
$match = 1;
|
2020-09-22 10:28:34 +02:00
|
|
|
$self->{output}->output_add(
|
|
|
|
severity => 'OK',
|
|
|
|
short_msg => $test_name
|
|
|
|
);
|
|
|
|
} elsif ($pattern =~ /$options{config}->{messages}->{critical}/i) {
|
2014-02-17 14:37:45 +01:00
|
|
|
$match = 1;
|
2020-09-22 10:28:34 +02:00
|
|
|
$self->{output}->output_add(
|
|
|
|
severity => 'CRITICAL',
|
|
|
|
short_msg => 'test ' . $test_name
|
|
|
|
);
|
|
|
|
} elsif ($pattern =~ /$options{config}->{messages}->{warning}/i) {
|
2014-02-17 14:37:45 +01:00
|
|
|
$match = 1;
|
2020-09-22 10:28:34 +02:00
|
|
|
$self->{output}->output_add(
|
|
|
|
severity => 'WARNING',
|
|
|
|
short_msg => 'test ' . $test_name
|
|
|
|
);
|
2014-02-17 14:37:45 +01:00
|
|
|
}
|
|
|
|
}
|
2020-09-22 10:28:34 +02:00
|
|
|
|
2014-02-17 14:37:45 +01:00
|
|
|
if ($match == 0) {
|
2020-09-22 10:28:34 +02:00
|
|
|
$self->{output}->output_add(
|
|
|
|
severity => 'UNKNOWN',
|
|
|
|
short_msg => 'Cannot match output test (maybe you need to set the good language)'
|
|
|
|
);
|
2014-02-17 14:37:45 +01:00
|
|
|
return 1;
|
|
|
|
}
|
2020-09-22 10:28:34 +02:00
|
|
|
|
2014-02-17 14:37:45 +01:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
sub run {
|
|
|
|
my ($self, %options) = @_;
|
|
|
|
|
2020-09-22 10:28:34 +02:00
|
|
|
my $config = $self->read_config();
|
|
|
|
if ($self->check_version() == 0) {
|
|
|
|
$self->dcdiag(config => $config);
|
2014-02-17 14:37:45 +01:00
|
|
|
}
|
2020-09-22 10:28:34 +02:00
|
|
|
|
2014-02-17 14:37:45 +01:00
|
|
|
$self->{output}->display();
|
|
|
|
$self->{output}->exit();
|
|
|
|
}
|
|
|
|
|
|
|
|
1;
|
|
|
|
|
|
|
|
__END__
|
|
|
|
|
|
|
|
=head1 MODE
|
|
|
|
|
|
|
|
Check Windows Active Directory Health (use 'dcdiag' command).
|
|
|
|
|
|
|
|
=over 8
|
|
|
|
|
|
|
|
=item B<--config>
|
|
|
|
|
|
|
|
command can be localized by using a configuration file.
|
|
|
|
This parameter can be used to specify an alternative location for the configuration file
|
|
|
|
|
|
|
|
=item B<--language>
|
|
|
|
|
|
|
|
Set the language used in config file (default: 'en').
|
|
|
|
|
|
|
|
=item B<--dfsr>
|
|
|
|
|
|
|
|
Specifies that SysVol replication uses DFS instead of FRS (Windows 2008 or later)
|
|
|
|
|
|
|
|
=item B<--noeventlog>
|
|
|
|
|
|
|
|
Don't run the dc tests kccevent, frsevent and dfsrevent
|
|
|
|
|
2017-09-07 15:16:51 +02:00
|
|
|
=item B<--nomachineaccount>
|
|
|
|
|
|
|
|
Don't run the dc tests machineaccount
|
|
|
|
|
2014-02-17 14:37:45 +01:00
|
|
|
=item B<--timeout>
|
|
|
|
|
|
|
|
Set timeout time for command execution (Default: 30 sec)
|
|
|
|
|
|
|
|
=back
|
|
|
|
|
2017-09-07 15:16:51 +02:00
|
|
|
=cut
|