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.
76 lines
2.0 KiB
76 lines
2.0 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\Filters; |
|
|
|
use CodeIgniter\HTTP\IncomingRequest; |
|
use CodeIgniter\HTTP\RedirectResponse; |
|
use CodeIgniter\HTTP\RequestInterface; |
|
use CodeIgniter\HTTP\ResponseInterface; |
|
use CodeIgniter\Security\Exceptions\SecurityException; |
|
use Config\Services; |
|
|
|
/** |
|
* CSRF filter. |
|
* |
|
* This filter is not intended to be used from the command line. |
|
* |
|
* @codeCoverageIgnore |
|
* @see \CodeIgniter\Filters\CSRFTest |
|
*/ |
|
class CSRF implements FilterInterface |
|
{ |
|
/** |
|
* Do whatever processing this filter needs to do. |
|
* By default it should not return anything during |
|
* normal execution. However, when an abnormal state |
|
* is found, it should return an instance of |
|
* CodeIgniter\HTTP\Response. If it does, script |
|
* execution will end and that Response will be |
|
* sent back to the client, allowing for error pages, |
|
* redirects, etc. |
|
* |
|
* @param list<string>|null $arguments |
|
* |
|
* @return RedirectResponse|void |
|
* |
|
* @throws SecurityException |
|
*/ |
|
public function before(RequestInterface $request, $arguments = null) |
|
{ |
|
if (! $request instanceof IncomingRequest) { |
|
return; |
|
} |
|
|
|
$security = Services::security(); |
|
|
|
try { |
|
$security->verify($request); |
|
} catch (SecurityException $e) { |
|
if ($security->shouldRedirect() && ! $request->isAJAX()) { |
|
return redirect()->back()->with('error', $e->getMessage()); |
|
} |
|
|
|
throw $e; |
|
} |
|
} |
|
|
|
/** |
|
* We don't have anything to do here. |
|
* |
|
* @param list<string>|null $arguments |
|
* |
|
* @return void |
|
*/ |
|
public function after(RequestInterface $request, ResponseInterface $response, $arguments = null) |
|
{ |
|
} |
|
}
|
|
|