001 // Copyright 2007, 2008, 2011 The Apache Software Foundation 002 // 003 // Licensed under the Apache License, Version 2.0 (the "License"); 004 // you may not use this file except in compliance with the License. 005 // You may obtain a copy of the License at 006 // 007 // http://www.apache.org/licenses/LICENSE-2.0 008 // 009 // Unless required by applicable law or agreed to in writing, software 010 // distributed under the License is distributed on an "AS IS" BASIS, 011 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 012 // See the License for the specific language governing permissions and 013 // limitations under the License. 014 015 package org.apache.tapestry5.internal.hibernate; 016 017 import org.apache.tapestry5.hibernate.HibernateConfigurer; 018 import org.apache.tapestry5.hibernate.HibernateSessionSource; 019 import org.apache.tapestry5.ioc.annotations.PostInjection; 020 import org.apache.tapestry5.ioc.services.RegistryShutdownHub; 021 import org.hibernate.Session; 022 import org.hibernate.SessionFactory; 023 import org.hibernate.cfg.AnnotationConfiguration; 024 import org.hibernate.cfg.Configuration; 025 import org.slf4j.Logger; 026 027 import java.util.List; 028 029 public class HibernateSessionSourceImpl implements HibernateSessionSource 030 { 031 private final SessionFactory sessionFactory; 032 033 private final Configuration configuration; 034 035 public HibernateSessionSourceImpl(Logger logger, List<HibernateConfigurer> hibernateConfigurers) 036 { 037 long startTime = System.currentTimeMillis(); 038 039 configuration = new AnnotationConfiguration(); 040 041 for (HibernateConfigurer configurer : hibernateConfigurers) 042 configurer.configure(configuration); 043 044 long configurationComplete = System.currentTimeMillis(); 045 046 sessionFactory = configuration.buildSessionFactory(); 047 048 long factoryCreated = System.currentTimeMillis(); 049 050 logger.info(HibernateCoreMessages.startupTiming(configurationComplete - startTime, factoryCreated - startTime)); 051 052 logger.info(HibernateCoreMessages.entityCatalog(sessionFactory.getAllClassMetadata().keySet())); 053 } 054 055 @PostInjection 056 public void listenForShutdown(RegistryShutdownHub hub) 057 { 058 hub.addRegistryShutdownListener(new Runnable() 059 { 060 public void run() 061 { 062 sessionFactory.close(); 063 } 064 }); 065 } 066 067 public Session create() 068 { 069 return sessionFactory.openSession(); 070 } 071 072 public SessionFactory getSessionFactory() 073 { 074 return sessionFactory; 075 } 076 077 public Configuration getConfiguration() 078 { 079 return configuration; 080 } 081 082 }