mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-06-16 17:55:15 +00:00
8371: Merged V2.1 to V2.2 8307: Next round of fixes for session management. 8309: Fixed AR-1891: Long MLText strings fail in Oracle 8313: Fix for case where existing MLText entry is null 8319: Follow-up fix for NPE where StringValue is null when persisting 8331: Fix for AR-1696: Long text in an aspect property causes an exception git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@8496 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
136 lines
5.6 KiB
Java
136 lines
5.6 KiB
Java
/*-----------------------------------------------------------------------------
|
|
* Copyright 2006 Alfresco Inc.
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License
|
|
* as published by the Free Software Foundation; either version 2
|
|
* of the License, or (at your option) any later version.
|
|
|
|
* This program 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 General Public License for more details.
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
* As a special exception to the terms and conditions of version 2.0 of
|
|
* the GPL, you may redistribute this Program in connection with Free/Libre
|
|
* and Open Source Software ("FLOSS") applications as described in Alfresco's
|
|
* FLOSS exception. You should have recieved a copy of the text describing
|
|
* the FLOSS exception, and it is also available here:
|
|
* http://www.alfresco.com/legal/licensing"
|
|
*----------------------------------------------------------------------------*/
|
|
package org.alfresco.util;
|
|
|
|
import java.util.HashMap;
|
|
import java.util.Map;
|
|
|
|
import org.apache.commons.logging.Log;
|
|
import org.apache.commons.logging.LogFactory;
|
|
import org.springframework.beans.BeansException;
|
|
import org.springframework.beans.factory.config.BeanFactoryPostProcessor;
|
|
import org.springframework.beans.factory.config.ConfigurableListableBeanFactory;
|
|
import org.springframework.core.Ordered;
|
|
|
|
/**
|
|
* Sets runtime JVM system properties for Spring Framework.
|
|
* <p>
|
|
* This class is used by the Spring framework to inject system properties into
|
|
* the runtime environment (e.g.: alfresco.jmx.dir). The motivation for this
|
|
* is that certain values must be set within spring must be computed in advance
|
|
* for org.springframework.beans.factory.config.PropertyPlaceholderConfigurer
|
|
* to work properly.
|
|
*
|
|
* @author Jon Cox
|
|
* @see #setProperties(Map)
|
|
*/
|
|
public class RuntimeSystemPropertiesSetter implements BeanFactoryPostProcessor, Ordered
|
|
{
|
|
private static Log logger = LogFactory.getLog(RuntimeSystemPropertiesSetter.class );
|
|
|
|
/** default: just before PropertyPlaceholderConfigurer */
|
|
private int order = Integer.MAX_VALUE - 1;
|
|
|
|
/**
|
|
* @see #setProperties(Map)
|
|
*/
|
|
private Map<String, String> jvmProperties;
|
|
|
|
public RuntimeSystemPropertiesSetter()
|
|
{
|
|
jvmProperties = new HashMap<String, String>(7);
|
|
}
|
|
|
|
/**
|
|
* Set the properties that will get pushed into the JVM system properties.
|
|
* This will be akin to running the JVM with the <b>-Dprop=value</b>. Existing system JVM properties
|
|
* <i>will not be overwritten</i>.
|
|
*
|
|
* @param jvmProperties properties to set if they are not already present in the VM
|
|
*/
|
|
public void setJvmProperties(Map<String, String> jvmProperties)
|
|
{
|
|
this.jvmProperties = jvmProperties;
|
|
}
|
|
|
|
public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException
|
|
{
|
|
// Push any mapped properties into the JVM
|
|
for (Map.Entry<String, String> entry : jvmProperties.entrySet())
|
|
{
|
|
String key = entry.getKey();
|
|
String value = entry.getValue();
|
|
// Push into VM
|
|
String currentValue = System.getProperty(key);
|
|
if (currentValue == null)
|
|
{
|
|
System.setProperty(key, value);
|
|
if (logger.isDebugEnabled())
|
|
{
|
|
logger.debug("Setting system property: " + key + " = " + value);
|
|
}
|
|
}
|
|
}
|
|
|
|
ClassLoader loader = Thread.currentThread().getContextClassLoader();
|
|
String path=null;
|
|
try
|
|
{
|
|
// Typically, the value of 'path' will be something like:
|
|
//
|
|
// $TOMCAT_HOME/webapps/alfresco/WEB-INF/classes/alfresco/alfresco-jmxrmi.password
|
|
// or: $TOMCAT_HOME/shared/classes/alfresco/alfresco-jmxrmi.password
|
|
//
|
|
// However, if WCM isn't installed there won't be a JMX password file.
|
|
// Therefore, while it's important to choke on bad paths, a missing
|
|
// password file must be acceptable -- it just means that WCM virtualization
|
|
// will be disabled later when org.alfresco.mbeans.VirtServerRegistry
|
|
// refuses to bring up the serverConnector bean.
|
|
|
|
path = loader.getResource("alfresco/alfresco-jmxrmi.password").toURI().getPath();
|
|
}
|
|
catch (java.net.URISyntaxException e ) { e.printStackTrace(); }
|
|
catch (Exception e )
|
|
{
|
|
if ( logger.isWarnEnabled() )
|
|
logger.warn("Could not find alfresco-jmxrmi.password on classpath");
|
|
}
|
|
|
|
if ( path == null ) { System.setProperty("alfresco.jmx.dir", ""); }
|
|
else
|
|
{
|
|
String alfresco_jmx_dir =
|
|
path.substring(0,path.lastIndexOf("/alfresco-jmxrmi.password"));
|
|
|
|
// The value of 'alfresco.jmx.dir' will be something like:
|
|
// $TOMCAT_HOME/webapps/alfresco/WEB-INF/classes/alfresco
|
|
|
|
System.setProperty("alfresco.jmx.dir", alfresco_jmx_dir);
|
|
}
|
|
}
|
|
public void setOrder(int order) { this.order = order; }
|
|
public int getOrder() { return order; }
|
|
}
|