From 21e74efbb54b4cdb7008957e644ff0e92cfa87b7 Mon Sep 17 00:00:00 2001 From: UrBnW <40244829+UrBnW@users.noreply.github.com> Date: Tue, 1 Dec 2020 17:09:03 +0100 Subject: [PATCH 1/2] enh(windows) Get windows version --- centreon/common/powershell/windows/pendingreboot.pm | 3 +++ 1 file changed, 3 insertions(+) diff --git a/centreon/common/powershell/windows/pendingreboot.pm b/centreon/common/powershell/windows/pendingreboot.pm index 39165848f..25960fe51 100644 --- a/centreon/common/powershell/windows/pendingreboot.pm +++ b/centreon/common/powershell/windows/pendingreboot.pm @@ -110,7 +110,10 @@ Try { $SCCM = $null } + $WindowsVersion = (Get-WmiObject -class Win32_OperatingSystem).Caption; + $item = @{ + WindowsVersion = $WindowsVersion; CBServicing = $CBSRebootPend; WindowsUpdate = $WUAURebootReq; CCMClientSDK = $SCCM; From fc3eb3b80d7307c93982af91f5b0c4991d50e88d Mon Sep 17 00:00:00 2001 From: UrBnW <40244829+UrBnW@users.noreply.github.com> Date: Tue, 1 Dec 2020 17:49:34 +0100 Subject: [PATCH 2/2] enh(windows) Output Windows version --- os/windows/local/mode/pendingreboot.pm | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/os/windows/local/mode/pendingreboot.pm b/os/windows/local/mode/pendingreboot.pm index ca80b8952..542658dc0 100644 --- a/os/windows/local/mode/pendingreboot.pm +++ b/os/windows/local/mode/pendingreboot.pm @@ -33,8 +33,8 @@ sub custom_status_output { my ($self, %options) = @_; return sprintf( - 'Reboot Pending: %s [Windows Update: %s][Component Based Servicing: %s][SCCM Client: %s][File Rename Operations: %s][Computer Name Change: %s]', - $self->{result_values}->{RebootPending}, + "'%s': reboot pending is %s [Windows Update: %s][Component Based Servicing: %s][SCCM Client: %s][File Rename Operations: %s][Computer Name Change: %s]", + $self->{result_values}->{WindowsVersion}, $self->{result_values}->{WindowsUpdate}, $self->{result_values}->{CBServicing}, $self->{result_values}->{CCMClientSDK}, @@ -46,6 +46,7 @@ sub custom_status_output { sub custom_status_calc { my ($self, %options) = @_; + $self->{result_values}->{WindowsVersion} = $options{new_datas}->{$self->{instance} . '_WindowsVersion'}; $self->{result_values}->{CBServicing} = $options{new_datas}->{$self->{instance} . '_CBServicing'}; $self->{result_values}->{RebootPending} = $options{new_datas}->{$self->{instance} . '_RebootPending'}; $self->{result_values}->{WindowsUpdate} = $options{new_datas}->{$self->{instance} . '_WindowsUpdate'}; @@ -64,7 +65,7 @@ sub set_counters { $self->{maps_counters}->{pendingreboot} = [ { label => 'status', , threshold => 0, set => { key_values => [ - { name => 'CBServicing' }, { name => 'RebootPending' }, { name => 'WindowsUpdate' }, + { name => 'WindowsVersion' }, { name => 'CBServicing' }, { name => 'RebootPending' }, { name => 'WindowsUpdate' }, { name => 'CCMClientSDK' }, { name => 'PendComputerRename' }, { name => 'PendFileRename' } ], closure_custom_calc => $self->can('custom_status_calc'), @@ -145,11 +146,11 @@ sub manage_selection { $self->{output}->option_exit(); } - #{ CBServicing: false, WindowsUpdate: false, CCMClientSDK: null, PendComputerRename: false, PendFileRename: false, PendFileRenVal: null, RebootPending: false } + #{ WindowsVersion: "Microsoft Windows 2003 Server", CBServicing: false, WindowsUpdate: false, CCMClientSDK: null, PendComputerRename: false, PendFileRename: false, PendFileRenVal: null, RebootPending: false } foreach (keys %$decoded) { $decoded->{$_} = '-' if (!defined($decoded->{$_})); - $decoded->{$_} = 'true' if ($decoded->{$_} =~ /true|1/i); - $decoded->{$_} = 'false' if ($decoded->{$_} =~ /false|0/i); + $decoded->{$_} = 'true' if ($decoded->{$_} =~ /^(?:true|1)$/i); + $decoded->{$_} = 'false' if ($decoded->{$_} =~ /^(?:false|0)$/i); } $self->{pendingreboot} = $decoded;