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

io.shardingsphere.core.rule.ShardingDataSourceNames Maven / Gradle / Ivy

/*
 * Copyright 2016-2018 shardingsphere.io.
 * 

* 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 io.shardingsphere.core.rule; import io.shardingsphere.core.api.config.MasterSlaveRuleConfiguration; import io.shardingsphere.core.api.config.ShardingRuleConfiguration; import lombok.Getter; import java.util.Collection; import java.util.LinkedHashSet; /** * Sharding data source names. * *

Will convert actual data source names to master-slave data source name.

* * @author zhangliang */ public final class ShardingDataSourceNames { private final ShardingRuleConfiguration shardingRuleConfig; @Getter private final Collection dataSourceNames; public ShardingDataSourceNames(final ShardingRuleConfiguration shardingRuleConfig, final Collection rawDataSourceNames) { this.shardingRuleConfig = shardingRuleConfig; dataSourceNames = getAllDataSourceNames(rawDataSourceNames); } private Collection getAllDataSourceNames(final Collection dataSourceNames) { Collection result = new LinkedHashSet<>(dataSourceNames); for (MasterSlaveRuleConfiguration each : shardingRuleConfig.getMasterSlaveRuleConfigs()) { result.remove(each.getMasterDataSourceName()); result.removeAll(each.getSlaveDataSourceNames()); result.add(each.getName()); } return result; } /** * Get default data source name. * * @return default data source name */ public String getDefaultDataSourceName() { return 1 == dataSourceNames.size() ? dataSourceNames.iterator().next() : shardingRuleConfig.getDefaultDataSourceName(); } /** * Get raw master data source name. * * @param dataSourceName data source name * @return raw master data source name */ public String getRawMasterDataSourceName(final String dataSourceName) { for (MasterSlaveRuleConfiguration each : shardingRuleConfig.getMasterSlaveRuleConfigs()) { if (each.getName().equals(dataSourceName)) { return each.getMasterDataSourceName(); } } return dataSourceName; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy