ratpack.hikari.HikariModule Maven / Gradle / Ivy
/*
* Copyright 2014 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
*
* http://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 ratpack.hikari;
import com.google.inject.Provides;
import com.google.inject.Singleton;
import com.zaxxer.hikari.HikariConfig;
import com.zaxxer.hikari.HikariDataSource;
import ratpack.guice.ConfigurableModule;
import javax.sql.DataSource;
/**
* An extension module that provides a {@link DataSource} from a HikariCP JDBC connection pool.
*
* This is a {@link ConfigurableModule}, exposing the {@link HikariConfig} type as the configuration.
* All aspects of the connection pool can be configured through this object.
* See {@link ConfigurableModule} for usage patterns.
*
{@code
* import ratpack.service.Service;
* import ratpack.service.StartEvent;
* import ratpack.exec.Blocking;
* import ratpack.guice.Guice;
* import ratpack.hikari.HikariModule;
* import ratpack.test.embed.EmbeddedApp;
*
* import javax.sql.DataSource;
* import java.sql.Connection;
* import java.sql.PreparedStatement;
* import java.sql.ResultSet;
*
* import static org.junit.Assert.*;
*
* public class Example {
* static class InitDb implements Service {
* public void onStart(StartEvent startEvent) throws Exception {
* DataSource dataSource = startEvent.getRegistry().get(DataSource.class);
* try (Connection connection = dataSource.getConnection()) {
* connection.createStatement().executeUpdate("create table if not exists val(ID INT PRIMARY KEY, val VARCHAR(255));");
* }
* }
* }
*
* public static void main(String... args) throws Exception {
* EmbeddedApp.of(s -> s
* .registry(Guice.registry(b -> b
* .module(HikariModule.class, hikariConfig -> {
* hikariConfig.setDataSourceClassName("org.h2.jdbcx.JdbcDataSource");
* hikariConfig.addDataSourceProperty("URL", "jdbc:h2:mem:dev"); // Use H2 in memory database
* })
* .bind(InitDb.class)
* ))
* .handlers(chain -> chain
* .post("set/:val", ctx ->
* Blocking.get(() -> {
* try (Connection connection = ctx.get(DataSource.class).getConnection()) {
* PreparedStatement statement = connection.prepareStatement("merge into val (id, val) key(id) values (?, ?)");
* statement.setInt(1, 1);
* statement.setString(2, ctx.getPathTokens().get("val"));
* return statement.executeUpdate();
* }
* }).then(result ->
* ctx.render(result.toString())
* )
* )
* .get("get", ctx ->
* Blocking.get(() -> {
* try (Connection connection = ctx.get(DataSource.class).getConnection()) {
* PreparedStatement statement = connection.prepareStatement("select val from val where id = ?");
* statement.setInt(1, 1);
* ResultSet resultSet = statement.executeQuery();
* resultSet.next();
* return resultSet.getString(1);
* }
* }).then(ctx::render)
* )
* )
* ).test(httpClient -> {
* httpClient.post("set/foo");
* assertEquals("foo", httpClient.getText("get"));
* });
* }
* }
* }
*
* @see HikariCP
* @see HikariConfig
* @see ConfigurableModule
*/
public class HikariModule extends ConfigurableModule {
@Override
protected void configure() {
}
@Provides
@Singleton
public HikariService hikariService(HikariConfig config) {
return new HikariService(new HikariDataSource(config));
}
@Provides
@Singleton
public DataSource dataSource(HikariService service) {
return getDataSource(service);
}
// separate from above to allow decoration of the datasource by extending the module
// Guice does not allow overriding @Provides methods
protected DataSource getDataSource(HikariService service) {
return service.getDataSource();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy