mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-06-30 18:15:39 +00:00
33935: ALF-12854: SOLR - requires more detailed tracking information - Part 1: info reported for the SOLR SUMMARY action 33936: ALF-11693: Treat logging.properties the same way as log4j.properties and excluded it from the core .jar 33945: ALF-12867: RIP jmx-dumper.jar 33946: Fix minor issue introduced in r33920 33947: IT-6847 "Error displays on recent 4.0 TS upgrade while navigate to a document details page" - errors spotted on folder details & in document library list also resolved by this fix 33951: ALF-12867: Fixed typo 33955: Some unit tests and examples on how to implement file wiping or shredding - One API change: On EagerContentStoreCleaner, the following is now protected: protected boolean deleteFromStore(String contentUrl, ContentStore store) - Examples in unit test ContentStoreCleanerTest: testForcedImmediateShredding and testShreddingCleanup 33962: RIP hyperic plugin 33965: ALF-12697: Asynchronously get RSS items for dashlets on page load 33969: Fix for ALF-12307 Solr backup fills the disk - number to Keep can be set by property/subsystem/Share admin - set default backup localtion 33970: Fix for ALF-12854 SOLR - requires more detailed tracking information Part 2: basic stats added to JMX and improved statistical moment calculation 33984: Update 4.0.1 installers to use Tomcat 6.0.35 - Remembered to set useHttpOnly on <Context> - Also commented out JreMemoryLeakPreventionListener 33988: ALF-12717 CIFS: Unfriendly message occurs when a user with consumer/contributor role tries to rename space. 33997: ALF-12697: Remove async WebScript from dashlet family 33999: Fix for ALF-12854 SOLR - requires more detailed tracking information - Final part - Expose via share admin 34005: Fix for ALF-12708 34007: Merged V3.4-BUG-FIX (3.4.9) to 3.4-BUG-FIX (4.0.1) 34006: Merged V3.4 (3.4.8) to V3.4-BUG-FIX (3.4.9) 34002: ALF-12898: MMT does not calculate the current version number correctly and does not report errors - ModuleManagementTool was constructing the wrong current war file version number. The minor and revision values were the wrong way around. 3.4.8 became 3.8.4 - Modified unit test to use the actual version number in the test war 4.1.0 rather than 4.0.1 - Modified the ModuleManagementTool so that problems would be reported to the user even if they did not have -verbose set 34016: Update version.revision for 4.0.1 34022: Merged V3.4-BUG-FIX to V4.0-BUG-FIX 33952: ALF-5680: It is possible to cut/paste a locked file 34003: Merged DEV to V3.4-BUG-FIX 34001: ALF-12709: CLONE - Run action Wizard. Can't run action. Fixed regression connected with separator of AVM path in .NodeRef. id that has been changed from .;. to .|. 34023: Merged V3.4-BUG-FIX to V4.0-BUG-FIX (RECORD ONLY) 33912: ALF-9899: Merged HEAD to V3.4-BUG-FIX (PARTIAL) 31912: Merged DEV to HEAD 31823: TransactionalCache provides REPEATABLE READ - Values found in shared cache are placed into transactional cache - Previously, values could keep changing until first write (READ COMMITTED) but now the first read sets the value until it is changed by the current transaction 33981: Updated version.revision for 3.4.9 33985: ALF-12364: Merged V4.0-BUG-FIX to V3.4-BUG-FIX 33984: Update 3.4.9 installers to use Tomcat 6.0.35 - Remembered to set useHttpOnly on <Context> - Also commented out JreMemoryLeakPreventionListener git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@34024 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
190 lines
7.2 KiB
Java
190 lines
7.2 KiB
Java
package org.alfresco.repo.module.tool;
|
|
|
|
import java.io.File;
|
|
import java.io.IOException;
|
|
import java.io.InputStream;
|
|
import java.util.ArrayList;
|
|
import java.util.List;
|
|
import java.util.Properties;
|
|
|
|
import org.alfresco.repo.module.ModuleDetailsImpl;
|
|
import org.alfresco.service.cmr.module.ModuleDependency;
|
|
import org.alfresco.service.cmr.module.ModuleDetails;
|
|
import org.alfresco.util.VersionNumber;
|
|
|
|
import de.schlichtherle.io.FileInputStream;
|
|
|
|
/**
|
|
* Performs logic for the Module Management Tool.
|
|
*
|
|
* @author Gethin James
|
|
*/
|
|
public class WarHelperImpl implements WarHelper
|
|
{
|
|
|
|
public static final String VERSION_PROPERTIES = "/WEB-INF/classes/alfresco/version.properties";
|
|
private LogOutput log = null;
|
|
|
|
|
|
public WarHelperImpl(LogOutput log)
|
|
{
|
|
super();
|
|
this.log = log;
|
|
}
|
|
|
|
@Override
|
|
public void checkCompatibleVersion(File war, ModuleDetails installingModuleDetails)
|
|
{
|
|
//Version check
|
|
File propsFile = getFile(war, VERSION_PROPERTIES);
|
|
if (propsFile != null && propsFile.exists())
|
|
{
|
|
Properties warVers = loadProperties(propsFile);
|
|
VersionNumber warVersion = new VersionNumber(warVers.getProperty("version.major")+"."+warVers.getProperty("version.minor")+"."+warVers.getProperty("version.revision"));
|
|
if(warVersion.compareTo(installingModuleDetails.getRepoVersionMin())==-1) {
|
|
throw new ModuleManagementToolException("The module ("+installingModuleDetails.getTitle()+") must be installed on a repo version greater than "+installingModuleDetails.getRepoVersionMin());
|
|
}
|
|
if(warVersion.compareTo(installingModuleDetails.getRepoVersionMax())==1) {
|
|
throw new ModuleManagementToolException("The module ("+installingModuleDetails.getTitle()+") cannot be installed on a repo version greater than "+installingModuleDetails.getRepoVersionMax());
|
|
}
|
|
}
|
|
else
|
|
{
|
|
log.info("No valid version found, is this a share war?");
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public void checkCompatibleEdition(File war, ModuleDetails installingModuleDetails)
|
|
{
|
|
|
|
List<String> installableEditions = installingModuleDetails.getEditions();
|
|
|
|
if (installableEditions != null && installableEditions.size() > 0) {
|
|
|
|
File propsFile = getFile(war, VERSION_PROPERTIES);
|
|
if (propsFile != null && propsFile.exists())
|
|
{
|
|
Properties warVers = loadProperties(propsFile);
|
|
String warEdition = warVers.getProperty("version.edition");
|
|
|
|
for (String edition : installableEditions)
|
|
{
|
|
if (warEdition.equalsIgnoreCase(edition))
|
|
{
|
|
return; //successful match.
|
|
}
|
|
}
|
|
throw new ModuleManagementToolException("The module ("+installingModuleDetails.getTitle()
|
|
+") can only be installed in one of the following editions"+installableEditions);
|
|
} else {
|
|
log.info("No valid editions found, is this a share war?");
|
|
}
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public void checkModuleDependencies(File war, ModuleDetails installingModuleDetails)
|
|
{
|
|
// Check that the target war has the necessary dependencies for this install
|
|
List<ModuleDependency> installingModuleDependencies = installingModuleDetails.getDependencies();
|
|
List<ModuleDependency> missingDependencies = new ArrayList<ModuleDependency>(0);
|
|
for (ModuleDependency dependency : installingModuleDependencies)
|
|
{
|
|
String dependencyId = dependency.getDependencyId();
|
|
ModuleDetails dependencyModuleDetails = getModuleDetails(war, dependencyId);
|
|
// Check the dependency. The API specifies that a null returns false, so no null check is required
|
|
if (!dependency.isValidDependency(dependencyModuleDetails))
|
|
{
|
|
missingDependencies.add(dependency);
|
|
continue;
|
|
}
|
|
}
|
|
if (missingDependencies.size() > 0)
|
|
{
|
|
throw new ModuleManagementToolException("The following modules must first be installed: " + missingDependencies);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public ModuleDetails getModuleDetailsOrAlias(File war, ModuleDetails installingModuleDetails)
|
|
{
|
|
ModuleDetails installedModuleDetails = getModuleDetails(war, installingModuleDetails.getId());
|
|
if (installedModuleDetails == null)
|
|
{
|
|
// It might be there as one of the aliases
|
|
List<String> installingAliases = installingModuleDetails.getAliases();
|
|
for (String installingAlias : installingAliases)
|
|
{
|
|
ModuleDetails installedAliasModuleDetails = getModuleDetails(war, installingAlias);
|
|
if (installedAliasModuleDetails == null)
|
|
{
|
|
// There is nothing by that alias
|
|
continue;
|
|
}
|
|
// We found an alias and will treat it as the same module
|
|
installedModuleDetails = installedAliasModuleDetails;
|
|
//outputMessage("Module '" + installingAlias + "' is installed and is an alias of '" + installingModuleDetails + "'", false);
|
|
break;
|
|
}
|
|
}
|
|
return installedModuleDetails;
|
|
}
|
|
|
|
/**
|
|
* Gets the module details for the specified module from the war.
|
|
* @param war a valid war file or exploded directory from a war
|
|
* @param moduleId
|
|
* @return
|
|
*/
|
|
protected ModuleDetails getModuleDetails(File war, String moduleId)
|
|
{
|
|
ModuleDetails moduleDets = null;
|
|
File theFile = getModuleDetailsFile(war, moduleId);
|
|
if (theFile != null && theFile.exists())
|
|
{
|
|
moduleDets = new ModuleDetailsImpl(loadProperties(theFile));
|
|
}
|
|
return moduleDets;
|
|
}
|
|
|
|
/**
|
|
* Reads a .properites file from the war and returns it as a Properties object
|
|
* @param propertiesPath Path to the properties file (including .properties)
|
|
* @return Properties object or null
|
|
*/
|
|
private Properties loadProperties(File propertiesFile)
|
|
{
|
|
Properties result = null;
|
|
try
|
|
{
|
|
if (propertiesFile.exists())
|
|
{
|
|
InputStream is = new FileInputStream(propertiesFile);
|
|
result = new Properties();
|
|
result.load(is);
|
|
}
|
|
}
|
|
catch (IOException exception)
|
|
{
|
|
throw new ModuleManagementToolException("Unable to load properties from the war file; "+propertiesFile.getPath(), exception);
|
|
}
|
|
return result;
|
|
|
|
}
|
|
|
|
private File getModuleDetailsFile(File war, String moduleId)
|
|
{
|
|
return getFile(war,MODULE_NAMESPACE_DIR+ "/" + moduleId+MODULE_CONFIG_IN_WAR);
|
|
}
|
|
|
|
private File getFile(File war, String pathToFileIncludingExtension)
|
|
{
|
|
return new de.schlichtherle.io.File(war,pathToFileIncludingExtension, ModuleManagementTool.DETECTOR_AMP_AND_WAR);
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|