* * 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:----CE5h0Mgh7/L3Bbx7G5Y8l2gJWT3vj4GMDAMOsJxk/c6Hr+6A5OEFfOqt+P0EcTeiTOFtmgpfWeU/hr99HwNQ5SJ10vJ+QsqFyjk2K+PH3QFy7PNIsizbTW5r259C/alrcxkttkwi87Ae3ZbrtiQvAxWzEhweje1Ozzaa14rnhu2DWn3T81YShWJ8AqGF/WAPUgpTmKhjCCHaV/NzcsCCoj2ybMMjXbaZQAclQRw/KjhT4P+twjtAv+OR7aocz1cjIHaBsLfJI7oNowxQgi/wP68S+9an5jw5uWBozeZMiQWc0Ldy+dl/d8dL4kEVdQxWMZAC2Nsl5qTyeGeZnUXhlQqHZSdcf46SxeeDfE0duFfgD6HsO6I9uNwdu3N5rU0i5ESBDnAvMLrS6i6KokfvjzzbXbpaohFif4sn8YcpPiX1q2gx83GthcsA6Bq9fhrVOLw2InYDwAuUzlYCE/wLJyTPsQDVslTsKY6861fnGIOV3NVaNeTyNtvP/N3vV0eDAjUiBSxPAgXKzvWCfHaZ3a1Dh2vYhYhV6fxXjtPNJj2giwtPZ5sP4LnMjTYk8oCh6BoODPZOArx1oY82cerKQiysTZSfP9mm7USdMSwM5bcNDkqu1AmrDX37wBrCTbd99tvSINF4uYKE5JBL1dCPAhVnwOZZBCS8QAaOLVkCNSg=----ATTACHMENT:----NTk5NjI5MDI4NTUyNzcyMyA4MTc3NjI2MjcwODE4Mjk4IDQ3NzY5OTUwOTIxNDEyMDA=