/* * Copyright (c) 2020 pig4cloud Authors. All Rights Reserved. * * 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 com.pig4cloud.pig.common.datasource.config; import com.baomidou.dynamic.datasource.creator.DataSourceProperty; import com.baomidou.dynamic.datasource.creator.DefaultDataSourceCreator; import com.baomidou.dynamic.datasource.provider.AbstractJdbcDataSourceProvider; import com.pig4cloud.pig.common.datasource.support.DataSourceConstants; import org.jasypt.encryption.StringEncryptor; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import java.util.HashMap; import java.util.Map; /** * @author lengleng * @date 2020/2/6 *

* 从数据源中获取 配置信息 */ public class JdbcDynamicDataSourceProvider extends AbstractJdbcDataSourceProvider { private final DataSourceProperties properties; private final StringEncryptor stringEncryptor; public JdbcDynamicDataSourceProvider(DefaultDataSourceCreator defaultDataSourceCreator, StringEncryptor stringEncryptor, DataSourceProperties properties) { super(defaultDataSourceCreator, properties.getDriverClassName(), properties.getUrl(), properties.getUsername(), properties.getPassword()); this.stringEncryptor = stringEncryptor; this.properties = properties; } /** * 执行语句获得数据源参数 * @param statement 语句 * @return 数据源参数 * @throws SQLException sql异常 */ @Override protected Map executeStmt(Statement statement) throws SQLException { ResultSet rs = statement.executeQuery(properties.getQueryDsSql()); Map map = new HashMap<>(8); while (rs.next()) { String name = rs.getString(DataSourceConstants.DS_NAME); String username = rs.getString(DataSourceConstants.DS_USER_NAME); String password = rs.getString(DataSourceConstants.DS_USER_PWD); String url = rs.getString(DataSourceConstants.DS_JDBC_URL); DataSourceProperty property = new DataSourceProperty(); property.setUsername(username); property.setLazy(true); property.setPassword(stringEncryptor.decrypt(password)); property.setUrl(url); map.put(name, property); } // 添加默认主数据源 DataSourceProperty property = new DataSourceProperty(); property.setUsername(properties.getUsername()); property.setPassword(properties.getPassword()); property.setUrl(properties.getUrl()); property.setLazy(true); map.put(DataSourceConstants.DS_MASTER, property); return map; } }