All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.trino.spi.connector.Connector Maven / Gradle / Ivy

The newest version!
/*
 * 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.spi.connector;

import io.trino.spi.Experimental;
import io.trino.spi.eventlistener.EventListener;
import io.trino.spi.function.FunctionProvider;
import io.trino.spi.function.table.ConnectorTableFunction;
import io.trino.spi.procedure.Procedure;
import io.trino.spi.session.PropertyMetadata;
import io.trino.spi.transaction.IsolationLevel;

import java.util.List;
import java.util.Optional;
import java.util.Set;

import static java.util.Collections.emptyList;
import static java.util.Collections.emptySet;

public interface Connector
{
    /**
     * Start a new transaction and return a handle for it. The engine will call
     * {@link #getMetadata} to fetch the metadata instance for the transaction.
     * The engine will later call exactly one of {@link #commit} or {@link #rollback}
     * to end the transaction, even in auto-commit mode.
     * 

* If {@code true} is returned from {@link #isSingleStatementWritesOnly}, then * the engine will enforce that auto-commit mode is used for writes, allowing * connectors to execute writes immediately, rather than needing to wait * until the transaction is committed. * * @param isolationLevel minimum isolation level for the transaction * @param readOnly if the transaction is guaranteed to only read data (not write) * @param autoCommit if the transaction uses auto-commit mode */ default ConnectorTransactionHandle beginTransaction(IsolationLevel isolationLevel, boolean readOnly, boolean autoCommit) { throw new UnsupportedOperationException(); } /** * Guaranteed to be called at most once per transaction. The returned metadata will only be accessed * in a single threaded context. */ default ConnectorMetadata getMetadata(ConnectorSession session, ConnectorTransactionHandle transactionHandle) { throw new UnsupportedOperationException(); } /** * @throws UnsupportedOperationException if this connector does not support tables with splits */ default ConnectorSplitManager getSplitManager() { throw new UnsupportedOperationException(); } /** * @throws UnsupportedOperationException if this connector does not support reading tables page at a time */ default ConnectorPageSourceProvider getPageSourceProvider() { throw new UnsupportedOperationException(); } /** * Provide a pageSourceProviderFactory to create stateful instances of PageSourceProvider per query. * If not implemented a singleton instance returned by getPageSourceProvider will be used for all queries. */ default ConnectorPageSourceProviderFactory getPageSourceProviderFactory() { ConnectorPageSourceProvider pageSourceProvider = getPageSourceProvider(); return () -> pageSourceProvider; } /** * @throws UnsupportedOperationException if this connector does not support reading tables record at a time */ default ConnectorRecordSetProvider getRecordSetProvider() { throw new UnsupportedOperationException(); } /** * @throws UnsupportedOperationException if this connector does not support writing tables page at a time */ default ConnectorPageSinkProvider getPageSinkProvider() { throw new UnsupportedOperationException(); } /** * @throws UnsupportedOperationException if this connector does not support indexes */ default ConnectorIndexProvider getIndexProvider() { throw new UnsupportedOperationException(); } /** * @throws UnsupportedOperationException if this connector does not support partitioned table layouts */ default ConnectorNodePartitioningProvider getNodePartitioningProvider() { throw new UnsupportedOperationException(); } /** * @return the set of system tables provided by this connector */ default Set getSystemTables() { return emptySet(); } /** * @return the set of procedures provided by this connector */ @Experimental(eta = "2022-10-31") default Optional getFunctionProvider() { return Optional.empty(); } /** * @return the set of procedures provided by this connector */ default Set getProcedures() { return emptySet(); } default Set getTableProcedures() { return emptySet(); } /** * Retrieves the initial memory requirement for the connector. *

* The memory allocation is per catalog and is freed when the catalog is shut down. * * @return the initial memory requirement in bytes. */ default long getInitialMemoryRequirement() { return 0; } /** * @return the set of table functions provided by this connector */ default Set getTableFunctions() { return emptySet(); } /** * @return the system properties for this connector */ default List> getSessionProperties() { return emptyList(); } /** * @return the schema properties for this connector */ default List> getSchemaProperties() { return emptyList(); } /** * @return the analyze properties for this connector */ default List> getAnalyzeProperties() { return emptyList(); } /** * @return the table properties for this connector */ default List> getTableProperties() { return emptyList(); } /** * @return the view properties for this connector */ default List> getViewProperties() { return emptyList(); } /** * @return the materialized view properties for this connector */ default List> getMaterializedViewProperties() { return emptyList(); } /** * @return the column properties for this connector */ default List> getColumnProperties() { return emptyList(); } /** * @throws UnsupportedOperationException if this connector does not have an access control */ default ConnectorAccessControl getAccessControl() { throw new UnsupportedOperationException(); } /** * @return the event listeners provided by this connector */ default Iterable getEventListeners() { return emptySet(); } /** * Commit the transaction. Will be called at most once and will not be called if * {@link #rollback} is called. */ default void commit(ConnectorTransactionHandle transactionHandle) {} /** * Rollback the transaction. Will be called at most once and will not be called if * {@link #commit} is called. *

* Note: calls to this method may race with calls to the ConnectorMetadata. */ default void rollback(ConnectorTransactionHandle transactionHandle) {} /** * True if the connector only supports write statements in independent transactions. * The engine will enforce this for the connector by requiring auto-commit mode for writes. */ default boolean isSingleStatementWritesOnly() { return true; } /** * Shutdown the connector by releasing any held resources such as * threads, sockets, etc. This method will only be called when no * queries are using the connector. After this method is called, * no methods will be called on the connector or any objects that * have been returned from the connector. */ default void shutdown() {} default Set getCapabilities() { return emptySet(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy