View Javadoc
1   /*
2    * Licensed to the Apache Software Foundation (ASF) under one or more
3    * contributor license agreements.  See the NOTICE file distributed with
4    * this work for additional information regarding copyright ownership.
5    * The ASF licenses this file to You under the Apache License, Version 2.0
6    * (the "License"); you may not use this file except in compliance with
7    * the License.  You may obtain a copy of the License at
8    *
9    *     http://www.apache.org/licenses/LICENSE-2.0
10   *
11   * Unless required by applicable law or agreed to in writing, software
12   * distributed under the License is distributed on an "AS IS" BASIS,
13   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14   * See the License for the specific language governing permissions and
15   * limitations under the License.
16   */
17  
18  package org.apache.shardingsphere.infra.database.core.type;
19  
20  import lombok.Getter;
21  import org.apache.shardingsphere.infra.database.core.metadata.database.DialectDatabaseMetaData;
22  import org.apache.shardingsphere.infra.database.core.spi.DatabaseTypedSPILoader;
23  import org.apache.shardingsphere.infra.spi.ShardingSphereServiceLoader;
24  
25  import java.util.Collection;
26  import java.util.Map;
27  import java.util.concurrent.ConcurrentHashMap;
28  import java.util.stream.Collectors;
29  
30  /**
31   * Database type registry.
32   */
33  public final class DatabaseTypeRegistry {
34      
35      private static final Map<DatabaseType, DialectDatabaseMetaData> REGISTERED_META_DATA = new ConcurrentHashMap<>();
36      
37      private final DatabaseType databaseType;
38      
39      @Getter
40      private final DialectDatabaseMetaData dialectDatabaseMetaData;
41      
42      public DatabaseTypeRegistry(final DatabaseType databaseType) {
43          this.databaseType = databaseType;
44          if (!REGISTERED_META_DATA.containsKey(databaseType)) {
45              REGISTERED_META_DATA.put(databaseType, DatabaseTypedSPILoader.getService(DialectDatabaseMetaData.class, databaseType));
46          }
47          dialectDatabaseMetaData = REGISTERED_META_DATA.get(databaseType);
48      }
49      
50      /**
51       * Get all branch database types.
52       * 
53       * @return all branch database types
54       */
55      public Collection<DatabaseType> getAllBranchDatabaseTypes() {
56          return ShardingSphereServiceLoader.getServiceInstances(DatabaseType.class)
57                  .stream().filter(each -> each.getTrunkDatabaseType().map(optional -> optional == databaseType).orElse(false)).collect(Collectors.toList());
58      }
59      
60      /**
61       * Get default schema name.
62       *
63       * @param databaseName database name
64       * @return default schema name
65       */
66      public String getDefaultSchemaName(final String databaseName) {
67          return dialectDatabaseMetaData.getDefaultSchema().orElseGet(() -> null == databaseName ? null : databaseName.toLowerCase());
68      }
69  }