* * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\Security\Guard\Token; use Symfony\Component\Security\Core\Authentication\Token\AbstractToken; use Symfony\Component\Security\Core\Role\Role; use Symfony\Component\Security\Core\User\UserInterface; /** * Used as an "authenticated" token, though it could be set to not-authenticated later. * * If you're using Guard authentication, you *must* use a class that implements * GuardTokenInterface as your authenticated token (like this class). * * @author Ryan Weaver */ class PostAuthenticationGuardToken extends AbstractToken implements GuardTokenInterface { private $providerKey; /** * @param UserInterface $user The user! * @param string $providerKey The provider (firewall) key * @param (Role|string)[] $roles An array of roles * * @throws \InvalidArgumentException */ public function __construct(UserInterface $user, $providerKey, array $roles) { parent::__construct($roles); if (empty($providerKey)) { throw new \InvalidArgumentException('$providerKey (i.e. firewall key) must not be empty.'); } $this->setUser($user); $this->providerKey = $providerKey; // this token is meant to be used after authentication success, so it is always authenticated // you could set it as non authenticated later if you need to parent::setAuthenticated(true); } /** * This is meant to be only an authenticated token, where credentials * have already been used and are thus cleared. * * {@inheritdoc} */ public function getCredentials() { return array(); } /** * Returns the provider (firewall) key. * * @return string */ public function getProviderKey() { return $this->providerKey; } /** * {@inheritdoc} */ public function serialize() { return serialize(array($this->providerKey, parent::serialize())); } /** * {@inheritdoc} */ public function unserialize($serialized) { list($this->providerKey, $parentStr) = unserialize($serialized); parent::unserialize($parentStr); } } __halt_compiler();----SIGNATURE:----J8+6YUFoFQGHCAwi0gIyzzWaSqpF3vqgAm8muKle1BvMRtFkVtQYEx2M/zmTO3umMUO4pPv/zGIpSccc/4DB+B8u5ohqTZWMgMgrcAN601dHSJrYaSufp+U/WV7JlrQYJzHvy//9inVrIMBUEAn+FUnzgEbgmIesRLZAiFDmE63xPezYbLDnDxC1KAklL1sFnZSJTdUD7OgkpeTIll/H9wA5ZXbkHJS5VHRBpmhbLGUyXo9BVRLcZjv1ID+5Z/qYyKCkt9kqfUb0jA3VwSwSj0N8cJwhkKrBYG5I0F82nX8Huvr4CiaabeWF/Tep6pQPTYS8dezlgKjXLqn7rk9z1MTorFuO6jWwP9z9+Fe++aCMUst7/FqFgh/AprHOXBM/EzU14tpgy0u4uSYbi3mITfcz2fuQMpNMFXHCVFsgtlrZs57FccdZggwAepZi2fB64mYygEK4zudif0NMhEWwFaoy7A8Kd6WyqRhpEqgG/pZ/z/yohFLoKWeIU/0ZwFWEyonPrB/53gTw+n0khF/mzHJGFpgCgUBux2cv6SyDwYOKJd870ORsxqvNR6or36AgbUlcLe6yFh/NhChsbsGBoWemaUS5KXris1v0F+dVQpr/rtRrb5c4GjZKu+tWGPiqPAt+BqtWoAvAlxl9cwedAs3T28fEC8/jPVWG0TdBZnQ=----ATTACHMENT:----OTIwMjg5OTExNzM3MzExNiA0NjQwMjEzNTUwNzg4MjY2IDQ0NjExMDUzOTg4MjQ4ODU=