3 * Copyright (C) 2007 EDIT
4 * European Distributed Institute of Taxonomy
5 * http://www.e-taxonomy.eu
7 * The contents of this file are subject to the Mozilla Public License Version 1.1
8 * See LICENSE.TXT at the top of this package for the full license terms.
12 package eu
.etaxonomy
.cdm
.api
.application
;
14 import java
.util
.List
;
15 import java
.util
.UUID
;
17 import org
.apache
.log4j
.Logger
;
18 import org
.hibernate
.SessionFactory
;
19 import org
.springframework
.beans
.MutablePropertyValues
;
20 import org
.springframework
.beans
.factory
.config
.BeanDefinition
;
21 import org
.springframework
.beans
.factory
.xml
.XmlBeanDefinitionReader
;
22 import org
.springframework
.context
.support
.AbstractApplicationContext
;
23 import org
.springframework
.context
.support
.GenericApplicationContext
;
24 import org
.springframework
.core
.io
.ClassPathResource
;
25 import org
.springframework
.core
.io
.Resource
;
26 import org
.springframework
.security
.authentication
.ProviderManager
;
27 import org
.springframework
.transaction
.PlatformTransactionManager
;
28 import org
.springframework
.transaction
.TransactionDefinition
;
29 import org
.springframework
.transaction
.TransactionStatus
;
30 import org
.springframework
.transaction
.support
.DefaultTransactionDefinition
;
32 import eu
.etaxonomy
.cdm
.api
.application
.eclipse
.EclipseRcpSaveGenericApplicationContext
;
33 import eu
.etaxonomy
.cdm
.api
.conversation
.ConversationHolder
;
34 import eu
.etaxonomy
.cdm
.api
.service
.IAgentService
;
35 import eu
.etaxonomy
.cdm
.api
.service
.ICollectionService
;
36 import eu
.etaxonomy
.cdm
.api
.service
.ICommonService
;
37 import eu
.etaxonomy
.cdm
.api
.service
.IDatabaseService
;
38 import eu
.etaxonomy
.cdm
.api
.service
.IDescriptionService
;
39 import eu
.etaxonomy
.cdm
.api
.service
.IFeatureTreeService
;
40 import eu
.etaxonomy
.cdm
.api
.service
.ILocationService
;
41 import eu
.etaxonomy
.cdm
.api
.service
.IMediaService
;
42 import eu
.etaxonomy
.cdm
.api
.service
.INameService
;
43 import eu
.etaxonomy
.cdm
.api
.service
.IOccurrenceService
;
44 import eu
.etaxonomy
.cdm
.api
.service
.IReferenceService
;
45 import eu
.etaxonomy
.cdm
.api
.service
.IService
;
46 import eu
.etaxonomy
.cdm
.api
.service
.ITaxonNodeService
;
47 import eu
.etaxonomy
.cdm
.api
.service
.ITaxonService
;
48 import eu
.etaxonomy
.cdm
.api
.service
.ITaxonTreeService
;
49 import eu
.etaxonomy
.cdm
.api
.service
.ITermService
;
50 import eu
.etaxonomy
.cdm
.api
.service
.IUserService
;
51 import eu
.etaxonomy
.cdm
.api
.service
.IVocabularyService
;
52 import eu
.etaxonomy
.cdm
.database
.CdmPersistentDataSource
;
53 import eu
.etaxonomy
.cdm
.database
.DataSourceNotFoundException
;
54 import eu
.etaxonomy
.cdm
.database
.DbSchemaValidation
;
55 import eu
.etaxonomy
.cdm
.database
.ICdmDataSource
;
56 import eu
.etaxonomy
.cdm
.model
.common
.CdmBase
;
57 import eu
.etaxonomy
.cdm
.model
.common
.CdmMetaData
;
58 import eu
.etaxonomy
.cdm
.model
.common
.DefinedTermBase
;
59 import eu
.etaxonomy
.cdm
.model
.common
.User
;
60 import eu
.etaxonomy
.cdm
.model
.common
.init
.TermNotFoundException
;
67 public class CdmApplicationController
{
68 private static final Logger logger
= Logger
.getLogger(CdmApplicationController
.class);
70 public static final String DEFAULT_APPLICATION_CONTEXT_RESOURCE
= "/eu/etaxonomy/cdm/defaultApplicationContext.xml";
72 public AbstractApplicationContext applicationContext
;
73 private ICdmApplicationConfiguration configuration
;
74 private Resource applicationContextResource
;
76 final static DbSchemaValidation defaultDbSchemaValidation
= DbSchemaValidation
.VALIDATE
;
81 * Constructor, opens an spring 2.5 ApplicationContext by using the default data source
83 public static CdmApplicationController
NewInstance() throws DataSourceNotFoundException
, TermNotFoundException
{
84 logger
.info("Start CdmApplicationController with default data source");
85 CdmPersistentDataSource dataSource
= CdmPersistentDataSource
.NewDefaultInstance();
86 DbSchemaValidation dbSchemaValidation
= defaultDbSchemaValidation
;
87 return new CdmApplicationController(null, dataSource
, dbSchemaValidation
, false);
91 * Constructor, opens an spring 2.5 ApplicationContext by using the default data source
92 * @param dbSchemaValidation validation type for database schema
94 public static CdmApplicationController
NewInstance(DbSchemaValidation dbSchemaValidation
) throws DataSourceNotFoundException
, TermNotFoundException
{
95 logger
.info("Start CdmApplicationController with default data source");
96 CdmPersistentDataSource dataSource
= CdmPersistentDataSource
.NewDefaultInstance();
97 if (dbSchemaValidation
== null){
98 dbSchemaValidation
= defaultDbSchemaValidation
;
100 return new CdmApplicationController(null, dataSource
, dbSchemaValidation
, false);
105 * Constructor, opens an spring 2.5 ApplicationContext by using the according data source and the
106 * default database schema validation type
109 public static CdmApplicationController
NewInstance(ICdmDataSource dataSource
)
110 throws DataSourceNotFoundException
, TermNotFoundException
{
111 return new CdmApplicationController(null, dataSource
, defaultDbSchemaValidation
, false);
114 public static CdmApplicationController
NewInstance(ICdmDataSource dataSource
, DbSchemaValidation dbSchemaValidation
)
115 throws DataSourceNotFoundException
, TermNotFoundException
{
116 return new CdmApplicationController(null, dataSource
, dbSchemaValidation
, false);
119 public static CdmApplicationController
NewInstance(ICdmDataSource dataSource
, DbSchemaValidation dbSchemaValidation
, boolean omitTermLoading
)
120 throws DataSourceNotFoundException
, TermNotFoundException
{
121 return new CdmApplicationController(null, dataSource
, dbSchemaValidation
, omitTermLoading
);
124 public static CdmApplicationController
NewInstance(Resource applicationContextResource
, ICdmDataSource dataSource
, DbSchemaValidation dbSchemaValidation
, boolean omitTermLoading
)
125 throws DataSourceNotFoundException
, TermNotFoundException
{
126 return new CdmApplicationController(applicationContextResource
, dataSource
, dbSchemaValidation
, omitTermLoading
);
130 * Constructor, opens an spring 2.5 ApplicationContext by using the according data source
132 * @param dbSchemaValidation
133 * @param omitTermLoading
135 private CdmApplicationController(Resource applicationContextResource
, ICdmDataSource dataSource
, DbSchemaValidation dbSchemaValidation
, boolean omitTermLoading
){
136 logger
.info("Start CdmApplicationController with datasource: " + dataSource
.getName());
137 if (applicationContextResource
!= null){
138 this.applicationContextResource
= applicationContextResource
;
140 this.applicationContextResource
= new ClassPathResource(DEFAULT_APPLICATION_CONTEXT_RESOURCE
);
143 setNewDataSource(dataSource
, dbSchemaValidation
, omitTermLoading
);
145 // if (setNewDataSource(dataSource, dbSchemaValidation, omitTermLoading) == false){
146 // throw new DataSourceNotFoundException("Wrong datasource: " + dataSource );
152 * Sets the application context to a new spring ApplicationContext by using the according data source and initializes the Controller.
155 private boolean setNewDataSource(ICdmDataSource dataSource
, DbSchemaValidation dbSchemaValidation
, boolean omitTermLoading
){
156 if (dbSchemaValidation
== null){
157 dbSchemaValidation
= defaultDbSchemaValidation
;
159 logger
.info("Connecting to '" + dataSource
.getName() + "'");
162 GenericApplicationContext appContext
;
164 appContext
= new EclipseRcpSaveGenericApplicationContext();
166 BeanDefinition datasourceBean
= dataSource
.getDatasourceBean();
167 datasourceBean
.setAttribute("isLazy", false);
168 appContext
.registerBeanDefinition("dataSource", datasourceBean
);
170 BeanDefinition hibernatePropBean
= dataSource
.getHibernatePropertiesBean(dbSchemaValidation
);
171 appContext
.registerBeanDefinition("hibernateProperties", hibernatePropBean
);
173 XmlBeanDefinitionReader xmlReader
= new XmlBeanDefinitionReader(appContext
);
174 xmlReader
.loadBeanDefinitions(this.applicationContextResource
);
177 String initializerName
= "persistentTermInitializer";
178 BeanDefinition beanDef
= appContext
.getBeanDefinition(initializerName
);
179 MutablePropertyValues values
= beanDef
.getPropertyValues();
180 values
.addPropertyValue("omit", omitTermLoading
);
182 appContext
.refresh();
185 setApplicationContext(appContext
);
187 //initialize user and metaData for new databases
188 int userCount
= getUserService().count(User
.class);
189 if (userCount
== 0 ){
192 int metaDataCount
= getCommonService().getCdmMetaData().size();
193 if (metaDataCount
== 0){
200 private void createAdminUser(){
201 User firstUser
= User
.NewInstance("admin", "0000");
202 getUserService().save(firstUser
);
203 logger
.info("Admin user created.");
206 private void createMetadata(){
207 List
<CdmMetaData
> metaData
= CdmMetaData
.defaultMetaData();
208 getCommonService().saveAllMetaData(metaData
);
209 logger
.info("Metadata created.");
214 * Tests if some DefinedTermsAreMissing.
215 * @return true, if at least one is missing, else false
217 public boolean testDefinedTermsAreMissing(){
218 UUID englishUuid
= UUID
.fromString("e9f8cdb7-6819-44e8-95d3-e2d0690c3523");
219 DefinedTermBase
<?
> english
= this.getTermService().getByUri(englishUuid
.toString());
220 if ( english
== null || ! english
.getUuid().equals(englishUuid
)){
229 * Changes the ApplicationContext to the new dataSource
232 public boolean changeDataSource(ICdmDataSource dataSource
){
233 //logger.info("Change datasource to : " + dataSource);
234 return setNewDataSource(dataSource
, DbSchemaValidation
.VALIDATE
, false);
238 * Changes the ApplicationContext to the new dataSource
240 * @param dbSchemaValidation
242 public boolean changeDataSource(ICdmDataSource dataSource
, DbSchemaValidation dbSchemaValidation
){
243 //logger.info("Change datasource to : " + dataSource);
244 return setNewDataSource(dataSource
, dbSchemaValidation
, false);
248 * Changes the ApplicationContext to the new dataSource
250 * @param dbSchemaValidation
251 * @param omitTermLoading
253 public boolean changeDataSource(ICdmDataSource dataSource
, DbSchemaValidation dbSchemaValidation
, boolean omitTermLoading
){
254 logger
.info("Change datasource to : " + dataSource
);
255 return setNewDataSource(dataSource
, dbSchemaValidation
, omitTermLoading
);
259 * Sets a new application Context.
262 public void setApplicationContext(AbstractApplicationContext ac
){
263 closeApplicationContext(); //closes old application context if necessary
264 applicationContext
= ac
;
265 applicationContext
.registerShutdownHook();
270 * @see java.lang.Object#finalize()
272 public void finalize(){
277 * closes the application
280 closeApplicationContext();
284 * closes the application context
286 private void closeApplicationContext(){
287 if (applicationContext
!= null){
288 logger
.info("Close ApplicationContext");
289 applicationContext
.close();
294 logger
.debug("Init " + this.getClass().getName() + " ... ");
295 if (logger
.isDebugEnabled()){for (String beanName
: applicationContext
.getBeanDefinitionNames()){ logger
.debug(beanName
);}}
296 //TODO delete next row (was just for testing)
297 if (logger
.isInfoEnabled()){
298 logger
.info("Registered Beans: ");
299 String
[] beans
= applicationContext
.getBeanDefinitionNames();
300 for (String bean
:beans
){
304 configuration
= (ICdmApplicationConfiguration
)applicationContext
.getBean("cdmApplicationDefaultConfiguration");
305 getDatabaseService().setApplicationController(this);
310 /* ****** Services *********/
311 public final INameService
getNameService(){
312 return configuration
.getNameService();
315 public final ITaxonService
getTaxonService(){
316 return configuration
.getTaxonService();
319 public final ITaxonTreeService
getTaxonTreeService(){
320 return configuration
.getTaxonTreeService();
323 public final ITaxonNodeService
getTaxonNodeService(){
324 return configuration
.getTaxonNodeService();
327 public final IReferenceService
getReferenceService(){
328 return configuration
.getReferenceService();
331 public final IAgentService
getAgentService(){
332 return configuration
.getAgentService();
335 public final IDatabaseService
getDatabaseService(){
336 return configuration
.getDatabaseService();
339 public final ITermService
getTermService(){
340 return configuration
.getTermService();
343 public final IDescriptionService
getDescriptionService(){
344 return configuration
.getDescriptionService();
347 public final IOccurrenceService
getOccurrenceService(){
348 return configuration
.getOccurrenceService();
351 public final IMediaService
getMediaService(){
352 return configuration
.getMediaService();
355 public final ICommonService
getCommonService(){
356 return configuration
.getCommonService();
359 public final ILocationService
getLocationService(){
360 return configuration
.getLocationService();
363 public final IUserService
getUserService(){
364 return configuration
.getUserService();
367 public final ICollectionService
getCollectionService(){
368 return configuration
.getCollectionService();
371 public final IFeatureTreeService
getFeatureTreeService(){
372 return configuration
.getFeatureTreeService();
375 public final IVocabularyService
getVocabularyService(){
376 return configuration
.getVocabularyService();
379 public final IService
<CdmBase
> getMainService(){
380 return configuration
.getMainService();
383 public final ConversationHolder
NewConversation(){
384 //return (ConversationHolder)applicationContext.getBean("conversationHolder");
385 return configuration
.NewConversation();
389 public final ProviderManager
getAuthenticationManager(){
390 return configuration
.getAuthenticationManager();
393 public final Object
getBean(String name
){
394 return this.applicationContext
.getBean(name
);
398 * OLD TRANSACTION STUFF
401 /* **** flush ***********/
402 public void flush() {
403 SessionFactory sf
= (SessionFactory
)applicationContext
.getBean("sessionFactory");
404 sf
.getCurrentSession().flush();
407 public SessionFactory
getSessionFactory(){
408 return (SessionFactory
)applicationContext
.getBean("sessionFactory");
411 public TransactionStatus
startTransaction() {
413 return startTransaction(false);
416 public TransactionStatus
startTransaction(Boolean readOnly
) {
418 PlatformTransactionManager txManager
= configuration
.getTransactionManager();
420 DefaultTransactionDefinition defaultTxDef
= new DefaultTransactionDefinition();
421 defaultTxDef
.setReadOnly(readOnly
);
422 TransactionDefinition txDef
= defaultTxDef
;
424 // Log some transaction-related debug information.
425 if (logger
.isDebugEnabled()) {
426 logger
.debug("Transaction name = " + txDef
.getName());
427 logger
.debug("Transaction facets:");
428 logger
.debug("Propagation behavior = " + txDef
.getPropagationBehavior());
429 logger
.debug("Isolation level = " + txDef
.getIsolationLevel());
430 logger
.debug("Timeout = " + txDef
.getTimeout());
431 logger
.debug("Read Only = " + txDef
.isReadOnly());
432 // org.springframework.orm.hibernate3.HibernateTransactionManager
433 // provides more transaction/session-related debug information.
436 TransactionStatus txStatus
= txManager
.getTransaction(txDef
);
440 public void commitTransaction(TransactionStatus txStatus
){
441 PlatformTransactionManager txManager
= configuration
.getTransactionManager();
442 txManager
.commit(txStatus
);