我们正在使用 OpenAM(强制 12)及其 ACL 策略决策。我们如何通过 REST API 或 Client SDK 获取资源列表(Uri+verb)?我们使用 SDK 添加了一些补充 REST,我们也可以添加资源列表。
问问题
86 次
1 回答
1
使用以下IP,您可以获得完整的数据
Get - http://youurl/openam/xacml/policies
Header - "iplanetDirectoryPro" = "Token value"
之后,您需要针对“应用程序”过滤“资源”。
function get_resources() {
$resources = array();
if(isset($_SESSION['OpenAmSession']['sso_token']) || !empty($_SESSION['OpenAmSession']['sso_token'])) {
$curl = new Curl();
$curl->setHeader('iPlanetDirectoryPro', $_SESSION['OpenAmSession']['sso_token']);
$curl->setHeader('Content-Type', 'application/json');
$curl->post(OPENAM_BASEURL.'/json/policies?_action=evaluate', array(
'resources' => array("your URL"),
'application' => 'Application Name',
));
if ($curl->error) {
//echo $curl->error_message;
} else {
if(isset($curl->response[0]->attributes->resources)) {
$resources = $curl->response[0]->attributes->resources;
}
}
}
return $resources;
}
于 2017-09-04T18:41:46.863 回答