X-Git-Url: http://wamblee.org/gitweb/?a=blobdiff_plain;f=system%2Fspring%2Fsrc%2Fmain%2Fjava%2Forg%2Fwamblee%2Fsystem%2Fspring%2Fcomponent%2FHibernateComponent.java;h=9d5bb83bf6e38e9b03ccad4958906f46b89f24c1;hb=dec278a67997ea8e85d10662e31548afd8890ed3;hp=7db715a8b156c39993ca1c048bbcd71e43c7850e;hpb=7d25939b586bd3a4235a75b9fee8389d06f12923;p=utils diff --git a/system/spring/src/main/java/org/wamblee/system/spring/component/HibernateComponent.java b/system/spring/src/main/java/org/wamblee/system/spring/component/HibernateComponent.java index 7db715a8..9d5bb83b 100644 --- a/system/spring/src/main/java/org/wamblee/system/spring/component/HibernateComponent.java +++ b/system/spring/src/main/java/org/wamblee/system/spring/component/HibernateComponent.java @@ -1,5 +1,5 @@ /* - * Copyright 2008 the original author or authors. + * Copyright 2005-2010 the original author or authors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -15,56 +15,108 @@ */ package org.wamblee.system.spring.component; -import java.io.IOException; import java.util.HashMap; import java.util.Map; import java.util.Properties; -import java.util.TreeMap; import javax.sql.DataSource; import org.hibernate.SessionFactory; -import org.springframework.core.io.ClassPathResource; +import org.hibernate.dialect.DerbyDialect; +import org.hibernate.dialect.MySQLInnoDBDialect; import org.springframework.orm.hibernate3.HibernateTemplate; import org.springframework.transaction.PlatformTransactionManager; import org.wamblee.persistence.hibernate.HibernateMappingFiles; +import org.wamblee.system.components.ORMappingConfig; +import org.wamblee.system.components.ORMappingConfig.DatabaseType; import org.wamblee.system.core.DefaultProvidedInterface; import org.wamblee.system.core.DefaultRequiredInterface; import org.wamblee.system.core.ProvidedInterface; import org.wamblee.system.core.RequiredInterface; +import org.wamblee.system.core.Scope; import org.wamblee.system.spring.SpringComponent; +/** + * + * @author $author$ + * @version $Revision$ + */ public class HibernateComponent extends SpringComponent { + private static final String HIBERNATE_DIALECT_PROP = "hibernate.dialect"; + + private static final String HIBERNATE_SCHEMAUPDATE_PROP = "hibernate.schemaupdate"; + + private static final String HIBERNATE_PROPS_KEY = "hibernateProperties"; - private static final String HIBERNATE_PROPERTIES = "properties/org.wamblee.system.spring.component.hibernate.properties"; private static final String HIBERNATE_SPRING_CONFIG = "spring/org.wamblee.system.spring.component.hibernate.xml"; - public HibernateComponent(String aName) throws IOException { - super(aName, new String[] { HIBERNATE_SPRING_CONFIG}, - createProvided(), createRequired()); - - Properties props = new Properties(); - props.load(new ClassPathResource(HIBERNATE_PROPERTIES).getInputStream()); - addProperties(props); + private final RequiredInterface config = new DefaultRequiredInterface( + "config", ORMappingConfig.class); + + /** + * Creates a new HibernateComponent object. + * + * + */ + public HibernateComponent(String aName) { + super(aName, new String[] { HIBERNATE_SPRING_CONFIG }, + createProvided(), createRequired()); + + Properties props = new Properties(); + addProperties(HIBERNATE_PROPS_KEY, props); + + addRequiredInterface(config); + } + + @Override + protected Scope doStart(Scope aExternalScope) { + ORMappingConfig orMappingConfig = aExternalScope.getInterfaceImplementation( + config.getProvider(), ORMappingConfig.class); + setProperty(HIBERNATE_SCHEMAUPDATE_PROP, "" + orMappingConfig.isSchemaUpdate()); + + DatabaseType db = orMappingConfig.getType(); + String dialect = db.handleCases(new DatabaseType.Switch() { + @Override + public String handleMySqlInnoDb() { + return MySQLInnoDBDialect.class.getName(); + } + + @Override + public String handleDerby() { + return DerbyDialect.class.getName(); + } + }); + + getHibernateProperties().put(HIBERNATE_DIALECT_PROP, dialect); + + return super.doStart(aExternalScope); + } + + private Properties getHibernateProperties() { + return getProperties(HIBERNATE_PROPS_KEY); } private static Map createRequired() { - Map required = new HashMap(); - required.put(new DefaultRequiredInterface("datasource", DataSource.class), "dataSource"); - required.put(new DefaultRequiredInterface("mappingFiles", HibernateMappingFiles.class), - "hibernateMappingFiles"); + Map required = new HashMap(); + required.put(new DefaultRequiredInterface("datasource", + DataSource.class), "dataSource"); + required.put(new DefaultRequiredInterface("mappingFiles", + HibernateMappingFiles.class), "hibernateMappingFiles"); + return required; } private static Map createProvided() { - Map provided = new HashMap(); - + Map provided = new HashMap(); + provided.put("transactionManager", new DefaultProvidedInterface( - "transactionMgr", PlatformTransactionManager.class)); + "transactionMgr", PlatformTransactionManager.class)); provided.put("sessionFactory", new DefaultProvidedInterface( - "sessionFactory", SessionFactory.class)); - provided.put("org.springframework.orm.hibernate3.HibernateTemplate", new DefaultProvidedInterface( - "hibernateTemplate", HibernateTemplate.class)); + "sessionFactory", SessionFactory.class)); + provided.put("org.springframework.orm.hibernate3.HibernateTemplate", + new DefaultProvidedInterface("hibernateTemplate", + HibernateTemplate.class)); + return provided; } }