mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-06-30 18:15:39 +00:00
42933: ALF-15328 could we add a sample log4j file in 'extension'? 42935: ALF-16455: Merged V3.4-BUG-FIX (3.4.12) to V4.1-BUG-FIX (4.1.2) 42934: ALF-16454 TransformerDebug id values have gaps 42955: ALF-15328 could we add a sample log4j file in 'extension'? - missing j in file name 42982: Merged DEV to V4.1-BUG-FIX 42873: ALF-16194: Checkout/Checkin leaves Lockable aspect on which disables autoVersionOnUpdateProps DoNothingCopyBehaviourCallback policy has been set for lockable aspect (implemented in LockServiceImpl); Unit test has been added. 43000: Merged BRANCHES/DEV/BELARUS/V4.1-BUG-FIX-2012_10_19 to BRANCHES/DEV/V4.1-BUG-FIX: 42936: ALF-11573: It's impossible to Modify settings for document versions 43010: ALF-16006 MT: Document Library is absent after upgrade from 3.4.x to 4.1.x (eg. 3.4.10 -> 4.1.1) - applied patch suggested in JIRA 43017: ALF-16457: "CmisObjectNotFoundException: No corresponding type found! Not a CMIS object?" thrown by AlfrescoCmisServiceImpl.getChildren - Check CMISNodeInfo for invalid type before processing. 43019: ALF-14353: Upgrade Activiti dependencies in Maven build 43022: ALF-14353: Upgrade Activiti dependencies in Maven build 43027: Merged DEV to V4.1-BUG-FIX 42426: ALF-15577: " does not support the method HEAD " when opening a MS Access file with "View In Browser" 43029: Merged DEV to 4.1-BUG-FIX (4.1.2) 42988: ALF-15791: Custom Types,Aspects defined with prefix using underscore cannot be loaded by API calls like api/classes/<type or aspect> Identical logic for old and new ClassDef API was moved to abstract super classes 42924: ALF-15791: Custom Types,Aspects defined with prefix using underscore cannot be loaded by API calls like api/classes/<type or aspect> New set of URL templates for class defenitions were provided to support requests with separated namespace prefixes and names 43031: ALF-16489: Typo in column-name of newly created index 43041: Merged DEV to 4.1-BUG-FIX (4.1.2) 43040: ALF-16425: API call to return all classes, returns wrong properties in classes Propertydefs and assocdefs are reordered to corelate with classdefs. Unit test was added for issue. 43052: ALF-16194: Checkout/Checkin leaves Lockable aspect on which disables autoVersionOnUpdateProps - Fix failing test 43055: Probable fix for ALF-15813. Replaced the 'skipCount' with the one in the query request, rather than query result. The Lucene query result does not support the reporting of the skipCount. 43065: Merged V3.4-BUG-FIX to V4.1-BUG-FIX 42958: ALF-14421: Inconsistencies when applying Versionable Aspect - We think the most preferable fix that will result in the best consistency between Share and old Explorer behaviour is to make the adding of the versionable aspect always result in an initial MAJOR version, if a version type has not been specified. Major/minor versions can still be controlled explicitly by checkout/checkin the versionable aspect properties and the version service API. 42998: ALF-14421: Fixed version label unit test fallout - back to what it used to be. 42999: Fix for ALF-16261 - IE script error occurs when email space users providing there are no users in this space 43006: Removed dependency on Apache Commons StringUtils. See ALF-12541, ALF-14254, AMZNSSS-17 43028: ALF-14722: Merged V4.1-BUG-FIX to V3.4-BUG-FIX 42902: Merged DEV to V4.1-BUG-FIX 42519: ALF-13588: Google Doc failed to authenticate after incorrect password being entered for google account Add ability to unregister class behaviours. Unregister googledocs behaviours when subsystem stops. 43066: ALF-16502: Merged PATCHES/V4.0.2 to V4.1-BUG-FIX 42969: Merged DEV to PATCHES/V4.0.2 42967: MNT-158: SharePoint Protocol Opening Documents in Read-Only for Site Consumer with Collaborator Privileges Remove manual throwing of AccessDeniedException is user has "consumer" or "contributor" role. Create "links" container from system user. 43067: Merged PATCHES/V4.1.1 to V4.1-BUG-FIX 42470: ALF-16503 / ALF-16256: Upgrade 3.4.6 HF to 4.1.1 - DuplicateChildNodeNameException: Duplicate child name not allowed: surf-config 42591: ALF-16504 / ALF-16332: Fixed synchronization around org.alfresco.repo.dictionary.NamespaceDAOImpl.namespaceRegistryCache - There was no 'double checking' after releasing the write lock, meaning that under high concurrency lots of threads would queue up to continuously re-initialize the registry. 42705: ALF-16504/ ALF-16332, ALF-16377: Revisited synchronization and initialization of mutually-dependent DictionaryDAO and NamespaceDAO to prevent deadlock and simultaneous re-initialization in more than one thread 43068: Merged DEV to V4.1-BUG-FIX - TODO: Update DB2 DDL in activiti 42388: ALF-15828: DB2: unexpected index found in database. Modify activity create script for db2 to create normal name for ACT_HI_PROCINST.PROC_INST_ID_ index. Introduce patch that will rename autogenerated name to normal name for ACT_HI_PROCINST.PROC_INST_ID_ index. Update schema reference file for DB2. 42429: ALF-15828: DB2: unexpected index found in database. Fix scripts from ALF-14983 and ALF-16038 to drop/recreate tables in DB2. 43069: ALF-11214: IMAP subsystem is not successfully restarted after incorrect modification of IMAP properties via Admin Console Stopped ChildApplicationContextFactory from caching a stale application context that didn't successfully refresh. 43071: ALF-13660: When using kerberos SSO, non domain explorer users requesting a download URL get a login page but after login do not get the requested document - Now the Web Client authentication filters use the same mechanism for preserving the request URL through a redirect to the login page 43076: ALF-15828: Fixed merge issue 43079: ALF-13602: Incorrect number of documents displayed in Share DocLib when a file is checked out - added ability for FileFolderService.list (-> FileFolder GetChildren CQ) to filter by one or more aspects, eg. cm:checkedOut 43080: ALF-14421: More version label unit test fallout 43092: Fix ALF-16460: Users may receive activity feed entries (from people they follow) for moderated sites to which they do not belong - also add unit test 43093: Fix for ALF-16091 - Unable to inline edit javascript file. 43096: Fix for ALF-16283 - When document is checked out, 'Edit Online' and 'Upload New Version' options should not be visible on the original document. git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@43103 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
614 lines
20 KiB
Java
614 lines
20 KiB
Java
/*
|
|
* Copyright (C) 2005-2010 Alfresco Software Limited.
|
|
*
|
|
* This file is part of Alfresco
|
|
*
|
|
* Alfresco is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Lesser General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* Alfresco is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
package org.alfresco.repo.module;
|
|
|
|
import java.util.ArrayList;
|
|
import java.util.Date;
|
|
import java.util.List;
|
|
import java.util.Map;
|
|
import java.util.Properties;
|
|
import java.util.StringTokenizer;
|
|
|
|
import org.alfresco.error.AlfrescoRuntimeException;
|
|
import org.alfresco.service.cmr.module.ModuleDependency;
|
|
import org.alfresco.service.cmr.module.ModuleDetails;
|
|
import org.alfresco.service.cmr.module.ModuleInstallState;
|
|
import org.springframework.extensions.surf.util.ISO8601DateFormat;
|
|
import org.alfresco.util.Pair;
|
|
import org.alfresco.util.VersionNumber;
|
|
|
|
/**
|
|
* Module details implementation.
|
|
*
|
|
* Loads details from the serialized properties file provided.
|
|
*
|
|
* @author Roy Wetherall
|
|
*/
|
|
/**
|
|
* @author Derek Hulley
|
|
*/
|
|
public class ModuleDetailsImpl implements ModuleDetails
|
|
{
|
|
private static final long serialVersionUID = 5782747774317351424L;
|
|
|
|
private String id;
|
|
private List<String> aliases;
|
|
private VersionNumber version;
|
|
private String title;
|
|
private String description;
|
|
private List<String> editions;
|
|
private VersionNumber repoVersionMin;
|
|
private VersionNumber repoVersionMax;
|
|
private List<ModuleDependency> dependencies;
|
|
private Date installDate;
|
|
private ModuleInstallState installState;
|
|
|
|
/**
|
|
* Private constructor to set default values.
|
|
*/
|
|
private ModuleDetailsImpl()
|
|
{
|
|
aliases = new ArrayList<String>(0);
|
|
repoVersionMin = VersionNumber.VERSION_ZERO;
|
|
repoVersionMax = VersionNumber.VERSION_BIG;
|
|
dependencies = new ArrayList<ModuleDependency>(0);
|
|
this.installState = ModuleInstallState.UNKNOWN;
|
|
}
|
|
|
|
/**
|
|
* Creates the instance from a set of properties. All the property values are trimmed
|
|
* and empty string values are removed from the set. In other words, zero length or
|
|
* whitespace strings are not supported.
|
|
*
|
|
* @param properties the set of properties
|
|
*/
|
|
public ModuleDetailsImpl(Properties properties)
|
|
{
|
|
// Set defaults
|
|
this();
|
|
// Copy the properties so they don't get modified
|
|
Properties trimmedProperties = new Properties();
|
|
// Trim all the property values
|
|
for (Map.Entry entry : properties.entrySet())
|
|
{
|
|
String key = (String) entry.getKey();
|
|
String value = (String) entry.getValue();
|
|
if (value == null)
|
|
{
|
|
// Don't copy nulls over
|
|
continue;
|
|
}
|
|
String trimmedValue = value.trim();
|
|
if (trimmedValue.length() == 0)
|
|
{
|
|
// Don't copy empty strings over
|
|
continue;
|
|
}
|
|
// It is a real value
|
|
trimmedProperties.setProperty(key, trimmedValue);
|
|
}
|
|
|
|
// Check that the required properties are present
|
|
List<String> missingProperties = new ArrayList<String>(1);
|
|
// ID
|
|
id = trimmedProperties.getProperty(PROP_ID);
|
|
if (id == null)
|
|
{
|
|
missingProperties.add(PROP_ID);
|
|
}
|
|
// ALIASES
|
|
String aliasesStr = trimmedProperties.getProperty(PROP_ALIASES);
|
|
if (aliasesStr != null)
|
|
{
|
|
StringTokenizer st = new StringTokenizer(aliasesStr, ",");
|
|
while (st.hasMoreTokens())
|
|
{
|
|
String alias = st.nextToken().trim();
|
|
if (alias.length() == 0)
|
|
{
|
|
continue;
|
|
}
|
|
aliases.add(alias);
|
|
}
|
|
}
|
|
// VERSION
|
|
if (trimmedProperties.getProperty(PROP_VERSION) == null)
|
|
{
|
|
missingProperties.add(PROP_VERSION);
|
|
}
|
|
else
|
|
{
|
|
version = new VersionNumber(trimmedProperties.getProperty(PROP_VERSION));
|
|
}
|
|
// TITLE
|
|
title = trimmedProperties.getProperty(PROP_TITLE);
|
|
if (title == null) { missingProperties.add(PROP_TITLE); }
|
|
// DESCRIPTION
|
|
description = trimmedProperties.getProperty(PROP_DESCRIPTION);
|
|
if (description == null) { missingProperties.add(PROP_DESCRIPTION); }
|
|
// REPO MIN
|
|
if (trimmedProperties.getProperty(PROP_REPO_VERSION_MIN) != null)
|
|
{
|
|
repoVersionMin = new VersionNumber(trimmedProperties.getProperty(PROP_REPO_VERSION_MIN));
|
|
}
|
|
// REPO MAX
|
|
if (trimmedProperties.getProperty(PROP_REPO_VERSION_MAX) != null)
|
|
{
|
|
repoVersionMax = new VersionNumber(trimmedProperties.getProperty(PROP_REPO_VERSION_MAX));
|
|
}
|
|
// DEPENDENCIES
|
|
this.dependencies = extractDependencies(trimmedProperties);
|
|
|
|
this.editions = extractEditions(trimmedProperties);
|
|
|
|
// INSTALL DATE
|
|
if (trimmedProperties.getProperty(PROP_INSTALL_DATE) != null)
|
|
{
|
|
String installDateStr = trimmedProperties.getProperty(PROP_INSTALL_DATE);
|
|
try
|
|
{
|
|
installDate = ISO8601DateFormat.parse(installDateStr);
|
|
}
|
|
catch (Throwable e)
|
|
{
|
|
throw new AlfrescoRuntimeException("Unable to parse install date: " + installDateStr, e);
|
|
}
|
|
}
|
|
// INSTALL STATE
|
|
if (trimmedProperties.getProperty(PROP_INSTALL_STATE) != null)
|
|
{
|
|
String installStateStr = trimmedProperties.getProperty(PROP_INSTALL_STATE);
|
|
try
|
|
{
|
|
installState = ModuleInstallState.valueOf(installStateStr);
|
|
}
|
|
catch (Throwable e)
|
|
{
|
|
throw new AlfrescoRuntimeException("Unable to parse install state: " + installStateStr, e);
|
|
}
|
|
}
|
|
// Check
|
|
if (missingProperties.size() > 0)
|
|
{
|
|
throw new AlfrescoRuntimeException("The following module properties need to be defined: " + missingProperties);
|
|
}
|
|
if (repoVersionMax.compareTo(repoVersionMin) < 0)
|
|
{
|
|
throw new AlfrescoRuntimeException("The max repo version must be greater than the min repo version:\n" +
|
|
" ID: " + id + "\n" +
|
|
" Min repo version: " + repoVersionMin + "\n" +
|
|
" Max repo version: " + repoVersionMax);
|
|
}
|
|
if (id.matches(INVALID_ID_REGEX))
|
|
{
|
|
throw new AlfrescoRuntimeException(
|
|
"The module ID '" + id + "' is invalid. It may consist of valid characters, numbers, '.', '_' and '-'");
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @param id module id
|
|
* @param versionNumber version number
|
|
* @param title title
|
|
* @param description description
|
|
*/
|
|
public ModuleDetailsImpl(String id, VersionNumber versionNumber, String title, String description)
|
|
{
|
|
// Set defaults
|
|
this();
|
|
|
|
this.id = id;
|
|
this.version = versionNumber;
|
|
this.title = title;
|
|
this.description = description;
|
|
}
|
|
|
|
private static List<String> extractEditions(Properties trimmedProperties)
|
|
{
|
|
List<String> specifiedEditions = null;
|
|
String editions = trimmedProperties.getProperty(PROP_EDITIONS);
|
|
if (editions != null)
|
|
{
|
|
specifiedEditions = new ArrayList<String>();
|
|
StringTokenizer st = new StringTokenizer(editions, ",");
|
|
while (st.hasMoreTokens())
|
|
{
|
|
specifiedEditions.add(st.nextToken());
|
|
}
|
|
}
|
|
return specifiedEditions;
|
|
}
|
|
|
|
private static List<ModuleDependency> extractDependencies(Properties properties)
|
|
{
|
|
int prefixLength = PROP_DEPENDS_PREFIX.length();
|
|
|
|
List<ModuleDependency> dependencies = new ArrayList<ModuleDependency>(2);
|
|
for (Map.Entry entry : properties.entrySet())
|
|
{
|
|
String key = (String) entry.getKey();
|
|
String value = (String) entry.getValue();
|
|
if (!key.startsWith(PROP_DEPENDS_PREFIX))
|
|
{
|
|
continue;
|
|
}
|
|
if (key.length() == prefixLength)
|
|
{
|
|
// Just ignore it
|
|
continue;
|
|
}
|
|
String dependencyId = key.substring(prefixLength);
|
|
// Build the dependency
|
|
ModuleDependency dependency = new ModuleDependencyImpl(dependencyId, value);
|
|
// Add it
|
|
dependencies.add(dependency);
|
|
}
|
|
// Done
|
|
return dependencies;
|
|
}
|
|
|
|
public Properties getProperties()
|
|
{
|
|
Properties properties = new Properties();
|
|
// Mandatory properties
|
|
properties.setProperty(PROP_ID, id);
|
|
properties.setProperty(PROP_VERSION, version.toString());
|
|
properties.setProperty(PROP_TITLE, title);
|
|
properties.setProperty(PROP_DESCRIPTION, description);
|
|
// Optional properites
|
|
if (repoVersionMin != null)
|
|
{
|
|
properties.setProperty(PROP_REPO_VERSION_MIN, repoVersionMin.toString());
|
|
}
|
|
if (repoVersionMax != null)
|
|
{
|
|
properties.setProperty(PROP_REPO_VERSION_MAX, repoVersionMax.toString());
|
|
}
|
|
if (editions != null)
|
|
{
|
|
properties.setProperty(PROP_EDITIONS, join(editions.toArray(new String[editions.size()]), ','));
|
|
}
|
|
if (dependencies.size() > 0)
|
|
{
|
|
for (ModuleDependency dependency : dependencies)
|
|
{
|
|
String key = PROP_DEPENDS_PREFIX + dependency.getDependencyId();
|
|
String value = dependency.getVersionString();
|
|
properties.setProperty(key, value);
|
|
}
|
|
}
|
|
if (installDate != null)
|
|
{
|
|
String installDateStr = ISO8601DateFormat.format(installDate);
|
|
properties.setProperty(PROP_INSTALL_DATE, installDateStr);
|
|
}
|
|
if (installState != null)
|
|
{
|
|
String installStateStr = installState.toString();
|
|
properties.setProperty(PROP_INSTALL_STATE, installStateStr);
|
|
}
|
|
if (aliases.size() > 0)
|
|
{
|
|
StringBuilder sb = new StringBuilder();
|
|
boolean first = true;
|
|
for (String oldId : aliases)
|
|
{
|
|
if (!first)
|
|
{
|
|
sb.append(", ");
|
|
}
|
|
sb.append(oldId);
|
|
first = false;
|
|
}
|
|
properties.setProperty(PROP_ALIASES, sb.toString());
|
|
}
|
|
// Done
|
|
return properties;
|
|
}
|
|
|
|
@Override
|
|
public String toString()
|
|
{
|
|
return "ModuleDetails[" + getProperties() + "]";
|
|
}
|
|
|
|
public String getId()
|
|
{
|
|
return id;
|
|
}
|
|
|
|
public List<String> getAliases()
|
|
{
|
|
return aliases;
|
|
}
|
|
|
|
public VersionNumber getVersion()
|
|
{
|
|
return version;
|
|
}
|
|
|
|
public String getTitle()
|
|
{
|
|
return title;
|
|
}
|
|
|
|
public String getDescription()
|
|
{
|
|
return description;
|
|
}
|
|
|
|
public VersionNumber getRepoVersionMin()
|
|
{
|
|
return repoVersionMin;
|
|
}
|
|
|
|
public void setRepoVersionMin(VersionNumber repoVersionMin)
|
|
{
|
|
this.repoVersionMin = repoVersionMin;
|
|
}
|
|
|
|
public VersionNumber getRepoVersionMax()
|
|
{
|
|
return repoVersionMax;
|
|
}
|
|
|
|
public void setRepoVersionMax(VersionNumber repoVersionMax)
|
|
{
|
|
this.repoVersionMax = repoVersionMax;
|
|
}
|
|
|
|
public List<ModuleDependency> getDependencies()
|
|
{
|
|
return dependencies;
|
|
}
|
|
|
|
public Date getInstallDate()
|
|
{
|
|
return installDate;
|
|
}
|
|
|
|
public void setInstallDate(Date installDate)
|
|
{
|
|
this.installDate = installDate;
|
|
}
|
|
|
|
public ModuleInstallState getInstallState()
|
|
{
|
|
return installState;
|
|
}
|
|
|
|
public void setInstallState(ModuleInstallState installState)
|
|
{
|
|
this.installState = installState;
|
|
}
|
|
|
|
public List<String> getEditions()
|
|
{
|
|
return editions;
|
|
}
|
|
|
|
public void setEditions(List<String> editions)
|
|
{
|
|
this.editions = editions;
|
|
}
|
|
|
|
/**
|
|
* Grateful received from Apache Commons StringUtils class
|
|
*
|
|
*/
|
|
private static String join(Object[] array, char separator) {
|
|
if (array == null) {
|
|
return null;
|
|
}
|
|
return join(array, separator, 0, array.length);
|
|
}
|
|
|
|
/**
|
|
* Grateful received from Apache Commons StringUtils class
|
|
*
|
|
* @param array
|
|
* @param separator
|
|
* @param startIndex
|
|
* @param endIndex
|
|
* @return
|
|
*/
|
|
private static String join(Object[] array, char separator, int startIndex, int endIndex) {
|
|
if (array == null) {
|
|
return null;
|
|
}
|
|
int bufSize = (endIndex - startIndex);
|
|
if (bufSize <= 0) {
|
|
return "";
|
|
}
|
|
|
|
bufSize *= ((array[startIndex] == null ? 16 : array[startIndex].toString().length()) + 1);
|
|
StringBuffer buf = new StringBuffer(bufSize);
|
|
|
|
for (int i = startIndex; i < endIndex; i++) {
|
|
if (i > startIndex) {
|
|
buf.append(separator);
|
|
}
|
|
if (array[i] != null) {
|
|
buf.append(array[i]);
|
|
}
|
|
}
|
|
return buf.toString();
|
|
}
|
|
|
|
/**
|
|
* @author Derek Hulley
|
|
*/
|
|
public static final class ModuleDependencyImpl implements ModuleDependency
|
|
{
|
|
private static final long serialVersionUID = -6850832632316987487L;
|
|
|
|
private String dependencyId;
|
|
private String versionStr;
|
|
private List<Pair<VersionNumber, VersionNumber>> versionRanges;
|
|
|
|
private ModuleDependencyImpl(String dependencyId, String versionStr)
|
|
{
|
|
this.dependencyId = dependencyId;
|
|
this.versionStr = versionStr;
|
|
try
|
|
{
|
|
versionRanges = buildVersionRanges(versionStr);
|
|
}
|
|
catch (Throwable e)
|
|
{
|
|
throw new AlfrescoRuntimeException("Unable to interpret the module version ranges: " + versionStr, e);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public String toString()
|
|
{
|
|
StringBuilder sb = new StringBuilder();
|
|
sb.append(dependencyId).append(":").append(versionStr);
|
|
return sb.toString();
|
|
}
|
|
|
|
private static List<Pair<VersionNumber, VersionNumber>> buildVersionRanges(String versionStr)
|
|
{
|
|
List<Pair<VersionNumber, VersionNumber>> versionRanges = new ArrayList<Pair<VersionNumber, VersionNumber>>(1);
|
|
StringTokenizer rangesTokenizer = new StringTokenizer(versionStr, ",");
|
|
while (rangesTokenizer.hasMoreTokens())
|
|
{
|
|
String range = rangesTokenizer.nextToken().trim();
|
|
// Handle the * special case
|
|
if (range.equals("*"))
|
|
{
|
|
range = "*-*";
|
|
}
|
|
if (range.startsWith("-"))
|
|
{
|
|
range = "*" + range;
|
|
}
|
|
if (range.endsWith("-"))
|
|
{
|
|
range = range + "*";
|
|
}
|
|
// The range must have at least one version in it
|
|
StringTokenizer rangeTokenizer = new StringTokenizer(range, "-", false);
|
|
VersionNumber versionLower = null;
|
|
VersionNumber versionUpper = null;
|
|
while (rangeTokenizer.hasMoreTokens())
|
|
{
|
|
String version = rangeTokenizer.nextToken();
|
|
version = version.trim();
|
|
if (versionLower == null)
|
|
{
|
|
if (version.equals("*"))
|
|
{
|
|
// Unbounded lower version
|
|
versionLower = VersionNumber.VERSION_ZERO;
|
|
}
|
|
else
|
|
{
|
|
// Explicit lower bound
|
|
versionLower = new VersionNumber(version);
|
|
}
|
|
}
|
|
else if (versionUpper == null)
|
|
{
|
|
if (version.equals("*"))
|
|
{
|
|
// Unbounded upper version
|
|
versionUpper = VersionNumber.VERSION_BIG;
|
|
}
|
|
else
|
|
{
|
|
// Explicit upper bound
|
|
versionUpper = new VersionNumber(version);
|
|
}
|
|
}
|
|
}
|
|
// Check
|
|
if (versionUpper == null && versionLower == null)
|
|
{
|
|
throw new AlfrescoRuntimeException(
|
|
"Valid dependency version ranges are: \n" +
|
|
" LOW - HIGH \n" +
|
|
" * - HIGH \n" +
|
|
" LOW - * \n" +
|
|
" * ");
|
|
}
|
|
else if (versionUpper == null && versionLower != null)
|
|
{
|
|
versionUpper = versionLower;
|
|
}
|
|
else if (versionLower == null && versionUpper != null)
|
|
{
|
|
versionLower = versionUpper;
|
|
}
|
|
// Create the range pair
|
|
Pair<VersionNumber, VersionNumber> rangePair = new Pair<VersionNumber, VersionNumber>(versionLower, versionUpper);
|
|
versionRanges.add(rangePair);
|
|
}
|
|
return versionRanges;
|
|
}
|
|
|
|
public String getDependencyId()
|
|
{
|
|
return dependencyId;
|
|
}
|
|
|
|
public String getVersionString()
|
|
{
|
|
return versionStr;
|
|
}
|
|
|
|
public boolean isValidDependency(ModuleDetails moduleDetails)
|
|
{
|
|
// Nothing to compare to
|
|
if (moduleDetails == null)
|
|
{
|
|
return false;
|
|
}
|
|
// Check the ID
|
|
if (!moduleDetails.getId().equals(dependencyId))
|
|
{
|
|
return false;
|
|
}
|
|
// Check the version number
|
|
VersionNumber checkVersion = moduleDetails.getVersion();
|
|
boolean matched = false;
|
|
for (Pair<VersionNumber, VersionNumber> versionRange : versionRanges)
|
|
{
|
|
VersionNumber versionLower = versionRange.getFirst();
|
|
VersionNumber versionUpper = versionRange.getSecond();
|
|
if (checkVersion.compareTo(versionLower) < 0)
|
|
{
|
|
// The version is too low
|
|
continue;
|
|
}
|
|
if (checkVersion.compareTo(versionUpper) > 0)
|
|
{
|
|
// The version is too high
|
|
continue;
|
|
}
|
|
// It is a match
|
|
matched = true;
|
|
break;
|
|
}
|
|
return matched;
|
|
}
|
|
}
|
|
}
|