当前位置: 首页>>代码示例>>PHP>>正文


PHP Authorization::isExplicit方法代码示例

本文整理汇总了PHP中Authorization::isExplicit方法的典型用法代码示例。如果您正苦于以下问题:PHP Authorization::isExplicit方法的具体用法?PHP Authorization::isExplicit怎么用?PHP Authorization::isExplicit使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Authorization的用法示例。


在下文中一共展示了Authorization::isExplicit方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。

示例1: getExplicitUserAZsForImplicitAZ

 /**
  * Given an implicit returns the matching explicit user Authorizations.
  * Explicit Authorizations can be modified.	 A null argument will be
  * treated as a wildcard.
  * 
  * @param object Authorization $implicitAuthorization
  *	
  * @return object AuthorizationIterator
  * 
  * @throws object AuthorizationException An exception with
  *		   one of the following messages defined in
  *		   org.osid.authorization.AuthorizationException may be thrown:
  *		   {@link
  *		   org.osid.authorization.AuthorizationException#OPERATION_FAILED
  *		   OPERATION_FAILED}, {@link
  *		   org.osid.authorization.AuthorizationException#PERMISSION_DENIED
  *		   PERMISSION_DENIED}, {@link
  *		   org.osid.authorization.AuthorizationException#CONFIGURATION_ERROR
  *		   CONFIGURATION_ERROR}, {@link
  *		   org.osid.authorization.AuthorizationException#UNIMPLEMENTED
  *		   UNIMPLEMENTED}, {@link
  *		   org.osid.authorization.AuthorizationException#NULL_ARGUMENT
  *		   NULL_ARGUMENT}, {@link
  *		   org.osid.authorization.AuthorizationException#UNKNOWN_ID
  *		   UNKNOWN_ID}, {@link
  *		   org.osid.authorization.AuthorizationException#UNKNOWN_TYPE
  *		   UNKNOWN_TYPE}
  * 
  * @access public
  */
 function getExplicitUserAZsForImplicitAZ(Authorization $implicitAuthorization)
 {
     if ($implicitAuthorization->isExplicit()) {
         // "The Authorization must be implicit."
         throwError(new Error(AuthorizationExeption::OPERATION_FAILED(), "AuthorizationManager", true));
     }
     $agentId = $implicitAuthorization->getAgentId();
     $function = $implicitAuthorization->getFunction();
     $functionId = $function->getId();
     $qualifier = $implicitAuthorization->getQualifier();
     $qualifierId = $qualifier->getId();
     $authorizations = $this->_cache->getAZs($agentId->getIdString(), $functionId->getIdString(), $qualifierId->getIdString(), null, true, true, $implicitAuthorization->isActiveNow(), $this->_getContainingGroupIdStrings($agentId));
     // isActiveNow
     // Make sure that we are only returning explicit AZs for implicit
     // AZs, not other explicit AZs at this node. This means, only return
     // AZs where the agentId or the qualifier Id are different from those
     // of the implicit AZ
     $explicitForImplicit = array();
     foreach (array_keys($authorizations) as $key) {
         $az = $authorizations[$key];
         $aId = $az->getAgentId();
         $q = $az->getQualifier();
         $qId = $q->getId();
         if ($agentId->isEqual($aId) && $qualifierId->isEqual($qId)) {
             continue;
         } else {
             $explicitForImplicit[] = $az;
         }
     }
     $i = new HarmoniAuthorizationIterator($explicitForImplicit);
     return $i;
 }
开发者ID:adamfranco,项目名称:harmoni,代码行数:62,代码来源:HarmoniAuthorizationManager.class.php

示例2: getExplicitUserAZsForImplicitAZ

 /**
  * Given an implicit returns the matching explicit user Authorizations.
  * Explicit Authorizations can be modified.	 A null argument will be
  * treated as a wildcard.
  * 
  * @param object Authorization $implicitAuthorization
  *	
  * @return object AuthorizationIterator
  * 
  * @throws object AuthorizationException An exception with
  *		   one of the following messages defined in
  *		   org.osid.authorization.AuthorizationException may be thrown:
  *		   {@link
  *		   org.osid.authorization.AuthorizationException#OPERATION_FAILED
  *		   OPERATION_FAILED}, {@link
  *		   org.osid.authorization.AuthorizationException#PERMISSION_DENIED
  *		   PERMISSION_DENIED}, {@link
  *		   org.osid.authorization.AuthorizationException#CONFIGURATION_ERROR
  *		   CONFIGURATION_ERROR}, {@link
  *		   org.osid.authorization.AuthorizationException#UNIMPLEMENTED
  *		   UNIMPLEMENTED}, {@link
  *		   org.osid.authorization.AuthorizationException#NULL_ARGUMENT
  *		   NULL_ARGUMENT}, {@link
  *		   org.osid.authorization.AuthorizationException#UNKNOWN_ID
  *		   UNKNOWN_ID}, {@link
  *		   org.osid.authorization.AuthorizationException#UNKNOWN_TYPE
  *		   UNKNOWN_TYPE}
  * 
  * @access public
  */
 function getExplicitUserAZsForImplicitAZ(Authorization $implicitAuthorization)
 {
     if ($implicitAuthorization->isExplicit()) {
         // "The Authorization must be implicit."
         throwError(new Error(AuthorizationExeption::OPERATION_FAILED(), "AuthorizationManager", true));
     }
     return new HarmoniIterator(array($implicitAuthorization->getExplicitAZ()));
 }
开发者ID:adamfranco,项目名称:harmoni,代码行数:38,代码来源:AuthorizationManager.class.php

示例3: isCascadingUpView

 /**
  * Answer true if the authorization is an implicit view AZ cascading up from
  * a descendent and should hence be ignored when determining roles.
  * 
  * @param object Authorization $az
  * @return boolean
  * @access protected
  * @since 7/11/08
  */
 protected function isCascadingUpView(Authorization $az)
 {
     // We are only interested in implicit AZs
     if ($az->isExplicit()) {
         return false;
     }
     // Return false if not a view AZ
     $authZ = Services::getService("AuthZ");
     $idMgr = Services::getService("Id");
     $viewId = $idMgr->getId('edu.middlebury.authorization.view');
     if (!$az->getFunction()->getId()->isEqual($viewId)) {
         return false;
     }
     // Load a list of descendents
     $qualifierId = $az->getQualifier()->getId();
     if (!isset($this->descendentIds)) {
         $this->descendentIds = array();
     }
     if (!isset($this->descendentIds[$qualifierId->getIdString()])) {
         $descendents = array();
         $descendents = $authZ->getQualifierDescendants($qualifierId);
         $descendentIds = array();
         while ($descendents->hasNext()) {
             $descendentIds[] = $descendents->next()->getId();
         }
         $this->descendentIds[$qualifierId->getIdString()] = $descendentIds;
     }
     // Check the explicit AZ's qualifier against our list of descendents.
     $explicitAZ = $az->getExplicitAZ();
     $explicitQualifierId = $explicitAZ->getQualifier()->getId();
     foreach ($this->descendentIds[$qualifierId->getIdString()] as $id) {
         if ($id->isEqual($explicitQualifierId)) {
             return true;
         }
     }
     return false;
 }
开发者ID:adamfranco,项目名称:segue,代码行数:46,代码来源:SegueRoleManager.class.php


注:本文中的Authorization::isExplicit方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。