當前位置: 首頁>>代碼示例>>PHP>>正文


PHP UserSecurityIdentity::fromToken方法代碼示例

本文整理匯總了PHP中Symfony\Component\Security\Acl\Domain\UserSecurityIdentity::fromToken方法的典型用法代碼示例。如果您正苦於以下問題:PHP UserSecurityIdentity::fromToken方法的具體用法?PHP UserSecurityIdentity::fromToken怎麽用?PHP UserSecurityIdentity::fromToken使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Symfony\Component\Security\Acl\Domain\UserSecurityIdentity的用法示例。


在下文中一共展示了UserSecurityIdentity::fromToken方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: getSecurityIdentities

 /**
  * {@inheritDoc}
  */
 public function getSecurityIdentities(TokenInterface $token)
 {
     $sids = array();
     // add user security identity
     if (!$token instanceof AnonymousToken) {
         try {
             $sids[] = UserSecurityIdentity::fromToken($token);
         } catch (\InvalidArgumentException $invalid) {
             // ignore, user has no user security identity
         }
     }
     // add all reachable roles
     foreach ($this->roleHierarchy->getReachableRoles($token->getRoles()) as $role) {
         $sids[] = new RoleSecurityIdentity($role);
     }
     // add built-in special roles
     if ($this->authenticationTrustResolver->isFullFledged($token)) {
         $sids[] = new RoleSecurityIdentity(AuthenticatedVoter::IS_AUTHENTICATED_FULLY);
         $sids[] = new RoleSecurityIdentity(AuthenticatedVoter::IS_AUTHENTICATED_REMEMBERED);
         $sids[] = new RoleSecurityIdentity(AuthenticatedVoter::IS_AUTHENTICATED_ANONYMOUSLY);
     } else {
         if ($this->authenticationTrustResolver->isRememberMe($token)) {
             $sids[] = new RoleSecurityIdentity(AuthenticatedVoter::IS_AUTHENTICATED_REMEMBERED);
             $sids[] = new RoleSecurityIdentity(AuthenticatedVoter::IS_AUTHENTICATED_ANONYMOUSLY);
         } else {
             if ($this->authenticationTrustResolver->isAnonymous($token)) {
                 $sids[] = new RoleSecurityIdentity(AuthenticatedVoter::IS_AUTHENTICATED_ANONYMOUSLY);
             }
         }
     }
     return $sids;
 }
開發者ID:robertowest,項目名稱:CuteFlow-V4,代碼行數:35,代碼來源:SecurityIdentityRetrievalStrategy.php

示例2: getCompareData

 public function getCompareData()
 {
     $account = $this->getMockBuilder('Symfony\\Component\\Security\\Core\\User\\UserInterface')->setMockClassName('USI_AccountImpl')->getMock();
     $account->expects($this->any())->method('getUsername')->will($this->returnValue('foo'));
     $token = $this->getMock('Symfony\\Component\\Security\\Core\\Authentication\\Token\\TokenInterface');
     $token->expects($this->any())->method('getUser')->will($this->returnValue($account));
     return array(array(new UserSecurityIdentity('foo', 'Foo'), new UserSecurityIdentity('foo', 'Foo'), true), array(new UserSecurityIdentity('foo', 'Bar'), new UserSecurityIdentity('foo', 'Foo'), false), array(new UserSecurityIdentity('foo', 'Foo'), new UserSecurityIdentity('bar', 'Foo'), false), array(new UserSecurityIdentity('foo', 'Foo'), UserSecurityIdentity::fromAccount($account), false), array(new UserSecurityIdentity('bla', 'Foo'), new UserSecurityIdentity('blub', 'Foo'), false), array(new UserSecurityIdentity('foo', 'Foo'), new RoleSecurityIdentity('foo'), false), array(new UserSecurityIdentity('foo', 'Foo'), UserSecurityIdentity::fromToken($token), false), array(new UserSecurityIdentity('foo', 'USI_AccountImpl'), UserSecurityIdentity::fromToken($token), true));
 }
開發者ID:richardmiller,項目名稱:symfony,代碼行數:8,代碼來源:UserSecurityIdentityTest.php

示例3: __construct

 public function __construct($uid = null, $token = null)
 {
     $this->_uid = is_null($uid) ? md5(uniqid('', true)) : $uid;
     $this->_created_at = new \DateTime();
     if ($token instanceof TokenInterface) {
         $this->_owner = UserSecurityIdentity::fromToken($token);
     }
 }
開發者ID:nietzcheson,項目名稱:BackBee,代碼行數:8,代碼來源:AdminLog.php

示例4: getSid

 /**
  * Constructs SID (an object implements SecurityIdentityInterface) based on the given identity
  *
  * @param string|RoleInterface|UserInterface|TokenInterface $identity
  * @throws \InvalidArgumentException
  * @return SID
  */
 public function getSid($identity)
 {
     if (is_string($identity)) {
         return new RoleSecurityIdentity($identity);
     } elseif ($identity instanceof RoleInterface) {
         return new RoleSecurityIdentity($identity->getRole());
     } elseif ($identity instanceof UserInterface) {
         return UserSecurityIdentity::fromAccount($identity);
     } elseif ($identity instanceof TokenInterface) {
         return UserSecurityIdentity::fromToken($identity);
     }
     throw new \InvalidArgumentException(sprintf('$identity must be a string or implement one of RoleInterface, UserInterface, TokenInterface' . ' (%s given)', is_object($identity) ? get_class($identity) : gettype($identity)));
 }
開發者ID:abdeldayem,項目名稱:pim-community-dev,代碼行數:20,代碼來源:AbstractAclManager.php

示例5: getSecurityIdentities

 /**
  * {@inheritdoc}
  */
 public function getSecurityIdentities(Token\TokenInterface $token)
 {
     $sids = array();
     // add user security identity
     if (!$token instanceof Token\AnonymousToken) {
         try {
             $sids[] = UserSecurityIdentity::fromToken($token);
         } catch (\InvalidArgumentException $invalid) {
             // ignore, user has no user security identity
         }
     }
     // add all reachable roles
     foreach ($this->roleHierarchy->getReachableRoles($token->getRoles()) as $role) {
         $sids[] = new RoleSecurityIdentity($role);
     }
     // add journal roles
     $user = $token->getUser();
     try {
         $selectedJournal = $this->journalService->getSelectedJournal();
     } catch (\Exception $e) {
         $selectedJournal = false;
     }
     if ($user instanceof User && $selectedJournal instanceof Journal) {
         foreach ($user->getJournalRoles($selectedJournal) as $journalRoles) {
             $sids[] = new JournalRoleSecurityIdentity($journalRoles[0], $journalRoles[1]);
         }
     }
     // add built-in special roles
     if ($this->authenticationTrustResolver->isFullFledged($token)) {
         $sids[] = new RoleSecurityIdentity(AuthenticatedVoter::IS_AUTHENTICATED_FULLY);
         $sids[] = new RoleSecurityIdentity(AuthenticatedVoter::IS_AUTHENTICATED_REMEMBERED);
         $sids[] = new RoleSecurityIdentity(AuthenticatedVoter::IS_AUTHENTICATED_ANONYMOUSLY);
     } elseif ($this->authenticationTrustResolver->isRememberMe($token)) {
         $sids[] = new RoleSecurityIdentity(AuthenticatedVoter::IS_AUTHENTICATED_REMEMBERED);
         $sids[] = new RoleSecurityIdentity(AuthenticatedVoter::IS_AUTHENTICATED_ANONYMOUSLY);
     } elseif ($this->authenticationTrustResolver->isAnonymous($token)) {
         $sids[] = new RoleSecurityIdentity(AuthenticatedVoter::IS_AUTHENTICATED_ANONYMOUSLY);
     }
     return $sids;
 }
開發者ID:hasantayyar,項目名稱:ojs,代碼行數:43,代碼來源:SecurityIdentityRetrievalStrategy.php

示例6: newPostAction

 /**
  * @PreAuthorize("isAuthenticated()")
  */
 public function newPostAction()
 {
     if (!($title = $this->request->request->get('title'))) {
         throw new HttpException(400);
     }
     $this->em->getConnection()->beginTransaction();
     try {
         $post = new Post($title);
         $this->em->persist($post);
         $this->em->flush();
         $oid = ObjectIdentity::fromDomainObject($post);
         $acl = $this->getAclProvider()->createAcl($oid);
         $sid = UserSecurityIdentity::fromToken($this->tokenStorage->getToken());
         $acl->insertObjectAce($sid, MaskBuilder::MASK_OWNER);
         $this->getAclProvider()->updateAcl($acl);
         $this->em->getConnection()->commit();
         return new Response('', 201, array('Location' => $this->router->generate('post_controller_edit', array('id' => $post->getId()))));
     } catch (\Exception $ex) {
         $this->em->getConnection()->rollBack();
         $this->em->close();
         throw $ex;
     }
 }
開發者ID:jmcclell,項目名稱:JMSSecurityExtraBundle,代碼行數:26,代碼來源:PostController.php

示例7: getAllDrafts

 /**
  * Returns all current drafts for authenticated user.
  *
  * @param TokenInterface $token
  *
  * @return array
  */
 public function getAllDrafts(TokenInterface $token)
 {
     $owner = UserSecurityIdentity::fromToken($token);
     $states = [Revision::STATE_ADDED, Revision::STATE_MODIFIED];
     $result = [];
     try {
         $result = $this->findBy(['_owner' => $owner, '_state' => $states]);
     } catch (ConversionException $e) {
         $result = [];
         foreach ($this->getAllDraftsUids($owner, $states) as $data) {
             try {
                 $result[] = $this->find($data['_uid']);
             } catch (ConversionException $e) {
                 $this->_em->getConnection()->executeUpdate('DELETE FROM revision WHERE uid = :uid', ['uid' => $data['_uid']]);
             }
         }
     } catch (MappingException $e) {
         $result = [];
         foreach ($this->getAllDraftsUids($owner, $states) as $data) {
             $draft = $this->find($data['_uid']);
             if (null !== $draft->getContent()) {
                 $result[] = $draft;
             } else {
                 $this->_em->getConnection()->executeUpdate('DELETE FROM revision WHERE uid = :uid', ['uid' => $data['_uid']]);
             }
         }
     }
     return $result;
 }
開發者ID:gobjila,項目名稱:BackBee,代碼行數:36,代碼來源:RevisionRepository.php

示例8: doCreateSecurityIdentity

 /**
  * Creates a new object instanceof SecurityIdentityInterface from input implementing one of UserInterface, TokenInterface or RoleInterface (or its string representation)
  * @param mixed $identity
  * @throws InvalidIdentityException
  * @return SecurityIdentityInterface
  */
 protected function doCreateSecurityIdentity($identity)
 {
     if (!$identity instanceof UserInterface && !$identity instanceof TokenInterface && !$identity instanceof RoleInterface && !is_string($identity)) {
         throw new \InvalidArgumentException(sprintf('$identity must implement one of: UserInterface, TokenInterface, RoleInterface (%s given)', get_class($identity)));
     }
     $securityIdentity = null;
     if ($identity instanceof UserInterface) {
         $securityIdentity = UserSecurityIdentity::fromAccount($identity);
     } else {
         if ($identity instanceof TokenInterface) {
             $securityIdentity = UserSecurityIdentity::fromToken($identity);
         } else {
             if ($identity instanceof RoleInterface || is_string($identity)) {
                 $securityIdentity = new RoleSecurityIdentity($identity);
             }
         }
     }
     if (!$securityIdentity instanceof SecurityIdentityInterface) {
         throw new \InvalidArgumentException('Couldn\'t create a valid SecurityIdentity with the provided identity information');
     }
     return $securityIdentity;
 }
開發者ID:Hristo3web,項目名稱:ProblematicAclManagerBundle,代碼行數:28,代碼來源:AbstractAclManager.php

示例9: getUserSecurityIdentity

 /**
  * {@inheritdoc}
  */
 public function getUserSecurityIdentity(UserInterface $user = null)
 {
     return null === $user ? UserSecurityIdentity::fromToken($this->tokenStorage->getToken()) : UserSecurityIdentity::fromAccount($user);
 }
開發者ID:dragosprotung,項目名稱:AclBundle,代碼行數:7,代碼來源:AclIdentifier.php

示例10: getAllDrafts

 /**
  * Returns all current drafts for authenticated user.
  *
  * @param TokenInterface $token
  *
  * @return array
  */
 public function getAllDrafts(TokenInterface $token)
 {
     $owner = UserSecurityIdentity::fromToken($token);
     $states = [Revision::STATE_ADDED, Revision::STATE_MODIFIED];
     $result = [];
     try {
         $result = $this->findBy(['_owner' => $owner, '_state' => $states]);
     } catch (ConversionException $e) {
         $qb = $this->createQueryBuilder('r');
         $uids = $qb->select('r._uid')->where('r._owner = :owner')->setParameter('owner', $owner)->andWhere($qb->expr()->in('r._state', $states))->getQuery()->getResult();
         $result = [];
         foreach ($uids as $data) {
             try {
                 $result[] = $this->find($data['_uid']);
             } catch (ConversionException $e) {
                 $this->_em->getConnection()->executeUpdate('DELETE FROM revision WHERE uid = :uid', ['uid' => $data['_uid']]);
             }
         }
     }
     return $result;
 }
開發者ID:quentin-boulard,項目名稱:BackBee,代碼行數:28,代碼來源:RevisionRepository.php

示例11: getAllDrafts

 /**
  * Returns all current drafts for authenticated user.
  *
  * @param TokenInterface $token
  */
 public function getAllDrafts(TokenInterface $token)
 {
     return $this->_em->getRepository('BackBee\\ClassContent\\Revision')->findBy(['_owner' => UserSecurityIdentity::fromToken($token), '_state' => [Revision::STATE_ADDED, Revision::STATE_MODIFIED]]);
 }
開發者ID:nietzcheson,項目名稱:BackBee,代碼行數:9,代碼來源:RevisionRepository.php

示例12: setOptions

 /**
  * Sets options at the construction of a new revision.
  *
  * @param mixed $options
  *
  * @return \BackBee\ClassContent\AContent
  * @return \BackBee\ClassContent\AbstractClassContent
  */
 protected function setOptions($options = null)
 {
     if ($options instanceof TokenInterface) {
         $this->_owner = UserSecurityIdentity::fromToken($options);
     }
     return $this;
 }
開發者ID:Bensid,項目名稱:BackBee,代碼行數:15,代碼來源:Revision.php

示例13: getAllDrafts

 /**
  * Returns all current drafts for authenticated user.
  *
  * @param TokenInterface $token
  *
  * @return array
  */
 public function getAllDrafts(TokenInterface $token)
 {
     return $this->findBy(['_owner' => UserSecurityIdentity::fromToken($token), '_state' => [Revision::STATE_ADDED, Revision::STATE_MODIFIED]]);
 }
開發者ID:mickaelsteinberg,項目名稱:BackBee,代碼行數:11,代碼來源:RevisionRepository.php

示例14: getSecurityEntity

 /**
  * getSecurityEntity
  *
  * @param  mixed                     $identityObject
  * @access private
  * @return SecurityIdentityInterface
  */
 private function getSecurityEntity($identityObject)
 {
     if ($identityObject instanceof UserInterface) {
         return UserSecurityIdentity::fromAccount($identityObject);
     } elseif ($identityObject instanceof TokenInterface) {
         return UserSecurityIdentity::fromToken($identityObject);
     } elseif ($identityObject instanceof RoleInterface) {
         return new RoleSecurityIdentity($identityObject->getRole());
     }
     return null;
 }
開發者ID:badaz,項目名稱:OneupAclBundle,代碼行數:18,代碼來源:AclProvider.php

示例15: getSecurityIdentity

 /**
  *
  * @param type $identity
  * @return SecurityIdentityInterface
  * @throws \InvalidArgumentException 
  */
 protected function getSecurityIdentity($identity)
 {
     $securityIdentity = null;
     if ($identity instanceof UserInterface) {
         $securityIdentity = UserSecurityIdentity::fromAccount($identity);
     } else {
         if ($identity instanceof TokenInterface) {
             $securityIdentity = UserSecurityIdentity::fromToken($identity);
         } else {
             if ($identity instanceof RoleInterface || is_string($identity)) {
                 $securityIdentity = new RoleSecurityIdentity($identity);
             }
         }
     }
     if (!$securityIdentity instanceof SecurityIdentityInterface) {
         throw new \Exception('Couldn\'t create a valid SecurityIdentity with the provided identity information');
     }
     return $securityIdentity;
 }
開發者ID:netmeansnet,項目名稱:NmnAclBundle,代碼行數:25,代碼來源:AclManager.php


注:本文中的Symfony\Component\Security\Acl\Domain\UserSecurityIdentity::fromToken方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。