本文整理匯總了PHP中Authorization::getAgentId方法的典型用法代碼示例。如果您正苦於以下問題:PHP Authorization::getAgentId方法的具體用法?PHP Authorization::getAgentId怎麽用?PHP Authorization::getAgentId使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類Authorization
的用法示例。
在下文中一共展示了Authorization::getAgentId方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的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;
}
示例2: createImplicitAZ
/**
* Create an implicit AZ at a nodeId for an explicit AZ.
*
* @param object Authorization $explicitAZ
* @param object Id $nodeId
* @return void
* @access protected
* @since 4/21/08
*/
protected function createImplicitAZ(Authorization $explicitAZ, Id $nodeId)
{
if (isset($this->harmoni_db)) {
if (!isset($this->createImplicitAZ_stmt)) {
$query = $this->harmoni_db->insert();
$query->setTable("az2_implicit_az");
$query->addRawValue("fk_explicit_az", "?");
$query->addRawValue("fk_agent", "?");
$query->addRawValue("fk_function", "?");
$query->addRawValue("fk_qualifier", "?");
$query->addRawValue("effective_date", "?");
$query->addRawValue("expiration_date", "?");
$this->createImplicitAZ_stmt = $query->prepare();
}
$this->createImplicitAZ_stmt->bindValue(1, $explicitAZ->getIdString());
$this->createImplicitAZ_stmt->bindValue(2, $explicitAZ->getAgentId()->getIdString());
$this->createImplicitAZ_stmt->bindValue(3, $explicitAZ->getFunction()->getId()->getIdString());
$this->createImplicitAZ_stmt->bindValue(4, $nodeId->getIdString());
$effectiveDate = $explicitAZ->getEffectiveDate();
if (is_null($effectiveDate)) {
$this->createImplicitAZ_stmt->bindValue(5, null);
} else {
$this->createImplicitAZ_stmt->bindValue(5, $effectiveDate->asString());
}
$expirationDate = $explicitAZ->getExpirationDate();
if (is_null($expirationDate)) {
$this->createImplicitAZ_stmt->bindValue(6, null);
} else {
$this->createImplicitAZ_stmt->bindValue(6, $expirationDate->asString());
}
try {
$this->createImplicitAZ_stmt->execute();
} catch (Exception $e) {
printpre($e->getMessage());
printpre("fk_explicit_az => " . $explicitAZ->getIdString() . "\nfk_agent => " . $explicitAZ->getAgentId()->getIdString() . "\nfk_function => " . $explicitAZ->getFunction()->getId()->getIdString() . "\nfk_qualifier => " . $explicitAZ->getAgentId()->getIdString());
printpre(__LINE__);
exit;
}
} else {
// now insert into database
$dbHandler = Services::getService("DatabaseManager");
$query = new InsertQuery();
$query->setTable("az2_implicit_az");
$query->addValue("fk_explicit_az", $explicitAZ->getIdString());
$query->addValue("fk_agent", $explicitAZ->getAgentId()->getIdString());
$query->addValue("fk_function", $explicitAZ->getFunction()->getId()->getIdString());
$query->addValue("fk_qualifier", $nodeId->getIdString());
$effectiveDate = $explicitAZ->getEffectiveDate();
if (is_null($effectiveDate)) {
$query->addRawValue("effective_date", "NULL");
} else {
$query->addValue("effective_date", $effectiveDate->asString());
}
$expirationDate = $explicitAZ->getExpirationDate();
if (is_null($expirationDate)) {
$query->addRawValue("expiration_date", "NULL");
} else {
$query->addValue("expiration_date", $expirationDate->asString());
}
$dbHandler->query($query, $this->_dbIndex);
}
}