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

edu.internet2.middleware.grouperInstaller.GiGrouperVersion Maven / Gradle / Ivy

/*******************************************************************************
 * Copyright 2012 Internet2
 * 
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * 
 *   http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 ******************************************************************************/
/*
 * @author mchyzer
 * $Id: GrouperVersion.java,v 1.9 2009-11-18 17:03:50 mchyzer Exp $
 */
package edu.internet2.middleware.grouperInstaller;

import java.util.HashMap;
import java.util.Map;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

import edu.internet2.middleware.grouperInstaller.util.GrouperInstallerUtils;



/**
 * keep track of which version grouper is.  Update this file (the GROUPER_VERSION constant) before each
 * non-release-candidate release
 */
public class GiGrouperVersion {
  
  /**
   * return the parsed and tostring version of this version string (consistent), 
   * or null if nothing passed in
   * @param versionString
   * @return the version string
   */
  public static String stringValueOrNull(String versionString) {
    if (GrouperInstallerUtils.isBlank(versionString)) {
      return null;
    }
    return valueOfIgnoreCase(versionString, true).toString();
  }
  
  /**
   * @see Object#equals(Object)
   */
  @Override
  public boolean equals(Object obj) {
    if (!(obj instanceof GiGrouperVersion)) {
      return false;
    }
    GiGrouperVersion other = (GiGrouperVersion)obj;
    if (this.build != other.build) {
      return false;
    }
    if (this.major != other.major) {
      return false;
    }
    if (this.minor != other.minor) {
      return false;
    }
    if (!GrouperInstallerUtils.equals(this.rc, other.rc)) {
      return false;
    }
    return true;
  }

  
  
  /**
   * @see java.lang.Object#hashCode()
   */
  @Override
  public int hashCode() {
    
    return ("" + this.major + "" + this.minor + "" + this.build + "" + this.rc).hashCode();
    
  }


  /**
   * 
   * @see java.lang.Object#toString()
   */
  @Override
  public String toString() {
    String result = this.major + "." + this.minor + "." + this.build;
    if (this.rc != null) {
      result+= "rc" + this.rc;
    }
    return result;
  }
  
  /**
   * se we dont have to keep constructing this
   */
  private static GiGrouperVersion currentVersion = null;
  
  /**
   * current grouper version
   * @return current grouper version
   */
  public static GiGrouperVersion currentVersion() {
    if (currentVersion == null) {
      currentVersion = valueOfIgnoreCase(GrouperInstallerUtils.grouperInstallerVersion());
    }
    return currentVersion;
  }
  
  
  /** major number */
  private int major;
  
  /** minor number */
  private int minor;

  /** build number */
  private int build;
  
  /** rc number (release cnadidate) */
  private Integer rc;

  /** keep a map of max size 1000 */
  private static Map versionCache = new HashMap();

  /**
   * convert string to version like an enum would
   * 
   * @param string cannot be blank
   * @return the enum or null or exception if not found
   */
  public static GiGrouperVersion valueOfIgnoreCase(String string) {
    return valueOfIgnoreCase(string, true);
  }

  /**
   * convert string to version like an enum would
   * 
   * @param string
   * @param exceptionOnNull will not allow null or blank entries
   * @return the enum or null or exception if not found
   */
  public static GiGrouperVersion valueOfIgnoreCase(String string, boolean exceptionOnNull) {

    if (GrouperInstallerUtils.isBlank(string)) {
      if (exceptionOnNull) {
        throw new RuntimeException("Not expecting a blank string for version");
      }
      return null;
    }
    
    //see if in cache
    GiGrouperVersion grouperVersion = versionCache.get(string);
    if (grouperVersion != null) {
      return grouperVersion;
    }
    
    grouperVersion = new GiGrouperVersion(string);
    
    //dont cause a memory leak
    if (versionCache.size() < 1000) {
      versionCache.put(string, grouperVersion);
    }
    return grouperVersion;
  }
  
  /**
   * private constructor
   * @param versionString
   */
  public GiGrouperVersion(String versionString) {
    Matcher grouperMatcher = shortPattern.matcher(versionString);
    
    // 1.2
    if (!grouperMatcher.matches()) {
    
      grouperMatcher = pattern.matcher(versionString);
      
      // 1.2.3
      if (!grouperMatcher.matches()) {
        

        grouperMatcher = rcPattern.matcher(versionString);
        
        // 1.2.3rc4
        if (!grouperMatcher.matches()) {
        
        
          throw new RuntimeException("Invalid version: " + versionString
              + ", expecting something like: 1.1 or 1.2.3 or 1.2.3rc4");
        }
        this.rc = GrouperInstallerUtils.intValue(grouperMatcher.group(4));
      }
      this.build = GrouperInstallerUtils.intValue(grouperMatcher.group(3));

    }
    //get the grouper versions
    this.major = GrouperInstallerUtils.intValue(grouperMatcher.group(1));
    this.minor = GrouperInstallerUtils.intValue(grouperMatcher.group(2));

  }
  
  /**
   * see if the grouper version is greater than or equal to a certain version
   * @param version
   * @return true if the grouper version is greater than or equal to a certain version
   */
  public static boolean grouperVersionGreaterOrEqual(String version) {
    return _grouperVersionGreaterOrEqualHelper(currentVersion().toString(), version);
  }
  
  /**
   * see if the grouper version is greater than or equal to a certain version
   * @param version
   * @return true if the grouper version is greater than or equal to a certain version
   */
  public boolean greaterOrEqualToArg(String version) {
    return this.thisGreaterThanArgument(new GiGrouperVersion(version), true);
  }
  
  /**
   * see if this version is less than the argument one
   * @param other
   * @param orEqual 
   * @return true if less than, false if equal or greater
   */
  public boolean lessThanArg(GiGrouperVersion other, boolean orEqual) {
    //switch these around.  if a < b, then b > a
    return other.thisGreaterThanArgument(this, orEqual);
  }

  /**
   * see if this version is less than the argument one, only considering major and minor version
   * @param other
   * @param orEqual 
   * @return true if less than, false if equal or greater
   */
  public boolean lessThanMajorMinorArg(GiGrouperVersion other, boolean orEqual) {
    
    GiGrouperVersion thisMajorMinor = valueOfIgnoreCase(this.major + "." + this.minor + ".0");
    GiGrouperVersion otherMajorMinor = valueOfIgnoreCase(other.major + "." + other.minor + ".0");
    
    return thisMajorMinor.lessThanArg(otherMajorMinor, orEqual);
    
  }

  /**
   * see if this version is less than the argument one
   * @param other
   * @return true if less than, false if equal or greater
   */
  public boolean lessThanArg(GiGrouperVersion other) {
    return this.lessThanArg(other, false);
  }
  
  /**
   * see if the grouper version is greater than or equal to a certain version
   * @param version
   * @return true if the grouper version is greater than or equal to a certain version
   */
  public boolean greaterOrEqualToArg(GiGrouperVersion version) {
    return this.thisGreaterThanArgument(version, true);
  }
  
  /**
   * 
   * start of string, optional v or V, first digit, period or underscore, second digit, period or underscore, third digit, end of string
   * parens are for capturing
   * ^(\\d+)\\.(\\d+)\\.(\\d+)$
   * 
*/ private static Pattern pattern = Pattern.compile("^[vV]?(\\d+)[\\._](\\d+)[\\._](\\d+)$"); /** *
   * start of string, optional v or V, first digit, period or underscore, second digit, period or underscore, third digit, end of string
   * parens are for capturing
   * ^(\\d+)\\.(\\d+)$
   * 
*/ private static Pattern shortPattern = Pattern.compile("^[vV]?(\\d+)[\\._](\\d+)$"); /** *
   * start of string, optional v or V, first digit, period or underscope, second digit, period or underscore, third digit, 
   * period, rc, 4th digit, end of string
   * parens are for capturing
   * ^(\\d+)\\.(\\d+)\\.(\\d+)$
   * 
*/ private static Pattern rcPattern = Pattern.compile("^[vV]?(\\d+)[\\._](\\d+)[\\._](\\d+)\\-?rc(\\d+)$"); /** * helper method for unit testing * @param grouperVersion * @param anotherVersion * @return true if grouper is greater */ public static boolean _grouperVersionGreaterOrEqualHelper(String grouperVersion, String anotherVersion) { GiGrouperVersion grouper = new GiGrouperVersion(grouperVersion); GiGrouperVersion another = new GiGrouperVersion(anotherVersion); //for grouper version to be greater or equal return grouper.thisGreaterThanArgument(another, true); } /** * see if this version is greater than or equal the argument * @param anotherVersion * @param orEqual if true then count equals as a true * @return true if this is less */ private boolean thisGreaterThanArgument(GiGrouperVersion anotherVersion, boolean orEqual) { //compare, first with major, minor, then build if (this.major > anotherVersion.major) { return true; } else if (this.major < anotherVersion.major) { return false; } if (this.minor > anotherVersion.minor) { return true; } else if (this.minor < anotherVersion.minor) { return false; } //note its greater or equal if (this.build > anotherVersion.build) { return true; } else if (this.build < anotherVersion.build) { return false; } if (GrouperInstallerUtils.equals(this.rc, anotherVersion.rc)) { return orEqual; } //not having a release candidate version is higher than having one if (this.rc == null) { return true; } if (anotherVersion.rc == null) { return false; } return this.rc > anotherVersion.rc; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy