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.
84 lines
2.1 KiB
84 lines
2.1 KiB
<?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')); |
|
} |
|
}
|
|
|