-
Notifications
You must be signed in to change notification settings - Fork 141
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Move DataSourceServiceImpl to core module (#1084)
Signed-off-by: Peng Huo <penghuo@gmail.com>
- Loading branch information
Showing
24 changed files
with
686 additions
and
448 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
99 changes: 99 additions & 0 deletions
99
core/src/main/java/org/opensearch/sql/datasource/DataSourceServiceImpl.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,99 @@ | ||
/* | ||
* Copyright OpenSearch Contributors | ||
* SPDX-License-Identifier: Apache-2.0 | ||
*/ | ||
|
||
package org.opensearch.sql.datasource; | ||
|
||
import com.google.common.base.Preconditions; | ||
import com.google.common.base.Strings; | ||
import java.util.Map; | ||
import java.util.Objects; | ||
import java.util.Set; | ||
import java.util.concurrent.ConcurrentHashMap; | ||
import java.util.stream.Collectors; | ||
import org.opensearch.sql.common.utils.StringUtils; | ||
import org.opensearch.sql.datasource.model.DataSource; | ||
import org.opensearch.sql.datasource.model.DataSourceMetadata; | ||
import org.opensearch.sql.datasource.model.DataSourceType; | ||
import org.opensearch.sql.storage.DataSourceFactory; | ||
|
||
/** | ||
* Default implementation of {@link DataSourceService}. It is per-jvm single instance. | ||
* | ||
* <p>{@link DataSourceService} is constructed by the list of {@link DataSourceFactory} at service | ||
* bootstrap time. The set of {@link DataSourceFactory} is immutable. Client could add {@link | ||
* DataSource} defined by {@link DataSourceMetadata} at any time. {@link DataSourceService} use | ||
* {@link DataSourceFactory} to create {@link DataSource}. | ||
*/ | ||
public class DataSourceServiceImpl implements DataSourceService { | ||
|
||
private static String DATASOURCE_NAME_REGEX = "[@*A-Za-z]+?[*a-zA-Z_\\-0-9]*"; | ||
|
||
private final ConcurrentHashMap<String, DataSource> dataSourceMap; | ||
|
||
private final Map<DataSourceType, DataSourceFactory> dataSourceFactoryMap; | ||
|
||
/** | ||
* Construct from the set of {@link DataSourceFactory} at bootstrap time. | ||
*/ | ||
public DataSourceServiceImpl(Set<DataSourceFactory> dataSourceFactories) { | ||
dataSourceFactoryMap = | ||
dataSourceFactories.stream() | ||
.collect(Collectors.toMap(DataSourceFactory::getDataSourceType, f -> f)); | ||
dataSourceMap = new ConcurrentHashMap<>(); | ||
} | ||
|
||
@Override | ||
public Set<DataSource> getDataSources() { | ||
return Set.copyOf(dataSourceMap.values()); | ||
} | ||
|
||
@Override | ||
public DataSource getDataSource(String dataSourceName) { | ||
if (!dataSourceMap.containsKey(dataSourceName)) { | ||
throw new IllegalArgumentException( | ||
String.format("DataSource with name %s doesn't exist.", dataSourceName)); | ||
} | ||
return dataSourceMap.get(dataSourceName); | ||
} | ||
|
||
@Override | ||
public void addDataSource(DataSourceMetadata... metadatas) { | ||
for (DataSourceMetadata metadata : metadatas) { | ||
validateDataSourceMetaData(metadata); | ||
dataSourceMap.put( | ||
metadata.getName(), | ||
dataSourceFactoryMap.get(metadata.getConnector()).createDataSource(metadata)); | ||
} | ||
} | ||
|
||
@Override | ||
public void clear() { | ||
dataSourceMap.clear(); | ||
} | ||
|
||
/** | ||
* This can be moved to a different validator class when we introduce more connectors. | ||
* | ||
* @param metadata {@link DataSourceMetadata}. | ||
*/ | ||
private void validateDataSourceMetaData(DataSourceMetadata metadata) { | ||
Preconditions.checkArgument( | ||
!Strings.isNullOrEmpty(metadata.getName()), | ||
"Missing Name Field from a DataSource. Name is a required parameter."); | ||
Preconditions.checkArgument( | ||
!dataSourceMap.containsKey(metadata.getName()), | ||
StringUtils.format( | ||
"Datasource name should be unique, Duplicate datasource found %s.", | ||
metadata.getName())); | ||
Preconditions.checkArgument( | ||
metadata.getName().matches(DATASOURCE_NAME_REGEX), | ||
StringUtils.format( | ||
"DataSource Name: %s contains illegal characters. Allowed characters: a-zA-Z0-9_-*@.", | ||
metadata.getName())); | ||
Preconditions.checkArgument( | ||
!Objects.isNull(metadata.getProperties()), | ||
"Missing properties field in catalog configuration. Properties are required parameters."); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
31 changes: 31 additions & 0 deletions
31
core/src/main/java/org/opensearch/sql/storage/DataSourceFactory.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,31 @@ | ||
/* | ||
* | ||
* * Copyright OpenSearch Contributors | ||
* * SPDX-License-Identifier: Apache-2.0 | ||
* | ||
*/ | ||
|
||
package org.opensearch.sql.storage; | ||
|
||
import org.opensearch.sql.datasource.DataSourceService; | ||
import org.opensearch.sql.datasource.model.DataSource; | ||
import org.opensearch.sql.datasource.model.DataSourceMetadata; | ||
import org.opensearch.sql.datasource.model.DataSourceType; | ||
|
||
/** | ||
* {@link DataSourceFactory} is used to create {@link DataSource} from {@link DataSourceMetadata}. | ||
* Each data source define {@link DataSourceFactory} and register to {@link DataSourceService}. | ||
* {@link DataSourceFactory} is one instance per JVM . Each {@link DataSourceType} mapping to one | ||
* {@link DataSourceFactory}. | ||
*/ | ||
public interface DataSourceFactory { | ||
/** | ||
* Get {@link DataSourceType}. | ||
*/ | ||
DataSourceType getDataSourceType(); | ||
|
||
/** | ||
* Create {@link DataSource}. | ||
*/ | ||
DataSource createDataSource(DataSourceMetadata metadata); | ||
} |
19 changes: 0 additions & 19 deletions
19
core/src/main/java/org/opensearch/sql/storage/StorageEngineFactory.java
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.