All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.mybatis.guice.XMLMyBatisModule Maven / Gradle / Ivy

Go to download

The MyBatis Guice module is easy-to-use Google Guice bridge for MyBatis sql mapping framework.

There is a newer version: 4.0.0
Show newest version
/*
 *    Copyright 2009-2022 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.
 *    You may obtain a copy of the License at
 *
 *       https://www.apache.org/licenses/LICENSE-2.0
 *
 *    Unless required by applicable law or agreed to in writing, software
 *    distributed under the License is distributed on an "AS IS" BASIS,
 *    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *    See the License for the specific language governing permissions and
 *    limitations under the License.
 */
package org.mybatis.guice;

import static org.apache.ibatis.io.Resources.getResourceAsReader;
import static org.mybatis.guice.Preconditions.checkArgument;

import java.io.IOException;
import java.io.Reader;
import java.util.Collection;
import java.util.Properties;

import org.apache.ibatis.plugin.Interceptor;
import org.apache.ibatis.session.Configuration;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.apache.ibatis.type.TypeHandler;

/**
 * Easy to use helper Module that alleviates users to write the boilerplate google-guice bindings to create the
 * SqlSessionFactory, via XML configuration.
 */
public abstract class XMLMyBatisModule extends AbstractMyBatisModule {

  private static final String DEFAULT_CONFIG_RESOURCE = "mybatis-config.xml";

  private static final String DEFAULT_ENVIRONMENT_ID = null;

  private String classPathResource = DEFAULT_CONFIG_RESOURCE;

  private String environmentId = DEFAULT_ENVIRONMENT_ID;

  private Properties properties = new Properties();

  /**
   * Set the MyBatis configuration class path resource.
   *
   * @param classPathResource
   *          the MyBatis configuration class path resource
   */
  protected final void setClassPathResource(String classPathResource) {
    checkArgument(classPathResource != null, "Parameter 'classPathResource' must be not null");
    this.classPathResource = classPathResource;
  }

  /**
   * Set the MyBatis configuration environment id.
   *
   * @param environmentId
   *          the MyBatis configuration environment id
   */
  protected final void setEnvironmentId(String environmentId) {
    this.environmentId = environmentId;
  }

  /**
   * Add the variables will be used to replace placeholders in the MyBatis configuration.
   *
   * @param properties
   *          the variables will be used to replace placeholders in the MyBatis configuration
   */
  protected final void addProperties(Properties properties) {
    if (properties != null) {
      this.properties.putAll(properties);
    }
  }

  /**
   * {@inheritDoc}
   */
  @Override
  final void internalConfigure() {
    this.initialize();

    Reader reader = null;
    try {
      reader = getResourceAsReader(getResourceClassLoader(), classPathResource);
      SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(reader, environmentId, properties);
      bind(SqlSessionFactory.class).toInstance(sessionFactory);

      Configuration configuration = sessionFactory.getConfiguration();

      // bind mappers
      Collection> mapperClasses = configuration.getMapperRegistry().getMappers();
      for (Class mapperType : mapperClasses) {
        bindMapper(mapperType);
      }

      // request injection for type handlers
      Collection> allTypeHandlers = configuration.getTypeHandlerRegistry().getTypeHandlers();
      for (TypeHandler handler : allTypeHandlers) {
        requestInjection(handler);
      }

      // request injection for interceptors
      Collection interceptors = configuration.getInterceptors();
      for (Interceptor interceptor : interceptors) {
        requestInjection(interceptor);
      }

      // request injection for object factory.
      requestInjection(configuration.getObjectFactory());

      // request injection for object wrapper factory.
      requestInjection(configuration.getObjectWrapperFactory());
    } catch (Exception e) {
      addError("Impossible to read classpath resource '%s', see nested exceptions: %s", classPathResource,
          e.getMessage());
    } finally {
      if (reader != null) {
        try {
          reader.close();
        } catch (IOException e) {
          // close quietly
        }
      }
    }
  }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy