All Downloads are FREE. Search and download functionalities are using the official Maven repository.
Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
io.trino.connector.CatalogServiceProviderModule Maven / Gradle / Ivy
/*
* 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.trino.connector;
import com.google.inject.Binder;
import com.google.inject.Inject;
import com.google.inject.Module;
import com.google.inject.Provides;
import com.google.inject.Singleton;
import io.trino.SystemSessionPropertiesProvider;
import io.trino.metadata.AnalyzePropertyManager;
import io.trino.metadata.CatalogProcedures;
import io.trino.metadata.CatalogTableFunctions;
import io.trino.metadata.CatalogTableProcedures;
import io.trino.metadata.ColumnPropertyManager;
import io.trino.metadata.MaterializedViewPropertyManager;
import io.trino.metadata.SchemaPropertyManager;
import io.trino.metadata.SessionPropertyManager;
import io.trino.metadata.TableProceduresPropertyManager;
import io.trino.metadata.TablePropertyManager;
import io.trino.metadata.ViewPropertyManager;
import io.trino.security.AccessControlManager;
import io.trino.spi.connector.ConnectorAccessControl;
import io.trino.spi.connector.ConnectorIndexProvider;
import io.trino.spi.connector.ConnectorNodePartitioningProvider;
import io.trino.spi.connector.ConnectorPageSinkProvider;
import io.trino.spi.connector.ConnectorPageSourceProviderFactory;
import io.trino.spi.connector.ConnectorSplitManager;
import io.trino.spi.function.FunctionProvider;
import java.util.Optional;
import java.util.Set;
public class CatalogServiceProviderModule
implements Module
{
@Override
public void configure(Binder binder)
{
binder.bind(ConnectorAccessControlLazyRegister.class).asEagerSingleton();
}
@Provides
@Singleton
public static CatalogServiceProvider createSplitManagerProvider(ConnectorServicesProvider connectorServicesProvider)
{
return new ConnectorCatalogServiceProvider<>("split manager", connectorServicesProvider, connector -> connector.getSplitManager().orElse(null));
}
@Provides
@Singleton
public static CatalogServiceProvider createPageSourceProviderFactory(ConnectorServicesProvider connectorServicesProvider)
{
return new ConnectorCatalogServiceProvider<>("page source provider factory", connectorServicesProvider, connector -> connector.getPageSourceProviderFactory().orElse(null));
}
@Provides
@Singleton
public static CatalogServiceProvider createPageSinkProvider(ConnectorServicesProvider connectorServicesProvider)
{
return new ConnectorCatalogServiceProvider<>("page sink provider", connectorServicesProvider, connector -> connector.getPageSinkProvider().orElse(null));
}
@Provides
@Singleton
public static CatalogServiceProvider createIndexProvider(ConnectorServicesProvider connectorServicesProvider)
{
return new ConnectorCatalogServiceProvider<>("index provider", connectorServicesProvider, connector -> connector.getIndexProvider().orElse(null));
}
@Provides
@Singleton
public static CatalogServiceProvider createNodePartitioningProvider(ConnectorServicesProvider connectorServicesProvider)
{
return new ConnectorCatalogServiceProvider<>("node partitioning provider", connectorServicesProvider, connector -> connector.getPartitioningProvider().orElse(null));
}
@Provides
@Singleton
public static CatalogServiceProvider createProceduresProvider(ConnectorServicesProvider connectorServicesProvider)
{
return new ConnectorCatalogServiceProvider<>("procedures", connectorServicesProvider, ConnectorServices::getProcedures);
}
@Provides
@Singleton
public static CatalogServiceProvider createTableProceduresProvider(ConnectorServicesProvider connectorServicesProvider)
{
return new ConnectorCatalogServiceProvider<>("table procedures", connectorServicesProvider, ConnectorServices::getTableProcedures);
}
@Provides
@Singleton
public static CatalogServiceProvider createTableFunctionProvider(ConnectorServicesProvider connectorServicesProvider)
{
return new ConnectorCatalogServiceProvider<>("table functions", connectorServicesProvider, ConnectorServices::getTableFunctions);
}
@Provides
@Singleton
public static SessionPropertyManager createSessionPropertyManager(Set systemSessionProperties, ConnectorServicesProvider connectorServicesProvider)
{
return new SessionPropertyManager(systemSessionProperties, new ConnectorCatalogServiceProvider<>("session properties", connectorServicesProvider, ConnectorServices::getSessionProperties));
}
@Provides
@Singleton
public static SchemaPropertyManager createSchemaPropertyManager(ConnectorServicesProvider connectorServicesProvider)
{
return new SchemaPropertyManager(new ConnectorCatalogServiceProvider<>("schema properties", connectorServicesProvider, ConnectorServices::getSchemaProperties));
}
@Provides
@Singleton
public static ColumnPropertyManager createColumnPropertyManager(ConnectorServicesProvider connectorServicesProvider)
{
return new ColumnPropertyManager(new ConnectorCatalogServiceProvider<>("column properties", connectorServicesProvider, ConnectorServices::getColumnProperties));
}
@Provides
@Singleton
public static TablePropertyManager createTablePropertyManager(ConnectorServicesProvider connectorServicesProvider)
{
return new TablePropertyManager(new ConnectorCatalogServiceProvider<>("table properties", connectorServicesProvider, ConnectorServices::getTableProperties));
}
@Provides
@Singleton
public static ViewPropertyManager createViewPropertyManager(ConnectorServicesProvider connectorServicesProvider)
{
return new ViewPropertyManager(new ConnectorCatalogServiceProvider<>("view properties", connectorServicesProvider, ConnectorServices::getViewProperties));
}
@Provides
@Singleton
public static MaterializedViewPropertyManager createMaterializedViewPropertyManager(ConnectorServicesProvider connectorServicesProvider)
{
return new MaterializedViewPropertyManager(new ConnectorCatalogServiceProvider<>("materialized view properties", connectorServicesProvider, ConnectorServices::getMaterializedViewProperties));
}
@Provides
@Singleton
public static AnalyzePropertyManager createAnalyzePropertyManager(ConnectorServicesProvider connectorServicesProvider)
{
return new AnalyzePropertyManager(new ConnectorCatalogServiceProvider<>("analyze properties", connectorServicesProvider, ConnectorServices::getAnalyzeProperties));
}
@Provides
@Singleton
public static TableProceduresPropertyManager createTableProceduresPropertyManager(ConnectorServicesProvider connectorServicesProvider)
{
return new TableProceduresPropertyManager(new ConnectorCatalogServiceProvider<>("table procedures", connectorServicesProvider, ConnectorServices::getTableProcedures));
}
@Provides
@Singleton
public static CatalogServiceProvider> createAccessControlProvider(ConnectorServicesProvider connectorServicesProvider)
{
return new ConnectorCatalogServiceProvider<>("access control", connectorServicesProvider, ConnectorServices::getAccessControl);
}
@Provides
@Singleton
public static CatalogServiceProvider createFunctionProvider(ConnectorServicesProvider connectorServicesProvider)
{
return new ConnectorCatalogServiceProvider<>("function provider", connectorServicesProvider, ConnectorServices::getFunctionProvider);
}
private static class ConnectorAccessControlLazyRegister
{
@Inject
public ConnectorAccessControlLazyRegister(
AccessControlManager accessControl,
CatalogServiceProvider> connectorAccessControlProvider)
{
accessControl.setConnectorAccessControlProvider(connectorAccessControlProvider);
}
}
}