⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 eqnode.java

📁 一个完整的XACML工程,学习XACML技术的好例子!
💻 JAVA
字号:
/*
* Copyright (c) 2000-2005, University of Salford
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without 
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice, this 
* list of conditions and the following disclaimer.
* 
* Redistributions in binary form must reproduce the above copyright notice, 
* this list of conditions and the following disclaimer in the documentation 
* and/or other materials provided with the distribution. 
*
* Neither the name of the University of Salford nor the names of its 
* contributors may be used to endorse or promote products derived from this 
* software without specific prior written permission. 
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE 
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 
* POSSIBILITY OF SUCH DAMAGE.
*/

package issrg.pba.rbac.xmlpolicy.ifstatement;

/**
 * This is the class for EQ node of the IF-statement. Its functionality is
 * very much determined by OperationNode and EqInterpreter, which are 
 * configured to deliver the following semantics:
 *
 * <p>This operation expects two and only two Terms of the same type, and 
 * returns a 
 * value of type Types.BOOLEAN_TYPE.
 * The evaluation result is "true", if and only if calling equals() method on
 * the first term returns boolean "true".
 *
 * <p>It is possible to register equality interpreters for specific 
 * combinations of Terms, which will be used in preference to the default 
 * EqInterpreter. Use registerInterpreter method to do that.
 *
 * @see #registerInterpreter
 *
 * @author A.Otenko
 */

public class EqNode extends OperationNode {
  public static final String EQ_NODE = "EQ";

  /**
   * Call this method to register the EqNode with the XMLPolicyParser. It also
   * registers the default EqInterpreter.
   */
  public static void register(){
    try{
      issrg.pba.rbac.xmlpolicy.XMLPolicyParser.registerXMLNode(EQ_NODE, EqNode.class);
    }catch (NoSuchMethodException nsme){
      nsme.printStackTrace();
    }

    registerInterpreter(new EqInterpreter());
  }

  /**
   * This method maintains a register of interpreters for specific combinations
   * of Terms. If no special interpreters are registered, the default one is 
   * used, as described above.
   *
   * @param i - the Interpreter instance that can evaluate equality expression
   *   for some combination of Terms
   */
  public static void registerInterpreter(Interpreter i){
    OperationNode.registerInterpreterForNode(EQ_NODE, i);
  }

  protected EqNode() {
  }

  /**
   * This constructor builds an EqNode given the XMLPolicyParser and the set of
   * attributes of this XML element. It expects that there are two and only two
   * child nodes.
   *
   * @param p - the XMLPolicyParser that builds this EqNode
   * @param attr - the attributes of this XML element
   */
  public EqNode(issrg.pba.rbac.xmlpolicy.XMLPolicyParser p, org.xml.sax.Attributes attrs){
    super(EQ_NODE, attrs, 2, 2);
  }
}


/**
 * This is a default equality interpreter. It can interpret any two terms of 
 * the same type
 * and will return the equality match as the corresponding Java object equals() 
 * method determines; that is, leftHandSideTerm.equals(rightHandSideTerm)
 *
 * @author A.Otenko
 */
class EqInterpreter implements Interpreter {
  public EqInterpreter(){}

  /**
   * This method returns null only if the types of the terms are different or 
   * there is more than
   * two terms.
   */
  public String canEvaluate(Term [] t){
    if (t.length==2){
      if (t[0].getType().intern()==t[1].getType().intern()){
        return Types.BOOLEAN_TYPE;
      }
    }

    return null;
  }

  public Object evaluate(Environment env, Term [] t) throws EvaluationException{
    if (canEvaluate(t)==null){
      throw new EvaluationException("Cannot evaluate expression");
    }

    return new Boolean(t[0].evaluate(env).equals(t[1].evaluate(env)));
  }
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -