From 88c39bc817eb5124f3f1c1f9828db15b01509165 Mon Sep 17 00:00:00 2001 From: qgarnier Date: Tue, 31 Aug 2021 17:36:12 +0200 Subject: [PATCH] fix(sccm): sites-status - better management of psprovider (#3065) --- apps/microsoft/sccm/local/mode/sitestatus.pm | 27 +++++-------- centreon/common/powershell/sccm/sitestatus.pm | 38 ++++++++++--------- 2 files changed, 29 insertions(+), 36 deletions(-) diff --git a/apps/microsoft/sccm/local/mode/sitestatus.pm b/apps/microsoft/sccm/local/mode/sitestatus.pm index 276bde0bc..09775e5ab 100644 --- a/apps/microsoft/sccm/local/mode/sitestatus.pm +++ b/apps/microsoft/sccm/local/mode/sitestatus.pm @@ -25,19 +25,19 @@ use base qw(centreon::plugins::templates::counter); use strict; use warnings; use JSON::XS; -use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold); +use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold_ng); use centreon::plugins::misc; use centreon::common::powershell::sccm::sitestatus; my %map_mode = ( - 0 => 'Unknown', + 0 => '-', 1 => 'Replication maintenance', 2 => 'Recovery in progress', 3 => 'Upgrade in progress', 4 => 'Evaluation has expired', 5 => 'Site expansion in progress', 6 => 'Interop mode where there are primary sites, having the same version as the CAS, were not upgraded', - 7 => 'Interop mode where there are secondary sites, having the same version as the top-level site server, were not upgraded', + 7 => 'Interop mode where there are secondary sites, having the same version as the top-level site server, were not upgraded' ); my %map_status = ( 0 => 'Unknown', @@ -49,19 +49,19 @@ my %map_status = ( 6 => 'Failed to delete or deinstall the secondary site', 7 => 'Failed to upgrade the secondary site', 8 => 'Secondary site recovery is in progress', - 9 => 'Failed to recover secondary site', + 9 => 'Failed to recover secondary site' ); my %map_type = ( 0 => 'Unknown', 1 => 'SECONDARY', 2 => 'PRIMARY', - 4 => 'CAS', + 4 => 'CAS' ); sub custom_status_output { my ($self, %options) = @_; - return sprintf("status is '%s' [Type: %s] [Mode: '%s']", + return sprintf("status is '%s' [type: %s] [mode: '%s']", $self->{result_values}->{status}, $self->{result_values}->{type}, $self->{result_values}->{mode} @@ -88,7 +88,7 @@ sub set_counters { ]; $self->{maps_counters}->{sites} = [ - { label => 'status', threshold => 0, set => { + { label => 'status', type => 2, set => { key_values => [ { name => 'display' }, { name => 'SiteName' }, { name => 'Type' }, { name => 'Mode' }, { name => 'Status' }, { name => 'SecondarySiteCMUpdateStatus' } @@ -96,7 +96,7 @@ sub set_counters { closure_custom_calc => $self->can('custom_status_calc'), closure_custom_output => $self->can('custom_status_output'), closure_custom_perfdata => sub { return 0; }, - closure_custom_threshold_check => \&catalog_status_threshold + closure_custom_threshold_check => \&catalog_status_threshold_ng } } ]; @@ -120,21 +120,12 @@ sub new { 'command-options:s' => { name => 'command_options', default => '-InputFormat none -NoLogo -EncodedCommand' }, 'no-ps' => { name => 'no_ps' }, 'ps-exec-only' => { name => 'ps_exec_only' }, - 'ps-display' => { name => 'ps_display' }, - 'warning-status:s' => { name => 'warning_status', default => '' }, - 'critical-status:s' => { name => 'critical_status', default => '' } + 'ps-display' => { name => 'ps_display' } }); return $self; } -sub check_options { - my ($self, %options) = @_; - $self->SUPER::check_options(%options); - - $self->change_macros(macros => ['warning_status', 'critical_status']); -} - sub manage_selection { my ($self, %options) = @_; diff --git a/centreon/common/powershell/sccm/sitestatus.pm b/centreon/common/powershell/sccm/sitestatus.pm index e3793c295..c4e6e98e1 100644 --- a/centreon/common/powershell/sccm/sitestatus.pm +++ b/centreon/common/powershell/sccm/sitestatus.pm @@ -46,25 +46,27 @@ Try { $module = $modulePath + "\ConfigurationManager.psd1" Import-Module $module - New-PSDrive -Name SCCMDrive -PSProvider "AdminUI.PS.Provider\CMSite" -Root $env:COMPUTERNAME -Description "SCCM Site" | Out-Null - CD "SCCMDrive:\" - - $CMObject = Get-CMSite - - CD "C:\" - Remove-PSDrive -Name SCCMDrive - $returnArray = @() - - Foreach ($site in $CMObject) { - $returnObject = New-Object -TypeName PSObject - Add-Member -InputObject $returnObject -MemberType NoteProperty -Name "SiteCode" -Value $site.SiteCode - Add-Member -InputObject $returnObject -MemberType NoteProperty -Name "SiteName" -Value $site.SiteName - Add-Member -InputObject $returnObject -MemberType NoteProperty -Name "Type" -Value $site.Type - Add-Member -InputObject $returnObject -MemberType NoteProperty -Name "Mode" -Value $site.Mode - Add-Member -InputObject $returnObject -MemberType NoteProperty -Name "Status" -Value $site.Status - Add-Member -InputObject $returnObject -MemberType NoteProperty -Name "SecondarySiteCMUpdateStatus" -Value $site.SecondarySiteCMUpdateStatus - $returnArray += $returnObject + + $providers = Get-PSProvider | Where {$_.Name -match "CMSite" } + foreach ($provider in $providers) { + New-PSDrive -Name SCCMDrive -PSProvider $provider.Name -Root $env:COMPUTERNAME -Description "SCCM Site" | Out-Null + CD "SCCMDrive:\" + $CMObject = Get-CMSite + CD "C:\" + Remove-PSDrive -Name SCCMDrive + + Foreach ($site in $CMObject) { + $returnObject = New-Object -TypeName PSObject + Add-Member -InputObject $returnObject -MemberType NoteProperty -Name "providerName" -Value $provider.Name + Add-Member -InputObject $returnObject -MemberType NoteProperty -Name "SiteCode" -Value $site.SiteCode + Add-Member -InputObject $returnObject -MemberType NoteProperty -Name "SiteName" -Value $site.SiteName + Add-Member -InputObject $returnObject -MemberType NoteProperty -Name "Type" -Value $site.Type + Add-Member -InputObject $returnObject -MemberType NoteProperty -Name "Mode" -Value $site.Mode + Add-Member -InputObject $returnObject -MemberType NoteProperty -Name "Status" -Value $site.Status + Add-Member -InputObject $returnObject -MemberType NoteProperty -Name "SecondarySiteCMUpdateStatus" -Value $site.SecondarySiteCMUpdateStatus + $returnArray += $returnObject + } } $returnArray | ConvertTo-JSON-20 -forceArray $true