icingadb-web/library/Icingadb/Common/ServiceStates.php
Bastian Lederer 8622514fcd Change implicit nullable type declaration to explicit
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>"
2026-03-19 22:08:30 +01:00

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;
}
}