经过大量工作尝试在 balana 中安装自定义函数(用于在策略中的应用条件中使用),我想在这里问。基本上什么文档告诉你在 balana 引擎中安装新功能是:1)在配置中插入如下内容:
<functionFactory name="func" useStandardFunctions="true">
<general>
<function class="singlerequestandpolicybalanatester.GpsFunction"/>
</general>
<!-- <target>
<function class="singlerequestandpolicybalanatester.GpsFunction"/>
</target>
<condition>
<function class="singlerequestandpolicybalanatester.GpsFunction"/>
</condition>
-->
</functionFactory>
和offcourse实现那个类
public class GpsFunction extends FunctionBase {
public static final String NAME_GPS = "coolfunctiongps";
public static Set getSupportedIdentifiers() {
Set set = new HashSet();
set.add(NAME_GPS);
return set;
}
public GpsFunction() {
super(NAME_GPS, 0, StringAttribute.identifier, false, 3, 3, BooleanAttribute.identifier, false);
System.out.println(NAME_GPS);
}
@Override
public EvaluationResult evaluate(List inputs, EvaluationCtx context) {
blablabla
确实覆盖 getsupportedidentifiers 它甚至不是必需的,但无论如何..
现在,当 balana 启动时,您会看到您的类已初始化,构造函数被调用。然后,即使在 balana 初始化之后,您也可以执行以下操作:
Set sup = balana.getFunctionGeneralFactory().getSupportedFunctions();
Iterator<String> it = sup.iterator();
System.out.println("General:");
while (it.hasNext()) {
String thisfunc = (String) it.next();
System.out.println(thisfunc);
}
并且您看到您的功能已加载并准备就绪。好的。不,失败。在使用我自己的自定义 balana 核心构建和大量调试消息进行调试后,您可以清楚地看到 Apply 元素在一个策略中解析运行时并且 Apply.getInstance( 它被调用,并且工厂它与您的函数名称一起传递,在那个工厂没有你的函数,所以你得到的只是一个带有“Unknown FunctionId”的异常运行时。我什至尝试手动安装函数工厂,比如:
FunctionFactoryProxy ff = StandardFunctionFactory.getNewFactoryProxy();
// ff.getGeneralFactory().addFunction(new GpsFunction());
balana.setFunctionGeneralFactory(ff.getGeneralFactory());
balana.setFunctionConditionFactory(ff.getConditionFactory());
balana.setFunctionTargetFactory(ff.getTargetFactory());
balana.getFunctionGeneralFactory().addFunction(new GpsFunction());
PDP pdp = new PDP(balana.getPdpConfig());
我再次可以在此代理中看到我的函数,但归根结底,在运行时,当引擎解析
<Rule Effect="Deny" RuleId="itsatrap">
<Target/>
<Condition>
<Apply FunctionId="coolfunctiongps">
<Apply FunctionId="urn:oasis:names:tc:xacml:1.0:function:string-one-and-only">
<AttributeDesignator AttributeId="attributoid" Category="attributocategory" DataType="http://www.w3.org/2001/XMLSchema#string" MustBePresent="true" />
</Apply>
</Apply>
</Condition>
</Rule>
一个例外,它是 trow,Unknow FunctionId。很明显我错过了一些东西,我在问谁能完成内部自定义函数的工作示例并应用元素。谢谢大家。