All Downloads are FREE. Search and download functionalities are using the official Maven repository.

ch.cern.ZKDefaultQuery Maven / Gradle / Ivy

/*
* Copyright © 2020, CERN
* This software is distributed under the terms of the MIT Licence,
* copied verbatim in the file 'LICENSE'. In applying this licence,
* CERN does not waive the privileges and immunities
* granted to it by virtue of its status as an Intergovernmental Organization
* or submit itself to any jurisdiction.
*/
package ch.cern;

import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import org.apache.commons.collections4.CollectionUtils;
import org.apache.commons.collections4.IterableUtils;
import org.apache.zookeeper.data.ACL;
import ch.cern.ZKPolicyDefs.Queries;

/**
 * ZKDefaultQuery Class that provides a basic set of queries for the ZNode tree.
 */
public class ZKDefaultQuery {

  // Define default queries with appropriate names
  public ExactACLDef exactACL = new ExactACLDef();
  public NoACLDef noACL = new NoACLDef();
  public SatisfyACLDef satisfyACL = new SatisfyACLDef();
  public NoSatisfyACLDef noSatisfyACL = new NoSatisfyACLDef();
  public ParentYesChildNoDef parentYesChildNo = new ParentYesChildNoDef();
  public DuplicateACLDef duplicateACL = new DuplicateACLDef();
  public RegexMatchACLDef regexMatchACL = new RegexMatchACLDef();
  public GlobMatchACLDef globMatchACL = new GlobMatchACLDef();
  public GlobMatchPathDef globMatchPath = new GlobMatchPathDef();
  public RegexMatchPathDef regexMatchPath = new RegexMatchPathDef();

  /**
   * Get value of class field using its name.
   * 
   * @param lookingForValue Field name
   * @return Corresponding query
   * @throws NoSuchFieldException
   * @throws SecurityException
   * @throws IllegalArgumentException
   * @throws IllegalAccessException
   */
  public ZKQuery getValueOf(String lookingForValue)
      throws NoSuchFieldException, SecurityException, IllegalArgumentException, IllegalAccessException {
    Field field = this.getClass().getField(lookingForValue);
    return (ZKQuery) field.get(this);
  }

  /**
   * Match znodes with ACL equal to the passed ACL argument.
   */
  private static class ExactACLDef implements ZKQuery {
    public String getDescription(){
      return Queries.EXACT_ACL_DESCRIPTION;
    }

    public boolean query(List aclList, List parentAclList, String path, ZKClient zk, List queryACLs) {
      // If the two provided lists do not have the same length, we are sure that the
      // query should fail
      if (aclList == null || aclList.size() != queryACLs.size()) {
        return false;
      }

      List aclListAugment = ACLAugment.generateACLAugmentList(aclList);

      // Get sublist removing the first argument (name of query)
      List queryACLsSub = queryACLs;
      List queryACLString = new ArrayList();
      for (String queryACL : queryACLsSub) {
        ACLAugment tempACLAugment = new ACLAugment(queryACL);
        queryACLString.add(tempACLAugment);
      }

      if (aclListAugment.containsAll(queryACLString)) {
        return true;
      } else {
        return false;
      }
    }
  }

  /**
   * Match znodes with no access control restrictions (ACL equals [world:anyone:cdrwa]).
   */
  private static class NoACLDef implements ZKQuery {
    public String getDescription(){
      return Queries.NO_ACL_DESCRIPTION;
    }

    public boolean query(List aclList, List parentAclList, String path, ZKClient zk, List queryACLs) {
      for (ACL aclElement : aclList) {
        ACLAugment aclAugment = new ACLAugment(aclElement);
        if (aclAugment.getScheme().equals("world") && aclAugment.getId().equals("anyone") && aclAugment.hasCreate()
            && aclAugment.hasWrite() && aclAugment.hasAdmin() && aclAugment.hasRead() && aclAugment.hasDelete()) {
          return true;
        }
      }
      return false;
    }
  }

  /**
   * Match znodes are accessible by clients with the passed authentication info arguments (logical match).
   */
  private static class SatisfyACLDef implements ZKQuery {
    public String getDescription(){
      return Queries.SATISFY_ACL_DESCRIPTION;
    }

    public boolean query(List aclList, List parentAclList, String path, ZKClient zk, List queryACLs) {
      List aclListAugment = ACLAugment.generateACLAugmentList(aclList);

      // queryACL list
      for (String queryACLString : queryACLs) {
        ACLAugment temp = new ACLAugment(queryACLString);
        if (IterableUtils.contains(aclListAugment, temp, new ACLAugmentSatisfyEquator())) {
          continue;
        } else {
          return false;
        }
      }

      return true;
    }
  }

  /**
   * Match znodes that are not accessible by clients with the passed authentication info arguments.
   */
  private static class NoSatisfyACLDef implements ZKQuery {
    public String getDescription(){
      return Queries.NO_SATISFY_ACL_DESCRIPTION;
    }

    public boolean query(List aclList, List parentAclList, String path, ZKClient zk, List queryACLs) {
      List aclListAugment = ACLAugment.generateACLAugmentList(aclList);

      // queryACL list
      for (String queryACLString : queryACLs) {
        ACLAugment temp = new ACLAugment(queryACLString);
        if (IterableUtils.contains(aclListAugment, temp, new ACLAugmentSatisfyEquator())) {
          continue;
        } else {
          return true;
        }
      }
      return false;
    }
  }
  /**
   * Match znodes with ACL not equal to their parent's ACL.
   */
  private static class ParentYesChildNoDef implements ZKQuery {
    public String getDescription(){
      return Queries.PARENT_YES_CHILD_NO_DESCRIPTION;
    }

    public boolean query(List aclList, List parentAclList, String path, ZKClient zk, List queryACLs) {
      List myACLsAugment = null;
      List parentACLsAugment = null;
      myACLsAugment = ACLAugment.generateACLAugmentList(aclList);
      parentACLsAugment = ACLAugment.generateACLAugmentList(parentAclList);

      if (CollectionUtils.isEqualCollection(myACLsAugment, parentACLsAugment)) {
        return true;
      }
      return false;
    }
  }

  /**
   * Match znodes with duplicate ACL entries.
   */
  private static class DuplicateACLDef implements ZKQuery {
    public String getDescription(){
      return Queries.DUPLICATE_ACL_DESCRIPTION;
    }

    public boolean query(List aclList, List parentAclList, String path, ZKClient zk, List queryACLs) {
      HashSet unique = new HashSet();

      for (ACL aclElement : aclList) {
        ACLAugment aclAugment = new ACLAugment(aclElement);
        if (!unique.add(aclAugment)) {
          return true;
        }
      }
      return false;
    }
  }

  /**
   * Match znodes with ACL entries matching the passed regular expression arguments.
   */
  private static class RegexMatchACLDef implements ZKQuery {
    public String getDescription(){
      return Queries.REGEX_MATCH_ACL_DESCRIPTION;
    }

    public boolean query(List aclList, List parentAclList, String path, ZKClient zk,
        List queryACLRegexList) {
      List queryPatternList = ZKPattern.createRegexPatternList(queryACLRegexList);

      int queryListSentinel = queryPatternList.size();
      for (ACL aclElement : aclList) {
        ACLAugment currentACLAugment = new ACLAugment(aclElement);
        String currentACLString = currentACLAugment.getStringFromACL();

        for (Pattern pattern : queryPatternList) {
          Matcher currentMatcher = pattern.matcher(currentACLString);
          if (currentMatcher.matches()) {
            queryListSentinel--;
          }
          // If all regular expressions where matched, we can return true
          if (queryListSentinel == 0) {
            return true;
          }
        }
      }
      return false;
    }
  }

  /**
   * Match znodes with ACL entries matching the passed glob pattern arguments.
   */
  private static class GlobMatchACLDef implements ZKQuery {
    public String getDescription(){
      return Queries.GLOB_MATCH_ACL_DESCRIPTION;
    }

    public boolean query(List aclList, List parentAclList, String path, ZKClient zk,
        List queryACLGlobList) {
      List queryPatternList = ZKPattern.createGlobPatternList(queryACLGlobList);

      int queryListSentinel = queryPatternList.size();
      for (ACL aclElement : aclList) {
        ACLAugment currentACLAugment = new ACLAugment(aclElement);
        String currentACLString = currentACLAugment.getStringFromACL();

        for (Pattern pattern : queryPatternList) {
          Matcher currentMatcher = pattern.matcher(currentACLString);
          if (currentMatcher.matches()) {
            queryListSentinel--;
          }
          // If all regular expressions where matched, we can return true
          if (queryListSentinel == 0) {
            return true;
          }
        }
      }
      return false;
    }
  }

  /**
   * Match znodes with paths matching the passed glob pattern argument.
   */
  private static class GlobMatchPathDef implements ZKQuery {
    public String getDescription(){
      return Queries.GLOB_MATCH_PATH_DESCRIPTION;
    }

    // We expect only one glob expression to check for path match
    public boolean query(List aclList, List parentAclList, String path, ZKClient zk,
        List queryPathGlobList) {
      List queryPatternList = ZKPattern.createGlobPatternList(queryPathGlobList);

      Matcher pathMatcher = queryPatternList.get(0).matcher(path);
      if (pathMatcher.matches()) {
        return true;
      }
      return false;
    }
  }

  /**
   * Match znodes with paths matching the passed regular expression argument.
   */
  private static class RegexMatchPathDef implements ZKQuery {
    public String getDescription(){
      return Queries.REGEX_MATCH_PATH_DESCRIPTION;
    }

    // We do expect only one glob expression to check for path match
    public boolean query(List aclList, List parentAclList, String path, ZKClient zk,
        List queryPathRegexList) {
      List queryPatternList = ZKPattern.createRegexPatternList(queryPathRegexList);
      Matcher pathMatcher = queryPatternList.get(0).matcher(path);
      if (pathMatcher.matches()) {
        return true;
      }
      return false;
    }
  }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy