diff options
| author | Christian Maierhofer <cmaierhofer@iaik.tugraz.at> | 2016-06-28 13:47:52 +0200 | 
|---|---|---|
| committer | Christian Maierhofer <cmaierhofer@iaik.tugraz.at> | 2016-06-28 13:47:52 +0200 | 
| commit | 7717d75918fb63ee7e9d7bf31de2696577b7e991 (patch) | |
| tree | 789f089649f27825e5570b8f6a0675474de5e6a5 /id/server/idserverlib/src | |
| parent | 0d4863abf480dd35d5ffa87f09604096aae905bc (diff) | |
| download | moa-id-spss-7717d75918fb63ee7e9d7bf31de2696577b7e991.tar.gz moa-id-spss-7717d75918fb63ee7e9d7bf31de2696577b7e991.tar.bz2 moa-id-spss-7717d75918fb63ee7e9d7bf31de2696577b7e991.zip | |
statisticlogger dbcp connection pool
Diffstat (limited to 'id/server/idserverlib/src')
10 files changed, 148 insertions, 26 deletions
| diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/advancedlogging/DummyStatisticLogger.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/advancedlogging/DummyStatisticLogger.java new file mode 100644 index 000000000..5a1b7205d --- /dev/null +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/advancedlogging/DummyStatisticLogger.java @@ -0,0 +1,49 @@ +/******************************************************************************* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + *******************************************************************************/ +package at.gv.egovernment.moa.id.advancedlogging; + + +import org.springframework.stereotype.Service; + +import at.gv.egovernment.moa.id.commons.api.IRequest; +import at.gv.egovernment.moa.id.data.IAuthData; +import at.gv.egovernment.moa.logging.Logger; + +@Service("StatisticLogger") +public class DummyStatisticLogger implements IStatisticLogger{ + +	@Override +	public void logSuccessOperation(IRequest protocolRequest, +			IAuthData authData, boolean isSSOSession) { +		Logger.trace("Dummy-logSuccessOperation");		 +	} + +	@Override +	public void logErrorOperation(Throwable throwable) { +		Logger.trace("Dummy-logErrorOperation");		 +	} + +	@Override +	public void logErrorOperation(Throwable throwable, IRequest errorRequest) { +		Logger.trace("Dummy-logErrorOperation");			 +	}} diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/advancedlogging/IStatisticLogger.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/advancedlogging/IStatisticLogger.java new file mode 100644 index 000000000..2d97d7258 --- /dev/null +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/advancedlogging/IStatisticLogger.java @@ -0,0 +1,37 @@ +/******************************************************************************* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + *******************************************************************************/ +package at.gv.egovernment.moa.id.advancedlogging; + +import at.gv.egovernment.moa.id.commons.api.IRequest; +import at.gv.egovernment.moa.id.data.IAuthData; + + +public interface IStatisticLogger { +		 +	public void logSuccessOperation(IRequest protocolRequest, IAuthData authData, boolean isSSOSession); +	 +	public void logErrorOperation(Throwable throwable); +	 +	public void logErrorOperation(Throwable throwable, IRequest errorRequest); +	 +} diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/advancedlogging/StatisticLogger.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/advancedlogging/StatisticLogger.java index 0171f9d90..d15d80efc 100644 --- a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/advancedlogging/StatisticLogger.java +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/advancedlogging/StatisticLogger.java @@ -33,6 +33,7 @@ import javax.xml.bind.Unmarshaller;  import org.apache.commons.lang3.StringEscapeUtils;  import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.context.annotation.Profile;  import org.springframework.stereotype.Service;  import at.gv.e_government.reference.namespace.mandates._20040701_.Mandate; @@ -48,6 +49,7 @@ import at.gv.egovernment.moa.id.commons.api.IOAAuthParameters;  import at.gv.egovernment.moa.id.commons.api.IRequest;  import at.gv.egovernment.moa.id.commons.api.exceptions.ConfigurationException;  import at.gv.egovernment.moa.id.commons.api.exceptions.MOAIDException; +import at.gv.egovernment.moa.id.commons.config.SpringProfileConstants;  import at.gv.egovernment.moa.id.commons.db.StatisticLogDBUtils;  import at.gv.egovernment.moa.id.commons.db.dao.statistic.StatisticLog;  import at.gv.egovernment.moa.id.commons.db.ex.MOADatabaseException; @@ -60,7 +62,8 @@ import at.gv.egovernment.moa.logging.Logger;  import at.gv.egovernment.moa.util.MiscUtil;  @Service("StatisticLogger") -public class StatisticLogger { +@Profile("advancedLogOn") +public class StatisticLogger implements IStatisticLogger{  	private static final String GENERIC_LOCALBKU = ":3496/https-security-layer-request";  	private static final String GENERIC_HANDYBKU = "https://www.handy-signatur.at/"; @@ -79,6 +82,7 @@ public class StatisticLogger {  	@Autowired AuthConfiguration authConfig;  	@Autowired IAuthenticationSessionStoreage authenticatedSessionStorage; +	@Autowired StatisticLogDBUtils statisticLogDBUtils;  	public void logSuccessOperation(IRequest protocolRequest, IAuthData authData, boolean isSSOSession) { @@ -191,7 +195,7 @@ public class StatisticLogger {  			try { -				StatisticLogDBUtils.saveOrUpdate(dblog); +				statisticLogDBUtils.saveOrUpdate(dblog);  			} catch (MOADatabaseException e) {  				Logger.warn("Statistic Log can not be stored into Database", e); @@ -217,7 +221,7 @@ public class StatisticLogger {  			try { -				StatisticLogDBUtils.saveOrUpdate(dblog); +				statisticLogDBUtils.saveOrUpdate(dblog);  			} catch (MOADatabaseException e) {  				Logger.warn("Statistic Log can not be stored into Database", e); @@ -268,7 +272,7 @@ public class StatisticLogger {  				try { -					StatisticLogDBUtils.saveOrUpdate(dblog); +					statisticLogDBUtils.saveOrUpdate(dblog);  				} catch (MOADatabaseException e) {  					Logger.warn("Statistic Log can not be stored into Database", e); diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/AbstractController.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/AbstractController.java index 9e0eb2ed2..0d99bcd68 100644 --- a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/AbstractController.java +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/auth/servlet/AbstractController.java @@ -32,9 +32,9 @@ import javax.servlet.http.HttpServletResponse;  import org.springframework.beans.factory.annotation.Autowired;  import org.springframework.web.bind.annotation.ExceptionHandler; +import at.gv.egovernment.moa.id.advancedlogging.IStatisticLogger;  import at.gv.egovernment.moa.id.advancedlogging.MOAIDEventConstants;  import at.gv.egovernment.moa.id.advancedlogging.MOAReversionLogger; -import at.gv.egovernment.moa.id.advancedlogging.StatisticLogger;  import at.gv.egovernment.moa.id.auth.exception.InvalidProtocolRequestException;  import at.gv.egovernment.moa.id.auth.exception.ProtocolNotActiveException;  import at.gv.egovernment.moa.id.auth.frontend.builder.DefaultGUIFormBuilderConfiguration; @@ -69,7 +69,7 @@ public abstract class AbstractController extends MOAIDAuthConstants {  	public static final String ERROR_CODE_PARAM = "errorid"; -	@Autowired protected StatisticLogger statisticLogger; +	@Autowired protected IStatisticLogger statisticLogger;  	@Autowired protected IRequestStorage requestStorage;  	@Autowired protected ITransactionStorage transactionStorage;  	@Autowired protected MOAReversionLogger revisionsLogger; diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/config/ConfigurationProviderImpl.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/config/ConfigurationProviderImpl.java index a07099a93..67ad4762c 100644 --- a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/config/ConfigurationProviderImpl.java +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/config/ConfigurationProviderImpl.java @@ -46,6 +46,7 @@  package at.gv.egovernment.moa.id.config; +import java.util.ArrayList;  import java.util.Map;  import java.util.Properties; @@ -53,6 +54,7 @@ import org.hibernate.cfg.Configuration;  import at.gv.egovernment.moa.id.commons.api.ConfigurationProvider;  import at.gv.egovernment.moa.id.commons.api.exceptions.ConfigurationException; +import at.gv.egovernment.moa.id.commons.config.SpringProfileConstants;  import at.gv.egovernment.moa.id.commons.db.MOASessionDBUtils;  import at.gv.egovernment.moa.id.commons.db.StatisticLogDBUtils;  import at.gv.egovernment.moa.id.commons.db.dao.session.AssertionStore; @@ -229,14 +231,14 @@ public abstract class ConfigurationProviderImpl implements ConfigurationProvider  					//MOASessionDBUtils.initHibernate(config, moaSessionProp);  					//initial advanced logging -					if (Boolean.valueOf(props.getProperty("configuration.advancedlogging.active", "false"))) { -						Logger.info("Advanced statistic log is activated, starting initialization process ..."); -						Configuration statisticconfig = new Configuration(); -						statisticconfig.addAnnotatedClass(StatisticLog.class); -						statisticconfig.addProperties(statisticProps); -						StatisticLogDBUtils.initHibernate(statisticconfig, statisticProps); -						Logger.info("Advanced statistic log is initialized."); -					} +//					if (Boolean.valueOf(props.getProperty("configuration.advancedlogging.active", "false"))) { +//						Logger.info("Advanced statistic log is activated, starting initialization process ..."); +//						Configuration statisticconfig = new Configuration(); +//						statisticconfig.addAnnotatedClass(StatisticLog.class); +//						statisticconfig.addProperties(statisticProps); +//						StatisticLogDBUtils.initHibernate(statisticconfig, statisticProps); +//						Logger.info("Advanced statistic log is initialized."); +//					}  				  }  				Logger.trace("Hibernate initialization finished."); @@ -271,6 +273,7 @@ public abstract class ConfigurationProviderImpl implements ConfigurationProvider  				eGovUtilsConfig =   						new EgovUtilPropertiesConfiguration(eGovUtilsConfigProp, rootConfigFileDir);  			} +			this.generateActiveProfiles(props);    } @@ -281,5 +284,24 @@ public abstract class ConfigurationProviderImpl implements ConfigurationProvider  	public EgovUtilPropertiesConfiguration geteGovUtilsConfig() {  		return eGovUtilsConfig;  	} +	 +	private ArrayList<String> activeProfiles = new ArrayList<String>(); +	 +	public void generateActiveProfiles(Properties props){ +		if (Boolean.valueOf(props.getProperty("configuration.advancedlogging.active", "false"))) { +			activeProfiles.add(SpringProfileConstants.ADVANCED_LOG); +		}else{ +			activeProfiles.add("advancedLogOff"); +		} +		if (Boolean.valueOf(props.getProperty("redis.active", "false"))) { +			activeProfiles.add(SpringProfileConstants.REDIS_BACKEND); +		}else{ +			activeProfiles.add(SpringProfileConstants.DB_BACKEND); +		} +	} +	 +	public String[] getActiveProfiles(){ +		return activeProfiles.toArray(new String[0]); +	}  } diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/storage/DBTransactionStorage.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/storage/DBTransactionStorage.java index fa8ca8547..f17e4a99a 100644 --- a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/storage/DBTransactionStorage.java +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/storage/DBTransactionStorage.java @@ -252,7 +252,7 @@ public class DBTransactionStorage implements ITransactionStorage {  		//store AssertionStore element to Database  		//try { -			entityManager.merge(element); +			entityManager.persist(element);  			//MOASessionDBUtils.saveOrUpdate(element);  			Logger.debug(value.getClass().getName() + " with ID: " + key + " is stored in Database");  //			 diff --git a/id/server/idserverlib/src/main/resources/moaid.authentication.beans.xml b/id/server/idserverlib/src/main/resources/moaid.authentication.beans.xml index cd5fe6acf..ad2a8a063 100644 --- a/id/server/idserverlib/src/main/resources/moaid.authentication.beans.xml +++ b/id/server/idserverlib/src/main/resources/moaid.authentication.beans.xml @@ -47,9 +47,6 @@  	<bean id="ProcessInstanceStoreage"   				class="at.gv.egovernment.moa.id.process.dao.ProcessInstanceStoreDAOImpl"/> -	<bean id="StatisticLogger"  -				class="at.gv.egovernment.moa.id.advancedlogging.StatisticLogger"/> -  	<bean id="MOAReversionLogger"   				class="at.gv.egovernment.moa.id.advancedlogging.MOAReversionLogger"/> @@ -80,7 +77,17 @@  	<bean id="EvaluateSSOConsentsTaskImpl"   				class="at.gv.egovernment.moa.id.auth.modules.internal.tasks.EvaluateSSOConsentsTaskImpl"  				scope="prototype"/>		 +				 +	<beans profile="advancedLogOn"> +		<bean id="StatisticLogger"  +				class="at.gv.egovernment.moa.id.advancedlogging.StatisticLogger"/> +	</beans> +	<beans profile="advancedLogOff"> +		<bean id="StatisticLogger"  +				class="at.gv.egovernment.moa.id.advancedlogging.DummyStatisticLogger"/> +	</beans> -	 -</beans>
\ No newline at end of file +</beans> + + diff --git a/id/server/idserverlib/src/main/resources/session.common.beans.xml b/id/server/idserverlib/src/main/resources/session.common.beans.xml index 10c1320cc..e63e87ae1 100644 --- a/id/server/idserverlib/src/main/resources/session.common.beans.xml +++ b/id/server/idserverlib/src/main/resources/session.common.beans.xml @@ -10,7 +10,8 @@  		http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd  		http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.1.xsd  		http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd"> - +	 +	<context:property-placeholder location="${moa.id.configuration}"/>   	<context:annotation-config/>      <bean id="sessionDataSource" class="org.apache.commons.dbcp2.BasicDataSource" lazy-init="true" destroy-method="close"> @@ -34,7 +35,7 @@  	<bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">      	<property name="dataSource"  ref="sessionDataSource"/> -    	<property name="packagesToScan" value="at.gv.egovernment.moa.id.commons.db" /> +    	<property name="packagesToScan" value="at.gv.egovernment.moa.id.commons.db.dao.session" />      	<property name="hibernateProperties">          	<props>              	<prop key="hibernate.dialect">${moasession.hibernate.dialect}</prop> diff --git a/id/server/idserverlib/src/main/resources/session.db.beans.xml b/id/server/idserverlib/src/main/resources/session.db.beans.xml index 18849c3f1..47aa9fde9 100644 --- a/id/server/idserverlib/src/main/resources/session.db.beans.xml +++ b/id/server/idserverlib/src/main/resources/session.db.beans.xml @@ -1,5 +1,5 @@  <?xml version="1.0" encoding="UTF-8"?> -<beans profile="default" +<beans profile="dbBackend"      xmlns="http://www.springframework.org/schema/beans"  	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  	xmlns:context="http://www.springframework.org/schema/context" @@ -11,7 +11,7 @@  		http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.1.xsd  		http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd"> - 	 + 	<context:property-placeholder location="${moa.id.configuration}"/>   	<bean id="TransactionStorage"   			class="at.gv.egovernment.moa.id.storage.DBTransactionStorage" @@ -26,9 +26,10 @@  		<property name="databasePlatform" value="${moasession.hibernate.dialect}" />  	</bean> -		<bean name="session" id="session" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean" depends-on="sessionDataSource"> +	<bean name="session" id="session" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean" depends-on="sessionDataSource">  		<property name="dataSource" ref="sessionDataSource" />  		<property name="jpaVendorAdapter" ref="sessionJpaVendorAdapter" /> +		<property name="packagesToScan" value="at.gv.egovernment.moa.id.commons.db.dao.session" />  		<property name="persistenceUnitName" value="session" />  	</bean> diff --git a/id/server/idserverlib/src/main/resources/session.redis.beans.xml b/id/server/idserverlib/src/main/resources/session.redis.beans.xml index 9caf5fc6a..feda9b273 100644 --- a/id/server/idserverlib/src/main/resources/session.redis.beans.xml +++ b/id/server/idserverlib/src/main/resources/session.redis.beans.xml @@ -1,5 +1,5 @@  <?xml version="1.0" encoding="UTF-8"?> -<beans profile="redis" +<beans profile="redisBackend"      xmlns="http://www.springframework.org/schema/beans"  	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  	xmlns:context="http://www.springframework.org/schema/context" @@ -11,6 +11,7 @@  		http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.1.xsd  		http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd"> +	<context:property-placeholder location="${moa.id.configuration}"/>   	<bean id="TransactionStorage"   				class="at.gv.egovernment.moa.id.storage.RedisTransactionStorage"/> | 
