/*
* Copyright 2016 Red Hat, Inc. and/or its affiliates.
*
* 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 org.kie.workbench.common.screens.datasource.management.backend.core.impl;
import java.util.Properties;
import javax.annotation.PostConstruct;
import javax.enterprise.context.ApplicationScoped;
import javax.enterprise.inject.spi.BeanManager;
import javax.inject.Inject;
import org.kie.workbench.common.screens.datasource.management.backend.core.DataSourceProvider;
import org.kie.workbench.common.screens.datasource.management.backend.core.DataSourceProviderFactory;
import org.kie.workbench.common.screens.datasource.management.backend.core.DataSourceSettings;
import org.kie.workbench.common.screens.datasource.management.backend.core.DriverProvider;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import static org.kie.workbench.common.screens.datasource.management.backend.core.DataSourceSettings.*;
import static org.kie.workbench.common.screens.datasource.management.util.ServiceUtil.*;
/**
* CDI based implementation of a DataSourceProviderFactory.
*/
@ApplicationScoped
public class DataSourceProviderFactoryImpl
implements DataSourceProviderFactory
{
private static final Logger logger = LoggerFactory.getLogger( DataSourceProviderFactoryImpl.class );
private static final String DATASOURCE_SERVICE = DATASOURCE_MANAGEMENT_PREFIX +".DataSourceProvider";
private static final String DRIVER_SERVICE = DATASOURCE_MANAGEMENT_PREFIX + ".DriverProvider";
@Inject
private BeanManager beanManager;
private DataSourceProvider dataSourceProvider;
private DriverProvider driverService;
@PostConstruct
public void init() {
Properties properties = DataSourceSettings.getInstance().getProperties();
String serviceName = getManagedProperty( properties, DATASOURCE_SERVICE );
if ( !isEmpty( serviceName ) ) {
try {
dataSourceProvider = ( DataSourceProvider ) getManagedBean( beanManager, serviceName );
if ( dataSourceProvider == null ) {
logger.error( "It was not possible to get the reference to the data sources service: "
+ serviceName + ". Data source services won't be available." );
} else {
dataSourceProvider.loadConfig( properties );
}
} catch ( Exception e ) {
logger.error( "An error was produced during: " + serviceName + " initialization.", e);
}
} else {
logger.warn( "Data source serviceName: " + DATASOURCE_SERVICE +
" property was not properly configured. Data source services won't be available." );
}
serviceName = getManagedProperty( properties, DRIVER_SERVICE );
if ( !isEmpty( serviceName ) ) {
try {
driverService = ( DriverProvider ) getManagedBean( beanManager, serviceName );
if ( driverService == null ) {
logger.error( "It was not possible to get reference to the drivers service: "
+ serviceName + ". Drivers services won't be available." );
} else {
driverService.loadConfig( properties );
}
} catch ( Exception e ) {
logger.error( "An error was produced during: " + serviceName + " initialization.", e );
}
} else {
logger.warn( "Drivers serviceName: " + DRIVER_SERVICE +
" property was not properly configured. Drivers services won't be available." );
}
if ( dataSourceProvider != null ) {
logger.debug( "Data source service was properly initialized." );
}
if ( driverService != null ) {
logger.debug( "Drivers service was properly initialized." );
}
}
@Override
public DataSourceProvider getDataSourceProvider() {
return dataSourceProvider;
}
@Override
public DriverProvider getDriverProvider() {
return driverService;
}
}