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.
127 lines
3.2 KiB
127 lines
3.2 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\Cookie\Exceptions; |
|
|
|
use CodeIgniter\Exceptions\FrameworkException; |
|
|
|
/** |
|
* CookieException is thrown for invalid cookies initialization and management. |
|
*/ |
|
class CookieException extends FrameworkException |
|
{ |
|
/** |
|
* Thrown for invalid type given for the "Expires" attribute. |
|
* |
|
* @return static |
|
*/ |
|
public static function forInvalidExpiresTime(string $type) |
|
{ |
|
return new static(lang('Cookie.invalidExpiresTime', [$type])); |
|
} |
|
|
|
/** |
|
* Thrown when the value provided for "Expires" is invalid. |
|
* |
|
* @return static |
|
*/ |
|
public static function forInvalidExpiresValue() |
|
{ |
|
return new static(lang('Cookie.invalidExpiresValue')); |
|
} |
|
|
|
/** |
|
* Thrown when the cookie name contains invalid characters per RFC 2616. |
|
* |
|
* @return static |
|
*/ |
|
public static function forInvalidCookieName(string $name) |
|
{ |
|
return new static(lang('Cookie.invalidCookieName', [$name])); |
|
} |
|
|
|
/** |
|
* Thrown when the cookie name is empty. |
|
* |
|
* @return static |
|
*/ |
|
public static function forEmptyCookieName() |
|
{ |
|
return new static(lang('Cookie.emptyCookieName')); |
|
} |
|
|
|
/** |
|
* Thrown when using the `__Secure-` prefix but the `Secure` attribute |
|
* is not set to true. |
|
* |
|
* @return static |
|
*/ |
|
public static function forInvalidSecurePrefix() |
|
{ |
|
return new static(lang('Cookie.invalidSecurePrefix')); |
|
} |
|
|
|
/** |
|
* Thrown when using the `__Host-` prefix but the `Secure` flag is not |
|
* set, the `Domain` is set, and the `Path` is not `/`. |
|
* |
|
* @return static |
|
*/ |
|
public static function forInvalidHostPrefix() |
|
{ |
|
return new static(lang('Cookie.invalidHostPrefix')); |
|
} |
|
|
|
/** |
|
* Thrown when the `SameSite` attribute given is not of the valid types. |
|
* |
|
* @return static |
|
*/ |
|
public static function forInvalidSameSite(string $sameSite) |
|
{ |
|
return new static(lang('Cookie.invalidSameSite', [$sameSite])); |
|
} |
|
|
|
/** |
|
* Thrown when the `SameSite` attribute is set to `None` but the `Secure` |
|
* attribute is not set. |
|
* |
|
* @return static |
|
*/ |
|
public static function forInvalidSameSiteNone() |
|
{ |
|
return new static(lang('Cookie.invalidSameSiteNone')); |
|
} |
|
|
|
/** |
|
* Thrown when the `CookieStore` class is filled with invalid Cookie objects. |
|
* |
|
* @param list<int|string> $data |
|
* |
|
* @return static |
|
*/ |
|
public static function forInvalidCookieInstance(array $data) |
|
{ |
|
return new static(lang('Cookie.invalidCookieInstance', $data)); |
|
} |
|
|
|
/** |
|
* Thrown when the queried Cookie object does not exist in the cookie collection. |
|
* |
|
* @param list<string> $data |
|
* |
|
* @return static |
|
*/ |
|
public static function forUnknownCookieInstance(array $data) |
|
{ |
|
return new static(lang('Cookie.unknownCookieInstance', $data)); |
|
} |
|
}
|
|
|