SetTimezoneController.php in Timezone Detect 8
File
src/Controller/SetTimezoneController.php
View source
<?php
namespace Drupal\timezone_detect\Controller;
use Drupal\Component\Utility\Html;
use Drupal\Core\Access\CsrfTokenGenerator;
use Drupal\Core\Ajax\AjaxResponse;
use Drupal\Core\Config\ConfigFactoryInterface;
use Drupal\Core\Controller\ControllerBase;
use Drupal\Core\DependencyInjection\ContainerInjectionInterface;
use Drupal\Core\Session\AccountProxyInterface;
use Drupal\user\Entity\User;
use Psr\Log\LoggerInterface;
use Symfony\Component\DependencyInjection\ContainerInterface;
use Symfony\Component\HttpFoundation\Request;
class SetTimezoneController extends ControllerBase implements ContainerInjectionInterface {
protected $request;
protected $account;
protected $logger;
protected $tokenGenerator;
public function __construct(Request $request, AccountProxyInterface $account, LoggerInterface $logger, CsrfTokenGenerator $tokenGenerator, ConfigFactoryInterface $configFactory) {
$this->request = $request;
$this->account = $account;
$this->logger = $logger;
$this->tokenGenerator = $tokenGenerator;
$this->configFactory = $configFactory;
}
public static function create(ContainerInterface $container) {
return new static($container
->get('request_stack')
->getCurrentRequest(), $container
->get('current_user'), $container
->get('logger.factory')
->get('timezone_detect'), $container
->get('csrf_token'), $container
->get('config.factory'));
}
public function updateTimezone() {
$response = new AjaxResponse();
if ($this->account
->isAuthenticated()) {
$timezone = Html::escape($this->request->request
->get('timezone'));
if (!isset($timezone)) {
$this->logger
->error('Attempting to set timezone for user @uid, but no timezone found in $_POST data; aborting.', [
'@uid' => $this->account
->id(),
]);
unset($_SESSION['timezone_detect']['update_timezone']);
return $response;
}
$token = $this->request->request
->get('token');
if (!isset($token) || !$this->tokenGenerator
->validate($token)) {
$this->logger
->error('Attempting to set timezone for user @uid, but session token in $_POST data is empty or invalid; aborting.', [
'@uid' => $this->account
->ui(),
]);
unset($_SESSION['timezone_detect']['update_timezone']);
return $response;
}
$_SESSION['timezone_detect']['current_timezone'] = $timezone;
$zone_list = timezone_identifiers_list();
if (!in_array($timezone, $zone_list)) {
$this->logger
->error('Attempting to set timezone for user @uid to @timezone, but that does not appear to be a valid timezone id; aborting.', [
'@uid' => $this->account
->id(),
'@timezone' => $timezone,
]);
unset($_SESSION['timezone_detect']['update_timezone']);
return $response;
}
User::load($this->account
->id())
->set('timezone', $timezone)
->save();
if ($this->configFactory
->get('timezone_detect.settings')
->get('watchdog')) {
$this->logger
->notice('Set timezone for user @uid to @timezone.', [
'@uid' => $this->account
->id(),
'@timezone' => $timezone,
]);
}
}
unset($_SESSION['timezone_detect']['update_timezone']);
return $response;
}
}