You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
85 lines
2.1 KiB
85 lines
2.1 KiB
1 year ago
|
<?php
|
||
|
|
||
|
/**
|
||
|
* This file is part of CodeIgniter 4 framework.
|
||
|
*
|
||
|
* (c) CodeIgniter Foundation <admin@codeigniter.com>
|
||
|
*
|
||
|
* For the full copyright and license information, please view
|
||
|
* the LICENSE file that was distributed with this source code.
|
||
|
*/
|
||
|
|
||
|
namespace CodeIgniter\Entity\Exceptions;
|
||
|
|
||
|
use CodeIgniter\Exceptions\FrameworkException;
|
||
|
use CodeIgniter\Exceptions\HasExitCodeInterface;
|
||
|
|
||
|
/**
|
||
|
* CastException is thrown for invalid cast initialization and management.
|
||
|
*/
|
||
|
class CastException extends FrameworkException implements HasExitCodeInterface
|
||
|
{
|
||
|
public function getExitCode(): int
|
||
|
{
|
||
|
return EXIT_CONFIG;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Thrown when the cast class does not extends BaseCast.
|
||
|
*
|
||
|
* @return static
|
||
|
*/
|
||
|
public static function forInvalidInterface(string $class)
|
||
|
{
|
||
|
return new static(lang('Cast.baseCastMissing', [$class]));
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Thrown when the Json format is invalid.
|
||
|
*
|
||
|
* @return static
|
||
|
*/
|
||
|
public static function forInvalidJsonFormat(int $error)
|
||
|
{
|
||
|
switch ($error) {
|
||
|
case JSON_ERROR_DEPTH:
|
||
|
return new static(lang('Cast.jsonErrorDepth'));
|
||
|
|
||
|
case JSON_ERROR_STATE_MISMATCH:
|
||
|
return new static(lang('Cast.jsonErrorStateMismatch'));
|
||
|
|
||
|
case JSON_ERROR_CTRL_CHAR:
|
||
|
return new static(lang('Cast.jsonErrorCtrlChar'));
|
||
|
|
||
|
case JSON_ERROR_SYNTAX:
|
||
|
return new static(lang('Cast.jsonErrorSyntax'));
|
||
|
|
||
|
case JSON_ERROR_UTF8:
|
||
|
return new static(lang('Cast.jsonErrorUtf8'));
|
||
|
|
||
|
default:
|
||
|
return new static(lang('Cast.jsonErrorUnknown'));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Thrown when the cast method is not `get` or `set`.
|
||
|
*
|
||
|
* @return static
|
||
|
*/
|
||
|
public static function forInvalidMethod(string $method)
|
||
|
{
|
||
|
return new static(lang('Cast.invalidCastMethod', [$method]));
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Thrown when the casting timestamp is not correct timestamp.
|
||
|
*
|
||
|
* @return static
|
||
|
*/
|
||
|
public static function forInvalidTimestamp()
|
||
|
{
|
||
|
return new static(lang('Cast.invalidTimestamp'));
|
||
|
}
|
||
|
}
|