Expanded upon lib/provider/services to support translated status values in Invoke-IcingaCheckService.psm1

This commit is contained in:
Alexander Stoll 2019-07-24 10:26:39 +02:00
parent e2c8933c9a
commit a5ab649f80
3 changed files with 28 additions and 2 deletions

View file

@ -13,10 +13,10 @@ function Invoke-IcingaCheckService()
$FoundService = Get-IcingaServices -Service $Service; $FoundService = Get-IcingaServices -Service $Service;
$ServiceName = $FoundService.Values.metadata.ServiceName; $ServiceName = $FoundService.Values.metadata.ServiceName;
$DisplayName = $FoundService.Values.metadata.DisplayName; $DisplayName = $FoundService.Values.metadata.DisplayName;
# $Status = Get-IcingaServicesStatusTranslation -Status $Status; $Status = Get-IcingaServicesStatusTranslation -Status $Status;
$StatusRaw = $FoundService.Values.configuration.Status.raw; $StatusRaw = $FoundService.Values.configuration.Status.raw;
$IcingaCheck = New-IcingaCheck -Name ([string]::Format('Service "{0} ({1})"', $DisplayName, $ServiceName)) -Value $StatusRaw -ObjectExists $FoundService -ValueTranslation $ProviderEnums.ServiceStatus; $IcingaCheck = New-IcingaCheck -Name ([string]::Format('Service "{0} ({1})"', $DisplayName, $ServiceName)) -Value $StatusRaw -ObjectExists $FoundService -ValueTranslation $ProviderEnums.ServicesStatus;
$IcingaCheck.CritIfNotMatch($Status) | Out-Null; $IcingaCheck.CritIfNotMatch($Status) | Out-Null;
exit (New-IcingaCheckResult -Name "Service $Service" -Check $IcingaCheck -NoPerfData $TRUE -Compile); exit (New-IcingaCheckResult -Name "Service $Service" -Check $IcingaCheck -NoPerfData $TRUE -Compile);

View file

@ -470,6 +470,15 @@
61= 'VSE'; 61= 'VSE';
62= 'TPF'; 62= 'TPF';
} }
<##################################################################################################
################# /lib/provider/Services ###########################################################
##################################################################################################>
[hashtable]$ServiceStatus = @{
'Stopped' = 1;
'Running' = 4;
}
[hashtable]$ProviderEnums = @{ [hashtable]$ProviderEnums = @{
#/lib/provider/bios #/lib/provider/bios
@ -493,6 +502,8 @@
WindowsOSProductSuite = $WindowsOSProductSuite; WindowsOSProductSuite = $WindowsOSProductSuite;
WindowsProductType = $WindowsProductType; WindowsProductType = $WindowsProductType;
WindowsOSType = $WindowsOSType; WindowsOSType = $WindowsOSType;
#/lib/provider/services
ServiceStatus = $ServiceStatus;
} }
Export-ModuleMember -Variable @('ProviderEnums'); Export-ModuleMember -Variable @('ProviderEnums');

View file

@ -62,4 +62,19 @@ function Get-IcingaServices()
); );
} }
return $ServiceData; return $ServiceData;
}
function Get-IcingaServicesStatusTranslation()
{
param (
$Status
)
if ($Status -match "^\d+$") {
return $Status
} else {
$Status = $ProviderEnums.ServiceStatus.($Status);
}
return $Status;
} }