fix pending reboot
This commit is contained in:
parent
7ddbe8efa4
commit
c455dd7668
|
@ -49,26 +49,26 @@ Try {
|
||||||
|
|
||||||
## Making registry connection to the local/remote computer
|
## Making registry connection to the local/remote computer
|
||||||
$HKLM = [UInt32] "0x80000002"
|
$HKLM = [UInt32] "0x80000002"
|
||||||
$WMI_Reg = [WMIClass] "\\$ComputerName\root\default:StdRegProv"
|
$WMI_Reg = [WMIClass] "\\\\$ComputerName\\root\\default:StdRegProv"
|
||||||
|
|
||||||
## If Vista/2008 & Above query the CBS Reg Key
|
## If Vista/2008 & Above query the CBS Reg Key
|
||||||
If ([Int32]$WMI_OS.BuildNumber -ge 6001) {
|
If ([Int32]$WMI_OS.BuildNumber -ge 6001) {
|
||||||
$RegSubKeysCBS = $WMI_Reg.EnumKey($HKLM,"SOFTWARE\Microsoft\Windows\CurrentVersion\Component Based Servicing\")
|
$RegSubKeysCBS = $WMI_Reg.EnumKey($HKLM,"SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Component Based Servicing\\")
|
||||||
$CBSRebootPend = $RegSubKeysCBS.sNames -contains "RebootPending"
|
$CBSRebootPend = $RegSubKeysCBS.sNames -contains "RebootPending"
|
||||||
}
|
}
|
||||||
|
|
||||||
## Query WUAU from the registry
|
## Query WUAU from the registry
|
||||||
$RegWUAURebootReq = $WMI_Reg.EnumKey($HKLM,"SOFTWARE\Microsoft\Windows\CurrentVersion\WindowsUpdate\Auto Update\")
|
$RegWUAURebootReq = $WMI_Reg.EnumKey($HKLM,"SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\WindowsUpdate\\Auto Update\\")
|
||||||
$WUAURebootReq = $RegWUAURebootReq.sNames -contains "RebootRequired"
|
$WUAURebootReq = $RegWUAURebootReq.sNames -contains "RebootRequired"
|
||||||
|
|
||||||
## Query PendingFileRenameOperations from the registry
|
## Query PendingFileRenameOperations from the registry
|
||||||
$RegSubKeySM = $WMI_Reg.GetMultiStringValue($HKLM,"SYSTEM\CurrentControlSet\Control\Session Manager\","PendingFileRenameOperations")
|
$RegSubKeySM = $WMI_Reg.GetMultiStringValue($HKLM,"SYSTEM\\CurrentControlSet\\Control\\Session Manager\\","PendingFileRenameOperations")
|
||||||
$RegValuePFRO = $RegSubKeySM.sValue
|
$RegValuePFRO = $RegSubKeySM.sValue
|
||||||
|
|
||||||
## Query ComputerName and ActiveComputerName from the registry
|
## Query ComputerName and ActiveComputerName from the registry
|
||||||
$ActCompNm = $WMI_Reg.GetStringValue($HKLM,"SYSTEM\CurrentControlSet\Control\ComputerName\ActiveComputerName\","ComputerName")
|
$ActCompNm = $WMI_Reg.GetStringValue($HKLM,"SYSTEM\\CurrentControlSet\\Control\\ComputerName\\ActiveComputerName\\","ComputerName")
|
||||||
$CompNm = $WMI_Reg.GetStringValue($HKLM,"SYSTEM\CurrentControlSet\Control\ComputerName\ComputerName\","ComputerName")
|
$CompNm = $WMI_Reg.GetStringValue($HKLM,"SYSTEM\\CurrentControlSet\\Control\\ComputerName\\ComputerName\\","ComputerName")
|
||||||
If ($ActCompNm -ne $CompNm) {
|
If ($ActCompNm -ne $CompNm) {
|
||||||
$CompPendRen = $true
|
$CompPendRen = $true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -81,7 +81,7 @@ Try {
|
||||||
## To avoid nested "if" statements and unneeded WMI calls to determine if the CCM_ClientUtilities class exist, setting EA = 0
|
## To avoid nested "if" statements and unneeded WMI calls to determine if the CCM_ClientUtilities class exist, setting EA = 0
|
||||||
$CCMClientSDK = $null
|
$CCMClientSDK = $null
|
||||||
$CCMSplat = @{
|
$CCMSplat = @{
|
||||||
NameSpace="ROOT\ccm\ClientSDK"
|
NameSpace="ROOT\\ccm\\ClientSDK"
|
||||||
Class="CCM_ClientUtilities"
|
Class="CCM_ClientUtilities"
|
||||||
Name="DetermineIfRebootPending"
|
Name="DetermineIfRebootPending"
|
||||||
ComputerName=$ComputerName
|
ComputerName=$ComputerName
|
||||||
|
@ -138,3 +138,4 @@ __END__
|
||||||
Method to get pending reboot informations.
|
Method to get pending reboot informations.
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
||||||
|
|
|
@ -25,7 +25,7 @@ use base qw(centreon::plugins::templates::counter);
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::misc;
|
use centreon::plugins::misc;
|
||||||
use centreon::common::powershell::windows::pendingreboot
|
use centreon::common::powershell::windows::pendingreboot;
|
||||||
|
|
||||||
my $instance_mode;
|
my $instance_mode;
|
||||||
|
|
||||||
|
@ -74,9 +74,9 @@ sub set_counters {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{maps_counters_type} = [
|
$self->{maps_counters_type} = [
|
||||||
{ name => 'vm', type => 1, },
|
{ name => 'pendingreboot', type => 0 },
|
||||||
];
|
];
|
||||||
$self->{maps_counters}->{vm} = [
|
$self->{maps_counters}->{pendingreboot} = [
|
||||||
{ label => 'status', , threshold => 0, set => {
|
{ label => 'status', , threshold => 0, set => {
|
||||||
key_values => [ { name => 'CBServicing' }, { name => 'RebootPending' }, { name => 'WindowsUpdate' },
|
key_values => [ { name => 'CBServicing' }, { name => 'RebootPending' }, { name => 'WindowsUpdate' },
|
||||||
{ name => 'CCMClientSDK' } ],
|
{ name => 'CCMClientSDK' } ],
|
||||||
|
@ -148,7 +148,7 @@ sub manage_selection {
|
||||||
|
|
||||||
#[CBServicing=False][WindowsUpdate=False][CCMClientSDK=][PendComputerRename=False][PendFileRename=False][PendFileRenVal=][RebootPending=False]
|
#[CBServicing=False][WindowsUpdate=False][CCMClientSDK=][PendComputerRename=False][PendFileRename=False][PendFileRenVal=][RebootPending=False]
|
||||||
$self->{pendingreboot} = {};
|
$self->{pendingreboot} = {};
|
||||||
while ($line =~ /\[(.*?)=\s*(.*?)\s*\]/mg) {
|
while ($stdout =~ /\[(.*?)=\s*(.*?)\s*\]/mg) {
|
||||||
$self->{pendingreboot}->{$1} = $2;
|
$self->{pendingreboot}->{$1} = $2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue