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

io.stargate.db.datastore.DataStore Maven / Gradle / Ivy

/*
 * Copyright DataStax, Inc. and/or 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.datastore;

import io.stargate.db.Persistence;
import io.stargate.db.query.AsyncQueryExecutor;
import io.stargate.db.query.BoundQuery;
import io.stargate.db.query.Query;
import io.stargate.db.query.TypedValue;
import io.stargate.db.query.builder.QueryBuilder;
import io.stargate.db.schema.Schema;
import java.util.concurrent.CompletableFuture;

/**
 * Wraps a {@link Persistence} implementation to provide more convenient and high-level access.
 *
 * 

DataStore provides a number of convenience over {@link Persistence}, like the use of actual * java object values (instead of raw byte buffers), automatic handling of paging in its result set, * etc. */ public interface DataStore extends AsyncQueryExecutor { TypedValue.Codec valueCodec(); /** Create a query using the DSL builder. */ default QueryBuilder queryBuilder() { return new QueryBuilder(schema(), valueCodec(), this); } CompletableFuture> prepare(Query query); /** * Returns the current schema. * * @return The current schema. */ Schema schema(); /** Returns true if the persistence backend supports secondary indexes */ boolean supportsSecondaryIndex(); /** Returns true if the persistence backend supports Storage Attached Indexes. */ boolean supportsSAI(); /** Returns true if the persistence backend allows logged batches. */ boolean supportsLoggedBatches(); /** Returns true if in schema agreement */ boolean isInSchemaAgreement(); /** Wait for schema to agree across the cluster */ void waitForSchemaAgreement(); }