本文整理匯總了Java中io.dropwizard.jdbi.DBIFactory類的典型用法代碼示例。如果您正苦於以下問題:Java DBIFactory類的具體用法?Java DBIFactory怎麽用?Java DBIFactory使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
DBIFactory類屬於io.dropwizard.jdbi包,在下文中一共展示了DBIFactory類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: run
import io.dropwizard.jdbi.DBIFactory; //導入依賴的package包/類
@Override
public void run(final BloopServerConfiguration configuration,
final Environment environment) {
final DBIFactory factory = new DBIFactory();
final DBI jdbi = factory.build(environment, configuration.getDataSourceFactory(), "postgresql");
final FlagDAO flagDAO = jdbi.onDemand(FlagDAO.class);
final NearbyFlagDAO nearbyFlagDAO = jdbi.onDemand(NearbyFlagDAO.class);
final PlayerDAO playerDAO = jdbi.onDemand(PlayerDAO.class);
final Client client = new JerseyClientBuilder(environment).using(configuration.getJerseyClientConfiguration())
.build(getName());
final String firebaseKey = configuration.getFirebaseKey();
environment.jersey().register(new FlagResource(flagDAO, nearbyFlagDAO, playerDAO, client, firebaseKey));
environment.jersey().register(new PlayerResource(playerDAO, flagDAO));
}
示例2: setup
import io.dropwizard.jdbi.DBIFactory; //導入依賴的package包/類
@Before
public void setup() throws Exception
{
DBIFactory factory = new DBIFactory();
Environment environment = new Environment("test", new ObjectMapper(), null, new MetricRegistry(), ClassLoader.getSystemClassLoader());
DataSourceFactory dataSourceFactory = new DataSourceFactory();
dataSourceFactory.setUrl("jdbc:hsqldb:mem:soa-jdbi;shutdown=true");
dataSourceFactory.setDriverClass("org.hsqldb.jdbc.JDBCDriver");
dataSourceFactory.setLogValidationErrors(true);
dataSourceFactory.setUser("SA");
dataSourceFactory.setValidationQuery("SELECT * FROM INFORMATION_SCHEMA.SYSTEM_TABLES");
DBI jdbi = factory.build(environment, dataSourceFactory, "test");
dynamicAttributes = new JdbiDynamicAttributes(jdbi, Collections.singletonList("test"));
dynamicAttributes.getDao().createTable();
dynamicAttributes.start();
}
示例3: JDBIManager
import io.dropwizard.jdbi.DBIFactory; //導入依賴的package包/類
/**
* @param shardService Your shard service.
* @param shardRegistry Your shard registry.
* @param dbiRegistry Your DBI registry.
* @param daoRegistry Your DAO registry.
* @param dropwizardDbiFactory Your dropwizard application's DBI Factory.
* @param dropwizardEnvironment Your dropwizard application's environment.
* @param dropwizardDSFactory Your dropwizard application's datasource factory.
* @param DBIInitializer We call your initializer immediately after dropwizardDbiFactory builds your
* DBI. @see jdbishard.jdbi.NoOpDBIInitializer.
* @param humanFriendlyShardNamer We register metrics for each shard connection given the human
* friendly name. @see jdbishard.sharding.IdOnlyShardNamer.
*/
@Inject
public JDBIManager(
ShardService<ShardIdT, KeyT> shardService,
ShardRegistry<ShardIdT, KeyT> shardRegistry,
DBIRegistry<ShardIdT> dbiRegistry,
DAORegistry<ShardIdT> daoRegistry,
DBIFactory dropwizardDbiFactory,
Environment dropwizardEnvironment,
DataSourceFactory dropwizardDSFactory,
DBIInitializer DBIInitializer,
HumanFriendlyShardNamer humanFriendlyShardNamer)
{
this.shardService = shardService;
this.shardRegistry = shardRegistry;
this.dbiRegistry = dbiRegistry;
this.daoRegistry = daoRegistry;
this.dropwizardDbiFactory = dropwizardDbiFactory;
this.dropwizardEnvironment = dropwizardEnvironment;
this.dropwizardDSFactory = dropwizardDSFactory;
this.DBIInitializer = DBIInitializer;
this.humanFriendlyShardNamer = humanFriendlyShardNamer;
}
示例4: run
import io.dropwizard.jdbi.DBIFactory; //導入依賴的package包/類
@Override
public void run(TestAppConfig configuration, Environment environment) throws Exception {
final ShardRegistry<String, UUID> shardRegistry = new ShardRegistry<>();
final DAORegistry<String> daoRegistry = new DAORegistry<>();
final DBIFactory dbiFactory = new DBIFactory();
jdbiManager = new JDBIManager<>(
new StaticShardService(),
shardRegistry,
new DBIRegistry<>(),
daoRegistry,
dbiFactory,
environment,
configuration.getDataSourceFactory(),
new NoOpDBIInitializer(),
new IdOnlyShardNamer());
clientDAO = new ClientDAO(shardRegistry, daoRegistry);
daoRegistry.registerType(ClientShardDAO.class);
jdbiManager.updateObjects();
}
示例5: createSampleResources
import io.dropwizard.jdbi.DBIFactory; //導入依賴的package包/類
private void createSampleResources(IronTestConfiguration configuration, Environment environment) {
final DBIFactory factory = new DBIFactory();
final DBI jdbi = factory.build(environment, configuration.getSampleDatabase(), "sampleDatabase");
// create DAO objects
final ArticleDAO articleDAO = jdbi.onDemand(ArticleDAO.class);
// create database tables
articleDAO.createTableIfNotExists();
// register APIs
environment.jersey().register(new ArticleResource(articleDAO));
// register SOAP web services
jaxWsBundle.publishEndpoint(new EndpointBuilder("/article", new ArticleSOAP(articleDAO)));
}
示例6: initializeStorage
import io.dropwizard.jdbi.DBIFactory; //導入依賴的package包/類
private IStorage initializeStorage(ReaperApplicationConfiguration config, Environment environment)
throws ReaperException {
IStorage storage;
if ("memory".equalsIgnoreCase(config.getStorageType())) {
storage = new MemoryStorage();
} else if ("cassandra".equalsIgnoreCase(config.getStorageType())) {
storage = new CassandraStorage(config, environment);
} else if ("postgres".equalsIgnoreCase(config.getStorageType())
|| "h2".equalsIgnoreCase(config.getStorageType())
|| "database".equalsIgnoreCase(config.getStorageType())) {
// create DBI instance
final DBIFactory factory = new DBIFactory();
// instanciate store
storage = new PostgresStorage(factory.build(environment, config.getDataSourceFactory(), "postgresql"));
initDatabase(config);
} else {
LOG.error("invalid storageType: {}", config.getStorageType());
throw new ReaperException("invalid storage type: " + config.getStorageType());
}
Preconditions.checkState(storage.isStorageConnected(), "Failed to connect storage");
return storage;
}
示例7: run
import io.dropwizard.jdbi.DBIFactory; //導入依賴的package包/類
@Override
public void run(PublicAuthConfiguration conf, Environment environment) throws Exception {
DataSourceFactory dataSourceFactory = conf.getDataSourceFactory();
jdbi = new DBIFactory().build(environment, dataSourceFactory, "postgresql");
initialiseMetrics(conf, environment);
TokenService tokenService = new TokenService(conf.getTokensConfiguration());
environment.jersey().register(new AuthDynamicFeature(
new OAuthCredentialAuthFilter.Builder<Token>()
.setAuthenticator(new TokenAuthenticator(tokenService))
.setPrefix("Bearer")
.buildAuthFilter()));
environment.jersey().register(new AuthValueFactoryProvider.Binder<>(Token.class));
environment.jersey().register(new PublicAuthResource(new AuthTokenDao(jdbi), tokenService));
environment.jersey().register(new HealthCheckResource(environment));
environment.jersey().register(new ValidationExceptionMapper());
environment.jersey().register(new TokenNotFoundExceptionMapper());
environment.healthChecks().register("database", new DatabaseHealthCheck(conf,environment));
environment.servlets().addFilter("LoggingFilter", new LoggingFilter())
.addMappingForUrlPatterns(of(REQUEST), true, "/v1" + "/*");
}
示例8: runService
import io.dropwizard.jdbi.DBIFactory; //導入依賴的package包/類
@Override
public void runService(final HmlJdbiConfiguration configuration, final Environment environment) throws Exception {
final DBIFactory factory = new DBIFactory();
final DBI jdbi = factory.build(environment, configuration.getDataSourceFactory(), "mysql");
final HmlDao hmlDao = jdbi.onDemand(HmlDao.class);
Injector injector = Guice.createInjector(new JdbiHmlServiceModule(), new AbstractModule() {
@Override
protected void configure() {
bind(HmlDao.class).toInstance(hmlDao);
}
});
environment.healthChecks().register("database", new DBIHealthCheck(jdbi, "select 1"));
environment.jersey().register(injector.getInstance(HmlResource.class));
environment.jersey().register(new HmlExceptionMapper());
environment.jersey().register(new HmlMessageBodyReader());
environment.getObjectMapper().enable(SerializationFeature.INDENT_OUTPUT);
}
示例9: run
import io.dropwizard.jdbi.DBIFactory; //導入依賴的package包/類
@Override
public void run(final ServiceRegistryConfiguration configuration, final Environment environment) throws Exception {
final DataSourceFactory database = configuration.getDatabase();
// execute DB migrations
final Flyway flyway = new Flyway();
flyway.setDataSource(database.getUrl(), database.getUser(), database.getPassword());
log.debug("execute database migrations");
flyway.migrate();
log.info("database migrations successfully executed");
// create DBI instance
final DBIFactory factory = new DBIFactory();
final DBI jdbi = factory.build(environment, database, "postgresql");
environment.jersey().register(AuthFactory.binder(new BasicAuthFactory<>(
new ServiceRegistryAuthenticator(configuration.getCredentials()), "Realm", ServiceRegistryCaller.class))
);
environment.jersey().register(new ServiceResource(jdbi.onDemand(ServiceDAO.class)));
}
示例10: run
import io.dropwizard.jdbi.DBIFactory; //導入依賴的package包/類
@Override
public void run(SentimentalConfiguration configuration, Environment environment) {
final TemplateHealthCheck healthCheck = new TemplateHealthCheck(configuration.getTemplate());
environment.healthChecks().register("template", healthCheck);
// SPI Lexicon
final Lexicon lexicon = new FileBasedLexicon(configuration.getLexiconFileName());
// SPI Trend
final DBIFactory factory = new DBIFactory();
final DBI jdbi = factory.build(environment, configuration.getDataSourceFactory(), "postgresql");
final AuditDAO auditDao = jdbi.onDemand(AuditDAO.class);
final Trend audit = new TrendRepository(auditDao);
// Domain Model
final SentimentAnalysis service = new SentimentAnalysis(lexicon, audit);
// API RESTful
final SentimentalResource resource = new SentimentalResource(service);
environment.jersey().register(resource);
// API Twitter
final TwitterAdapter twitterAdapter = new TwitterAdapter(service, new SamplePlayer());
twitterAdapter.subscribe("devoxx, #memepasmal, @cyriux, @tpierrain, arolla");
// start
}
示例11: runService
import io.dropwizard.jdbi.DBIFactory; //導入依賴的package包/類
@Override
public void runService(final FeatureJdbiConfiguration configuration, final Environment environment) throws Exception {
final DBIFactory factory = new DBIFactory();
final DBI jdbi = factory.build(environment, configuration.getDataSourceFactory(), "mysql");
final FeatureDao featureDao = jdbi.onDemand(FeatureDao.class);
Injector injector = Guice.createInjector(new JdbiFeatureServiceModule(), new ExceptionMapperModule(),
new AbstractModule() {
@Override
protected void configure() {
bind(FeatureDao.class).toInstance(featureDao);
}
});
environment.healthChecks().register("database", new DBIHealthCheck(jdbi, "select 1"));
environment.jersey().register(injector.getInstance(FeatureResource.class));
environment.jersey().register(injector.getInstance(UserInputExceptionMapper.class));
environment.getObjectMapper()
.enable(SerializationFeature.INDENT_OUTPUT)
.addMixInAnnotations(Feature.class, FeatureMixIn.class);
}
示例12: run
import io.dropwizard.jdbi.DBIFactory; //導入依賴的package包/類
public void run(MyApplicationConfiguration configuration,
Environment environment) throws ClassNotFoundException {
// create database connection using JDBI
final DBIFactory factory = new DBIFactory();
final DataSourceFactory dataSourceFactory = configuration.getDataSourceFactory();
final DBI jdbi = factory.build(environment, dataSourceFactory, "derby");
// add resources
final UserDAO dao = jdbi.onDemand(UserDAO.class);
try {
dao.createUserTable();
logger.info("User table created");
} catch (Exception e) {
// probably the table already exists. Don't worry about it.
if (e.getCause().getMessage().contains("already exists in Schema")) {
logger.info("User table already exists.");
} else {
logger.log(Level.INFO, "User DB was not created", e);
}
}
environment.jersey().register(new UserResourceImpl(dao));
}
示例13: run
import io.dropwizard.jdbi.DBIFactory; //導入依賴的package包/類
@Override
public void run(HelloConfiguration configuration, Environment environment) throws ClassNotFoundException {
final DBI dbi = new DBIFactory().build(environment, configuration.getDataSourceFactory(), "h2");
final NameDAO nameDAO = dbi.onDemand(NameDAO.class);
final ObjectGraph objectGraph = ObjectGraph.create(new HelloModule(configuration, nameDAO));
initializeDatabase(dbi);
/*
* API:
* GET -> String /hello
* GET -> String /hello?name={name}
* GET -> JSON /hello/all
* GET -> JSON /hello/{id}
* POST -> JSON /hello/add
*/
environment.jersey().register(objectGraph.get(NameResource.class));
}
示例14: run
import io.dropwizard.jdbi.DBIFactory; //導入依賴的package包/類
@Override
public void run(ThmmyRssConfiguration configuration, Environment env)
throws Exception {
client = new JerseyClientBuilder(env).using(configuration.getJerseyClientConfiguration()).using(env)
.withProperty("PROPERTY_CHUNKED_ENCODING_SIZE", 0).build("jersey-client");
DBIFactory factory = new DBIFactory();
DBI jdbi = factory.build(env, configuration.getDatabase(), "announcement-db");
announcementDAO = jdbi.onDemand(AnnouncementDAO.class);
tryCreateAnnouncementTable();
AnnouncementFetcher announcementFetcher = new AnnouncementFetcher(client, configuration);
env.healthChecks().register("announcement-fetcher-health", new AnnouncementFetcherHealthCheck(configuration, announcementFetcher));
this.announcementService = new AnnouncementServiceImpl(announcementDAO, announcementFetcher, configuration);
env.jersey().register(new FeedResource(announcementService, configuration));
env.jersey().register(new IndexResource(configuration));
}
示例15: run
import io.dropwizard.jdbi.DBIFactory; //導入依賴的package包/類
@Override
protected void run(Environment env, Namespace namespace, T configuration) throws Exception {
CliConveniences.quietLogging("ifar", "hsqldb.db");
final DBIFactory factory = new DBIFactory();
final DBI jdbi = factory.build(env, getSkidRoadReadOnlyConfiguration(configuration).getDatabaseConfiguration(), "logfile");
JDBILogFileDAO dao = jdbi.onDemand(DefaultJDBILogFileDAO.class);
List<CountByState> counts = dao.countLogFilesByState();
if (!counts.isEmpty()) {
System.out.println(String.format("%-20s | %-10s", "STATE", "COUNT"));
System.out.println(String.format("%s_|_%s", StringUtils.repeat("_", 20), StringUtils.repeat("_", 10)));
}
for (CountByState cbs : counts) {
System.out.println(String.format("%-20s | %-10d", cbs.getState(), cbs.getCount()));
}
}