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.
79 lines
1.9 KiB
79 lines
1.9 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\Security;
|
||
|
|
||
|
use CodeIgniter\HTTP\RequestInterface;
|
||
|
use CodeIgniter\Security\Exceptions\SecurityException;
|
||
|
|
||
|
/**
|
||
|
* Expected behavior of a Security.
|
||
|
*/
|
||
|
interface SecurityInterface
|
||
|
{
|
||
|
/**
|
||
|
* CSRF Verify
|
||
|
*
|
||
|
* @return $this|false
|
||
|
*
|
||
|
* @throws SecurityException
|
||
|
*/
|
||
|
public function verify(RequestInterface $request);
|
||
|
|
||
|
/**
|
||
|
* Returns the CSRF Hash.
|
||
|
*/
|
||
|
public function getHash(): ?string;
|
||
|
|
||
|
/**
|
||
|
* Returns the CSRF Token Name.
|
||
|
*/
|
||
|
public function getTokenName(): string;
|
||
|
|
||
|
/**
|
||
|
* Returns the CSRF Header Name.
|
||
|
*/
|
||
|
public function getHeaderName(): string;
|
||
|
|
||
|
/**
|
||
|
* Returns the CSRF Cookie Name.
|
||
|
*/
|
||
|
public function getCookieName(): string;
|
||
|
|
||
|
/**
|
||
|
* Check if CSRF cookie is expired.
|
||
|
*
|
||
|
* @deprecated
|
||
|
*/
|
||
|
public function isExpired(): bool;
|
||
|
|
||
|
/**
|
||
|
* Check if request should be redirect on failure.
|
||
|
*/
|
||
|
public function shouldRedirect(): bool;
|
||
|
|
||
|
/**
|
||
|
* Sanitize Filename
|
||
|
*
|
||
|
* Tries to sanitize filenames in order to prevent directory traversal attempts
|
||
|
* and other security threats, which is particularly useful for files that
|
||
|
* were supplied via user input.
|
||
|
*
|
||
|
* If it is acceptable for the user input to include relative paths,
|
||
|
* e.g. file/in/some/approved/folder.txt, you can set the second optional
|
||
|
* parameter, $relative_path to TRUE.
|
||
|
*
|
||
|
* @param string $str Input file name
|
||
|
* @param bool $relativePath Whether to preserve paths
|
||
|
*/
|
||
|
public function sanitizeFilename(string $str, bool $relativePath = false): string;
|
||
|
}
|