mirror of
https://github.com/Combodo/iTop.git
synced 2026-02-23 04:14:12 +01:00
- Add Symfony Form Component - Add Symfony CSRF security component - Add iTop default form template - Add Twig debug extension to Twig Environment - Add iTop abstract controller facility to get form builder - Add Twig filter to make trans an alias of dict_s filter
72 lines
1.9 KiB
PHP
72 lines
1.9 KiB
PHP
<?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\Security\Core\Authentication\Token;
|
|
|
|
use Symfony\Component\Security\Core\Exception\InvalidArgumentException;
|
|
use Symfony\Component\Security\Core\User\UserInterface;
|
|
|
|
/**
|
|
* Authentication Token for "Remember-Me".
|
|
*
|
|
* @author Johannes M. Schmitt <schmittjoh@gmail.com>
|
|
*/
|
|
class RememberMeToken extends AbstractToken
|
|
{
|
|
private string $secret;
|
|
private string $firewallName;
|
|
|
|
/**
|
|
* @param string $secret A secret used to make sure the token is created by the app and not by a malicious client
|
|
*
|
|
* @throws \InvalidArgumentException
|
|
*/
|
|
public function __construct(UserInterface $user, string $firewallName, #[\SensitiveParameter] string $secret)
|
|
{
|
|
parent::__construct($user->getRoles());
|
|
|
|
if (!$secret) {
|
|
throw new InvalidArgumentException('A non-empty secret is required.');
|
|
}
|
|
|
|
if (!$firewallName) {
|
|
throw new InvalidArgumentException('$firewallName must not be empty.');
|
|
}
|
|
|
|
$this->firewallName = $firewallName;
|
|
$this->secret = $secret;
|
|
|
|
$this->setUser($user);
|
|
}
|
|
|
|
public function getFirewallName(): string
|
|
{
|
|
return $this->firewallName;
|
|
}
|
|
|
|
public function getSecret(): string
|
|
{
|
|
return $this->secret;
|
|
}
|
|
|
|
public function __serialize(): array
|
|
{
|
|
return [$this->secret, $this->firewallName, parent::__serialize()];
|
|
}
|
|
|
|
public function __unserialize(array $data): void
|
|
{
|
|
[$this->secret, $this->firewallName, $parentData] = $data;
|
|
$parentData = \is_array($parentData) ? $parentData : unserialize($parentData);
|
|
parent::__unserialize($parentData);
|
|
}
|
|
}
|