Skip to content

Commit

Permalink
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'devel' into CB-5955-add-create-connection-folder-action…
Browse files Browse the repository at this point in the history
…s-in-navigator-tree
sergeyteleshev committed Dec 16, 2024
2 parents c758e33 + 522620e commit c42b1a1
Showing 6 changed files with 40 additions and 9 deletions.
Original file line number Diff line number Diff line change
@@ -45,9 +45,9 @@

public class WebDataSourceRegistryProxy implements DBPDataSourceRegistry, DataSourcePersistentRegistry, DBPDataSourceRegistryCache {
private final DataSourceFilter dataSourceFilter;
private final DataSourceRegistry dataSourceRegistry;
private final DataSourceRegistry<?> dataSourceRegistry;

public WebDataSourceRegistryProxy(DataSourceRegistry dataSourceRegistry, DataSourceFilter filter) {
public WebDataSourceRegistryProxy(DataSourceRegistry<?> dataSourceRegistry, DataSourceFilter filter) {
this.dataSourceRegistry = dataSourceRegistry;
this.dataSourceFilter = filter;
}
@@ -113,6 +113,26 @@ public DBPDataSourceContainer createDataSource(@NotNull DBPDriver driver, @NotNu
return dataSourceRegistry.createDataSource(driver, connConfig);
}

@Override
public DBPDataSourceContainer createDataSource(
@NotNull String id,
@NotNull DBPDriver driver,
@NotNull DBPConnectionConfiguration connConfig
) {
return dataSourceRegistry.createDataSource(id, driver, connConfig);
}

@Override
public DBPDataSourceContainer createDataSource(
@NotNull DBPDataSourceConfigurationStorage dataSourceStorage,
@NotNull DBPDataSourceOrigin origin,
@NotNull String id,
@NotNull DBPDriver driver,
@NotNull DBPConnectionConfiguration configuration
) {
return dataSourceRegistry.createDataSource(dataSourceStorage, origin, id, driver, configuration);
}

@NotNull
@Override
public DBPDataSourceContainer createDataSource(@NotNull DBPDataSourceContainer source) {
Original file line number Diff line number Diff line change
@@ -27,6 +27,7 @@
import org.jkiss.dbeaver.model.rm.RMController;
import org.jkiss.dbeaver.model.rm.RMProject;
import org.jkiss.dbeaver.model.task.DBTTaskManager;
import org.jkiss.dbeaver.registry.DataSourceRegistry;
import org.jkiss.dbeaver.registry.rm.DataSourceRegistryRM;
import org.jkiss.dbeaver.runtime.DBWorkbench;

@@ -84,11 +85,15 @@ public DBTTaskManager getTaskManager() {
@Override
protected DBPDataSourceRegistry createDataSourceRegistry() {
return new WebDataSourceRegistryProxy(
new DataSourceRegistryRM(this, getResourceController(), preferenceStore),
createRMRegistry(),
getDataSourceFilter()
);
}

protected DataSourceRegistry<?> createRMRegistry() {
return new DataSourceRegistryRM<>(this, getResourceController(), preferenceStore);
}

@NotNull
public DataSourceFilter getDataSourceFilter() {
return (ds) -> true;
Original file line number Diff line number Diff line change
@@ -34,6 +34,7 @@

import java.nio.file.Path;
import java.util.*;
import java.util.function.Function;
import java.util.stream.Collectors;

public class WebSessionProjectImpl extends WebProjectImpl {
@@ -199,8 +200,8 @@ public synchronized boolean updateProjectDataSources(@NotNull List<String> dataS
.filter(Objects::nonNull)
.collect(Collectors.toMap(
DBPDataSourceContainer::getId,
ds -> new DataSourceDescriptor((DataSourceDescriptor) ds, ds.getRegistry())
));
Function.identity())
);
if (type == WSEventType.DATASOURCE_CREATED || type == WSEventType.DATASOURCE_UPDATED) {
registry.refreshConfig(dataSourceIds);
}
Original file line number Diff line number Diff line change
@@ -316,7 +316,7 @@ private WebSessionProjectImpl createWebProject(RMProject project) throws DBExcep
if (project.isGlobal()) {
sessionProject = createGlobalProject(project);
} else {
sessionProject = new WebSessionProjectImpl(this, project, getProjectPath(project));
sessionProject = createSessionProject(project);
}
// do not load data sources for anonymous project
if (project.getType() == RMProjectType.USER && userContext.getUser() == null) {
@@ -329,6 +329,10 @@ private WebSessionProjectImpl createWebProject(RMProject project) throws DBExcep
return sessionProject;
}

protected WebSessionProjectImpl createSessionProject(@NotNull RMProject project) throws DBException {
return new WebSessionProjectImpl(this, project, getProjectPath(project));
}

@NotNull
protected Path getProjectPath(@NotNull RMProject project) throws DBException {
return RMUtils.getProjectPath(project);
Original file line number Diff line number Diff line change
@@ -80,6 +80,6 @@ public boolean isUseSecretStorage() {
@NotNull
@Override
protected DBPDataSourceRegistry createDataSourceRegistry() {
return new DataSourceRegistry(this);
return new DataSourceRegistry<>(this);
}
}
Original file line number Diff line number Diff line change
@@ -505,8 +505,9 @@ public WebConnectionInfo updateConnection(
WebConnectionInfo connectionInfo = WebDataSourceUtils.getWebConnectionInfo(webSession, projectId, config.getConnectionId());
DBPDataSourceContainer dataSource = connectionInfo.getDataSourceContainer();
webSession.addInfoMessage("Update connection - " + WebServiceUtils.getConnectionContainerInfo(dataSource));
var oldDataSource = new DataSourceDescriptor((DataSourceDescriptor) dataSource, dataSource.getRegistry());

DataSourceDescriptor oldDataSource;
oldDataSource = dataSource.getRegistry().createDataSource(dataSource);
oldDataSource.setId(dataSource.getId());
if (!CommonUtils.isEmpty(config.getName())) {
dataSource.setName(config.getName());
}

0 comments on commit c42b1a1

Please sign in to comment.