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.
92 lines
2.3 KiB
92 lines
2.3 KiB
<?php |
|
|
|
/* |
|
* This file is part of the Symfony package. |
|
* |
|
* (c) Fabien Potencier <fabien@symfony.com> |
|
* |
|
* For the full copyright and license information, please view the LICENSE |
|
* file that was distributed with this source code. |
|
*/ |
|
|
|
namespace Symfony\Component\HttpKernel\Event; |
|
|
|
use Symfony\Component\HttpFoundation\Request; |
|
use Symfony\Component\HttpKernel\HttpKernelInterface; |
|
use Symfony\Contracts\EventDispatcher\Event; |
|
|
|
/** |
|
* Base class for events thrown in the HttpKernel component. |
|
* |
|
* @author Bernhard Schussek <bschussek@gmail.com> |
|
*/ |
|
class KernelEvent extends Event |
|
{ |
|
private $kernel; |
|
private $request; |
|
private $requestType; |
|
|
|
/** |
|
* @param int $requestType The request type the kernel is currently processing; one of |
|
* HttpKernelInterface::MAIN_REQUEST or HttpKernelInterface::SUB_REQUEST |
|
*/ |
|
public function __construct(HttpKernelInterface $kernel, Request $request, ?int $requestType) |
|
{ |
|
$this->kernel = $kernel; |
|
$this->request = $request; |
|
$this->requestType = $requestType; |
|
} |
|
|
|
/** |
|
* Returns the kernel in which this event was thrown. |
|
* |
|
* @return HttpKernelInterface |
|
*/ |
|
public function getKernel() |
|
{ |
|
return $this->kernel; |
|
} |
|
|
|
/** |
|
* Returns the request the kernel is currently processing. |
|
* |
|
* @return Request |
|
*/ |
|
public function getRequest() |
|
{ |
|
return $this->request; |
|
} |
|
|
|
/** |
|
* Returns the request type the kernel is currently processing. |
|
* |
|
* @return int One of HttpKernelInterface::MAIN_REQUEST and |
|
* HttpKernelInterface::SUB_REQUEST |
|
*/ |
|
public function getRequestType() |
|
{ |
|
return $this->requestType; |
|
} |
|
|
|
/** |
|
* Checks if this is the main request. |
|
*/ |
|
public function isMainRequest(): bool |
|
{ |
|
return HttpKernelInterface::MAIN_REQUEST === $this->requestType; |
|
} |
|
|
|
/** |
|
* Checks if this is a master request. |
|
* |
|
* @return bool |
|
* |
|
* @deprecated since symfony/http-kernel 5.3, use isMainRequest() instead |
|
*/ |
|
public function isMasterRequest() |
|
{ |
|
trigger_deprecation('symfony/http-kernel', '5.3', '"%s()" is deprecated, use "isMainRequest()" instead.', __METHOD__); |
|
|
|
return $this->isMainRequest(); |
|
} |
|
}
|
|
|