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

com.taotao.boot.data.shardingsphere.configuration.ShardingJdbcAutoConfiguration Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (c) 2020-2030, Shuigedeng ([email protected] & https://blog.taotaocloud.top/).
 *
 * 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 com.taotao.boot.data.shardingsphere.configuration;

import com.taotao.boot.common.constant.StarterName;
import com.taotao.boot.common.utils.log.LogUtils;
import com.taotao.boot.data.shardingsphere.algorithm.DataSourceShardingAlgorithm;
import com.taotao.boot.data.shardingsphere.properties.ShardingJdbcProperties;
import org.springframework.beans.BeansException;
import org.springframework.beans.factory.InitializingBean;
import org.springframework.boot.autoconfigure.AutoConfiguration;
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
import org.springframework.boot.context.properties.EnableConfigurationProperties;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import org.springframework.context.annotation.Bean;

/**
 * ShardingJdbcConfiguration
 *
 * @author shuigedeng
 * @version 2021.9
 * @since 2021-09-07 20:54:47
 */
@AutoConfiguration
@EnableConfigurationProperties({ShardingJdbcProperties.class})
@ConditionalOnProperty(prefix = ShardingJdbcProperties.PREIX, name = "enabled", havingValue = "true")
public class ShardingJdbcAutoConfiguration implements ApplicationContextAware, InitializingBean {

    @Override
    public void afterPropertiesSet() throws Exception {
        LogUtils.started(ShardingJdbcAutoConfiguration.class, StarterName.DATA_SHARDINGSPHERE_STARTER);
    }

    @Override
    public void setApplicationContext(ApplicationContext context) throws BeansException {
        // super.setEnvironment(context.getEnvironment());
    }

    // @ConstructorProperties({
    //	"shardingRule",
    //	"masterSlaveRule",
    //	"encryptRule",
    //	"shadowRule",
    //	"props"
    // })
    // public ShardingJdbcConfiguration(
    //	SpringBootShardingRuleConfigurationProperties shardingRule,
    //	SpringBootMasterSlaveRuleConfigurationProperties masterSlaveRule,
    //	SpringBootEncryptRuleConfigurationProperties encryptRule,
    //	SpringBootShadowRuleConfigurationProperties shadowRule,
    //	SpringBootPropertiesConfigurationProperties props) {
    //	super(shardingRule, masterSlaveRule, encryptRule, shadowRule, props);
    // }

    @Bean
    public DataSourceShardingAlgorithm dataSourceShardingAlgorithm() {
        return new DataSourceShardingAlgorithm();
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy