mirror of
https://github.com/Icinga/icingadb-web.git
synced 2026-05-28 04:36:06 -04:00
Since PHP 8.4 implicitly nullable parameter types are deprecated. Normalize scoped PHPDoc for nullable-parameter updates: use `?Type` instead of `Type|null` and remove column alignment. Co-authored-by: "Eric Lippmann <eric.lippmann@icinga.com>"
130 lines
3.5 KiB
PHP
130 lines
3.5 KiB
PHP
<?php
|
|
|
|
// SPDX-FileCopyrightText: 2019 Icinga GmbH <https://icinga.com>
|
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
namespace Icinga\Module\Icingadb\Common;
|
|
|
|
/**
|
|
* Collection of possible service states.
|
|
*/
|
|
class ServiceStates
|
|
{
|
|
public const OK = 0;
|
|
|
|
public const WARNING = 1;
|
|
|
|
public const CRITICAL = 2;
|
|
|
|
public const UNKNOWN = 3;
|
|
|
|
public const PENDING = 99;
|
|
|
|
/**
|
|
* Get the integer value of the given textual service state
|
|
*
|
|
* @param string $state
|
|
*
|
|
* @return int
|
|
*
|
|
* @throws \InvalidArgumentException If the given service state is invalid, i.e. not known
|
|
*/
|
|
public static function int(string $state): int
|
|
{
|
|
switch (strtolower($state)) {
|
|
case 'ok':
|
|
$int = self::OK;
|
|
break;
|
|
case 'warning':
|
|
$int = self::WARNING;
|
|
break;
|
|
case 'critical':
|
|
$int = self::CRITICAL;
|
|
break;
|
|
case 'unknown':
|
|
$int = self::UNKNOWN;
|
|
break;
|
|
case 'pending':
|
|
$int = self::PENDING;
|
|
break;
|
|
default:
|
|
throw new \InvalidArgumentException(sprintf('Invalid service state %d', $state));
|
|
}
|
|
|
|
return $int;
|
|
}
|
|
|
|
/**
|
|
* Get the textual representation of the passed service state
|
|
*
|
|
* @param ?int $state
|
|
*
|
|
* @return string
|
|
*
|
|
* @throws \InvalidArgumentException If the given service state is invalid, i.e. not known
|
|
*/
|
|
public static function text(?int $state = null): string
|
|
{
|
|
switch (true) {
|
|
case $state === self::OK:
|
|
$text = 'ok';
|
|
break;
|
|
case $state === self::WARNING:
|
|
$text = 'warning';
|
|
break;
|
|
case $state === self::CRITICAL:
|
|
$text = 'critical';
|
|
break;
|
|
case $state === self::UNKNOWN:
|
|
$text = 'unknown';
|
|
break;
|
|
case $state === self::PENDING:
|
|
$text = 'pending';
|
|
break;
|
|
case $state === null:
|
|
$text = 'not-available';
|
|
break;
|
|
default:
|
|
throw new \InvalidArgumentException(sprintf('Invalid service state %d', $state));
|
|
}
|
|
|
|
return $text;
|
|
}
|
|
|
|
/**
|
|
* Get the translated textual representation of the passed service state
|
|
*
|
|
* @param ?int $state
|
|
*
|
|
* @return string
|
|
*
|
|
* @throws \InvalidArgumentException If the given service state is invalid, i.e. not known
|
|
*/
|
|
public static function translated(?int $state = null): string
|
|
{
|
|
switch (true) {
|
|
case $state === self::OK:
|
|
$text = t('ok');
|
|
break;
|
|
case $state === self::WARNING:
|
|
$text = t('warning');
|
|
break;
|
|
case $state === self::CRITICAL:
|
|
$text = t('critical');
|
|
break;
|
|
case $state === self::UNKNOWN:
|
|
$text = t('unknown');
|
|
break;
|
|
case $state === self::PENDING:
|
|
$text = t('pending');
|
|
break;
|
|
case $state === null:
|
|
$text = t('not available');
|
|
break;
|
|
default:
|
|
throw new \InvalidArgumentException(sprintf('Invalid service state %d', $state));
|
|
}
|
|
|
|
return $text;
|
|
}
|
|
}
|