Skip to content
Snippets Groups Projects

Issue #3371840: Time::getRequestTime is not immutable when there is no request

Closed Issue #3371840: Time::getRequestTime is not immutable when there is no request
All threads resolved!
Closed mondrake requested to merge issue/drupal-3371840:3371840-timegetrequesttime-is-not into 11.x
All threads resolved!
Files
3
@@ -6,23 +6,32 @@
/**
* Provides a class for obtaining system time.
*
* While the normal use case of this class expects that a Request object is
* available from the RequestStack, it is still possible to use it without, for
* example for early bootstrap containers or for unit tests. In those cases,
* the class will access global variables or set a proxy request time in order
* to return the request time.
*/
class Time implements TimeInterface {
/**
* The request stack.
*
* @var \Symfony\Component\HttpFoundation\RequestStack
*/
protected $requestStack;
protected ?RequestStack $requestStack;
/**
* A proxied request time if the request time is not available.
*/
protected float $proxyRequestTime;
/**
* Constructs a Time object.
*
* @param \Symfony\Component\HttpFoundation\RequestStack $request_stack
* The request stack.
* @param \Symfony\Component\HttpFoundation\RequestStack|null $request_stack
* (Optional) The request stack.
*/
public function __construct(RequestStack $request_stack) {
public function __construct(RequestStack $request_stack = NULL) {
$this->requestStack = $request_stack;
}
@@ -30,26 +39,26 @@ public function __construct(RequestStack $request_stack) {
* {@inheritdoc}
*/
public function getRequestTime() {
$request = $this->requestStack->getCurrentRequest();
$request = $this->requestStack ? $this->requestStack->getCurrentRequest() : NULL;
if ($request) {
return $request->server->get('REQUEST_TIME');
}
// If this is called prior to the request being pushed to the stack fallback
// to built-in globals (if available) or the system time.
return $_SERVER['REQUEST_TIME'] ?? $this->getCurrentTime();
return $_SERVER['REQUEST_TIME'] ?? $this->getProxyRequestTime();
}
/**
* {@inheritdoc}
*/
public function getRequestMicroTime() {
$request = $this->requestStack->getCurrentRequest();
$request = $this->requestStack ? $this->requestStack->getCurrentRequest() : NULL;
if ($request) {
return $request->server->get('REQUEST_TIME_FLOAT');
}
// If this is called prior to the request being pushed to the stack fallback
// to built-in globals (if available) or the system time.
return $_SERVER['REQUEST_TIME_FLOAT'] ?? $this->getCurrentMicroTime();
return $_SERVER['REQUEST_TIME_FLOAT'] ?? $this->getProxyRequestMicroTime();
}
/**
@@ -66,4 +75,30 @@ public function getCurrentMicroTime() {
return microtime(TRUE);
}
/**
* Returns a mimic of the timestamp of the current request.
*
* @return int
* A value returned by time().
*/
protected function getProxyRequestTime(): int {
if (!isset($this->proxyRequestTime)) {
$this->proxyRequestTime = $this->getCurrentMicroTime();
}
return (int) $this->proxyRequestTime;
}
/**
* Returns a mimic of the timestamp of the current request.
*
* @return float
* A value returned by microtime().
*/
protected function getProxyRequestMicroTime(): float {
if (!isset($this->proxyRequestTime)) {
$this->proxyRequestTime = $this->getCurrentMicroTime();
}
return $this->proxyRequestTime;
}
}
Loading