This commit is contained in:
Lord Hepipud 2019-07-24 13:13:31 +02:00
commit 27b78a757e
5 changed files with 30 additions and 5 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 = ConvertTo-ServiceStatusCode -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

@ -1,7 +1,7 @@
Import-IcingaLib core\perfcounter; Import-IcingaLib core\perfcounter;
Import-IcingaLib icinga\plugin; Import-IcingaLib icinga\plugin;
function Invoke-IcingaCheckFreePartition() function Invoke-IcingaCheckUsedPartitionSpace()
{ {
param( param(
$Warning, $Warning,
@ -33,7 +33,7 @@ function Invoke-IcingaCheckFreePartition()
} }
} }
$IcingaCheck = New-IcingaCheck -Name ([string]::Format('Partition {0}', $Letter)) -Value $DiskFree.([string]::Format($Letter))."Free Space" -Unit '%'; $IcingaCheck = New-IcingaCheck -Name ([string]::Format('Partition {0}', $Letter)) -Value (100-($DiskFree.([string]::Format($Letter))."Free Space")) -Unit '%';
$IcingaCheck.WarnOutOfRange($Warning).CritOutOfRange($Critical) | Out-Null; $IcingaCheck.WarnOutOfRange($Warning).CritOutOfRange($Critical) | Out-Null;
$DiskPackage.AddCheck($IcingaCheck); $DiskPackage.AddCheck($IcingaCheck);
} }

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

@ -0,0 +1,14 @@
function ConvertTo-ServiceStatusCode()
{
param (
$Status
)
if ($Status -match "^\d+$") {
return $Status
} else {
$Status = $ProviderEnums.ServiceStatus.($Status);
}
return $Status;
}

View file

@ -62,4 +62,4 @@ function Get-IcingaServices()
); );
} }
return $ServiceData; return $ServiceData;
} }