|
|
@ -33,6 +33,7 @@ public class SimpleEvaluationPoint implements PolicyEvaluationPoint {
|
|
|
|
//TODO : to revove the stale reference
|
|
|
|
//TODO : to revove the stale reference
|
|
|
|
private PolicyManagerService policyManagerService;
|
|
|
|
private PolicyManagerService policyManagerService;
|
|
|
|
private List<Policy> policyList;
|
|
|
|
private List<Policy> policyList;
|
|
|
|
|
|
|
|
PIPDevice pipDevice;
|
|
|
|
// public SimpleEvaluationPoint() {
|
|
|
|
// public SimpleEvaluationPoint() {
|
|
|
|
// policyManagerService = PolicyDecisionPointDataHolder.getInstance().getPolicyManagerService();
|
|
|
|
// policyManagerService = PolicyDecisionPointDataHolder.getInstance().getPolicyManagerService();
|
|
|
|
// }
|
|
|
|
// }
|
|
|
@ -73,15 +74,26 @@ public class SimpleEvaluationPoint implements PolicyEvaluationPoint {
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
|
public Policy getEffectivePolicy(DeviceIdentifier deviceIdentifier) throws PolicyEvaluationException {
|
|
|
|
public Policy getEffectivePolicy(DeviceIdentifier deviceIdentifier) throws PolicyEvaluationException {
|
|
|
|
|
|
|
|
|
|
|
|
if (policyManagerService == null || policyList.size() == 0) {
|
|
|
|
try {
|
|
|
|
return null;
|
|
|
|
policyManagerService = getPolicyManagerService();
|
|
|
|
}
|
|
|
|
PolicyInformationPoint policyInformationPoint = policyManagerService.getPIP();
|
|
|
|
|
|
|
|
pipDevice = policyInformationPoint.getDeviceData(deviceIdentifier);
|
|
|
|
|
|
|
|
policyList = policyInformationPoint.getRelatedPolicies(pipDevice);
|
|
|
|
|
|
|
|
|
|
|
|
Policy policy = new Policy();
|
|
|
|
if (policyManagerService == null || policyList.size() == 0) {
|
|
|
|
Profile profile = new Profile();
|
|
|
|
return null;
|
|
|
|
profile.setProfileFeaturesList(getEffectiveFeatures(deviceIdentifier));
|
|
|
|
}
|
|
|
|
policy.setProfile(profile);
|
|
|
|
|
|
|
|
return policy;
|
|
|
|
Policy policy = new Policy();
|
|
|
|
|
|
|
|
Profile profile = new Profile();
|
|
|
|
|
|
|
|
profile.setProfileFeaturesList(getEffectiveFeatures(deviceIdentifier));
|
|
|
|
|
|
|
|
policy.setProfile(profile);
|
|
|
|
|
|
|
|
return policy;
|
|
|
|
|
|
|
|
} catch (PolicyManagementException e) {
|
|
|
|
|
|
|
|
String msg = "Error occurred when retrieving the policy related data from policy management service.";
|
|
|
|
|
|
|
|
log.error(msg, e);
|
|
|
|
|
|
|
|
throw new PolicyEvaluationException(msg, e);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private Policy policyResolve(List<Policy> policyList) throws PolicyEvaluationException, PolicyManagementException {
|
|
|
|
private Policy policyResolve(List<Policy> policyList) throws PolicyEvaluationException, PolicyManagementException {
|
|
|
|