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

io.stargate.db.Persistence Maven / Gradle / Ivy

/*
 * Copyright The Stargate Authors
 *
 * 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.stargate.db;

import com.datastax.oss.driver.shaded.guava.common.util.concurrent.Uninterruptibles;
import io.stargate.db.datastore.DataStore;
import io.stargate.db.schema.Schema;
import java.nio.ByteBuffer;
import java.util.List;
import java.util.Map;
import java.util.Optional;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.TimeUnit;
import org.apache.cassandra.stargate.exceptions.AuthenticationException;

/**
 * A persistence layer that can be queried.
 *
 * 

This is the interface that stargate API extensions uses (either directly, or through the * higher level {@link DataStore} API which wraps a instance of this interface) to query the * underlying store, and thus the one interface that persistence extensions must implement. */ public interface Persistence { int SCHEMA_AGREEMENT_WAIT_RETRIES = Integer.getInteger("stargate.persistence.schema.agreement.wait.retries", 900); /** Name describing the persistence implementation. */ String name(); /** The current schema. */ Schema schema(); /** * Registers a listener whose methods will be called when either the schema or the topology of the * persistence changes. */ void registerEventListener(EventListener listener); Authenticator getAuthenticator(); /** * Notify the other stargate nodes whether RPC is or is not ready on this node. * * @param status true means that RPC is ready, otherwise RPC is not ready. */ void setRpcReady(boolean status); /** * Creates a new connection for an "external" client identified by the provided info. * * @param clientInfo info identifying the client for which the connection is created. * @return the newly created persistence connection. */ Connection newConnection(ClientInfo clientInfo); /** * Creates a new "internal" connection, that is one with no client information. * * @return the newly created persistence connection. */ Connection newConnection(); /** * The object that should be used to act as an 'unset' value for this persistence (for use in * {@link Statement#values()}). * *

Please note that persistence implementations are allowed to use reference equality to * detect this value, so the object returned by this method should be used "as-is" and should * not be copied (through {@link ByteBuffer#duplicate()} or any other method). */ ByteBuffer unsetValue(); boolean isInSchemaAgreement(); default boolean supportsSecondaryIndex() { return Boolean.parseBoolean( System.getProperty("stargate.persistence.2i.support.default", "true")); } /** Wait for schema to agree across the cluster */ default void waitForSchemaAgreement() { for (int count = 0; count < SCHEMA_AGREEMENT_WAIT_RETRIES; count++) { if (isInSchemaAgreement()) { return; } Uninterruptibles.sleepUninterruptibly(200, TimeUnit.MILLISECONDS); } throw new IllegalStateException( "Failed to reach schema agreement after " + (200 * SCHEMA_AGREEMENT_WAIT_RETRIES) + " milliseconds."); } /** * Persistence-specific CQL options to be returned in SUPPORTED response messages. * *

Important: At a minimum, this must return the {@code "CQL_VERSION"} option. */ Map> cqlSupportedOptions(); /** * A connection to the persistence. * *

It is through this object that a user can be logged in and that the persistence can be * queried. */ interface Connection { /** The underlying persistence on which this is a connection. */ Persistence persistence(); /** * Login a user on that connection. * * @param user the user to login. * @throws AuthenticationException if the user is not authorized to login. */ void login(AuthenticatedUser user) throws AuthenticationException; /** The user logged in, if any. */ Optional loggedUser(); /** Information on the client for which the connection was created, if any. */ Optional clientInfo(); /** * The default keyspace that is in use on this connection, if any (that is, if a {@code USE} * query has been performed on this connection). */ Optional usedKeyspace(); /** * Prepare a query on this connection. * * @param query the query to prepare. * @param parameters the parameters for the preparation (note that preparation only use a subset * of parameters). * @return a future that, on completion of the preparation, provides its result. Please see the * {@link #execute} method for warnings regarding the completion of that future. The same * warnings apply for this method as well. */ CompletableFuture prepare(String query, Parameters parameters); /** * Executes a statement on this connection. * * @param statement the statement to execute. * @param parameters the parameters for the execution. * @param queryStartNanoTime the start time of the query, as a nano time returned by {@link * System#nanoTime()}. * @return a future that, on completion of the execution, provides its result. Please note that * persistence implementations are allowed to complete this future on an internal, and * potentially performance sensitive, thread. As such, consumers should not "chain" * costly/blocking operations on this future without passing their own executor. In other * words, do not do something like: * execute(...).thenRun(() -> { someBlockingOperation(); }) * Instead, use one of the "async" variants of {@link CompletableFuture}, namely: * * // you can also provide your own executor below obviously * execute(...).thenRunAsync(() -> { someBlockingOperation(); }) * */ CompletableFuture execute( Statement statement, Parameters parameters, long queryStartNanoTime); /** * Executes a batch on this connection. * * @param batch the batch to execute. * @param parameters the parameters for the batch execution. * @return a future that, on completion of the execution, provides its result. Please see the * {@link #execute} method for warnings regarding the completion of that future. The same * warnings apply for this method as well. */ CompletableFuture batch(Batch batch, Parameters parameters, long queryStartNanoTime); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy