com.couchbase.client.java.manager.collection.AsyncCollectionManager Maven / Gradle / Ivy
/*
* Copyright 2019 Couchbase, Inc.
*
* 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 com.couchbase.client.java.manager.collection;
import com.couchbase.client.core.annotation.Stability;
import com.couchbase.client.core.error.CollectionExistsException;
import com.couchbase.client.core.error.CollectionNotFoundException;
import com.couchbase.client.core.error.CouchbaseException;
import com.couchbase.client.core.error.ScopeExistsException;
import com.couchbase.client.core.error.ScopeNotFoundException;
import com.couchbase.client.core.manager.CoreCollectionManager;
import com.couchbase.client.core.util.PreventsGarbageCollection;
import com.couchbase.client.java.AsyncBucket;
import com.couchbase.client.java.AsyncCluster;
import java.time.Duration;
import java.util.List;
import java.util.Optional;
import java.util.concurrent.CompletableFuture;
import java.util.stream.Collectors;
import static com.couchbase.client.core.util.Validators.notNull;
import static com.couchbase.client.core.util.Validators.notNullOrEmpty;
import static com.couchbase.client.java.manager.collection.CreateCollectionOptions.createCollectionOptions;
import static com.couchbase.client.java.manager.collection.CreateCollectionSettings.createCollectionSettings;
import static com.couchbase.client.java.manager.collection.CreateScopeOptions.createScopeOptions;
import static com.couchbase.client.java.manager.collection.DropCollectionOptions.dropCollectionOptions;
import static com.couchbase.client.java.manager.collection.DropScopeOptions.dropScopeOptions;
import static com.couchbase.client.java.manager.collection.GetAllScopesOptions.getAllScopesOptions;
import static com.couchbase.client.java.manager.collection.GetScopeOptions.getScopeOptions;
import static com.couchbase.client.java.manager.collection.UpdateCollectionOptions.updateCollectionOptions;
import static java.util.Objects.requireNonNull;
/**
* The {@link AsyncCollectionManager} provides APIs to manage collections and scopes within a bucket.
*/
@Stability.Volatile
public class AsyncCollectionManager {
/**
* References the core-io collection manager which abstracts common I/O functionality.
*/
private final CoreCollectionManager coreCollectionManager;
@PreventsGarbageCollection
private final AsyncCluster cluster;
/**
* Creates a new {@link AsyncCollectionManager}.
*
* This API is not intended to be called by the user directly, use {@link AsyncBucket#collections()}
* instead.
*/
@Stability.Internal
public AsyncCollectionManager(
final CoreCollectionManager coreCollectionManager,
final AsyncCluster cluster
) {
this.coreCollectionManager = requireNonNull(coreCollectionManager);
this.cluster = requireNonNull(cluster);
}
/**
* Creates a collection if it does not already exist.
*
* Note that a scope needs to be created first (via {@link #createScope(String)}) if it doesn't exist already.
*
* @param collectionSpec the collection spec that contains the properties of the collection.
* @return a {@link CompletableFuture} completing when the operation is applied or failed with an error.
* @throws CollectionExistsException (async) if the collection already exists
* @throws ScopeNotFoundException (async) if the specified scope does not exist.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
* @deprecated This method cannot be used to set the collection's "history" property.
* Please use {@link #createCollection(String, String, CreateCollectionSettings)} instead.
*/
@Deprecated
public CompletableFuture createCollection(final CollectionSpec collectionSpec) {
return createCollection(collectionSpec, createCollectionOptions());
}
/**
* Creates a collection if it does not already exist with custom options.
*
* Note that a scope needs to be created first (via {@link #createScope(String)}) if it doesn't exist already.
*
* @param collectionSpec the collection spec that contains the properties of the collection.
* @param options the custom options to apply.
* @return a {@link CompletableFuture} completing when the operation is applied or failed with an error.
* @throws CollectionExistsException (async) if the collection already exists
* @throws ScopeNotFoundException (async) if the specified scope does not exist.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
* @deprecated This method cannot be used to set the collection's "history" property.
* Please use {@link #createCollection(String, String, CreateCollectionSettings, CreateCollectionOptions)} instead.
*/
@Deprecated
public CompletableFuture createCollection(final CollectionSpec collectionSpec,
final CreateCollectionOptions options) {
return createCollection(
collectionSpec.scopeName(),
collectionSpec.name(),
createCollectionSettings()
.maxExpiry(collectionSpec.maxExpiry()),
options
);
}
/**
* Creates a collection if it does not already exist with custom options.
*
* Note that a scope needs to be created first (via {@link #createScope(String)}) if it doesn't exist already.
*
* @param scopeName name of scope to create collection in
* @param collectionName name of collection to create
* @param settings the collection settings
* @return a {@link CompletableFuture} completing when the operation is applied or failed with an error.
* @throws CollectionExistsException (async) if the collection already exists
* @throws ScopeNotFoundException (async) if the specified scope does not exist.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
*/
@Stability.Volatile
public CompletableFuture createCollection(String scopeName, String collectionName, CreateCollectionSettings settings) {
return coreCollectionManager.createCollection(scopeName, collectionName, settings.build(), createCollectionOptions().build());
}
/**
* Creates a collection if it does not already exist with custom options.
*
* Note that a scope needs to be created first (via {@link #createScope(String)}) if it doesn't exist already.
*
* @param scopeName name of scope to create collection in
* @param collectionName name of collection to create
* @param settings the collection settings
* @param options the custom options to apply.
* @return a {@link CompletableFuture} completing when the operation is applied or failed with an error.
* @throws CollectionExistsException (async) if the collection already exists
* @throws ScopeNotFoundException (async) if the specified scope does not exist.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
*/
@Stability.Volatile
public CompletableFuture createCollection(String scopeName, String collectionName, CreateCollectionSettings settings, CreateCollectionOptions options) {
return coreCollectionManager.createCollection(scopeName, collectionName, settings.build(), options.build());
}
/**
* Creates a scope if it does not already exist.
*
* @param scopeName the name of the scope to create.
* @return a {@link CompletableFuture} completing when the operation is applied or failed with an error.
* @throws ScopeExistsException (async) if the scope already exists.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
*/
public CompletableFuture createScope(final String scopeName) {
return createScope(scopeName, createScopeOptions());
}
/**
* Creates a scope if it does not already exist with custom options.
*
* @param scopeName the name of the scope to create.
* @param options the custom options to apply.
* @return a {@link CompletableFuture} completing when the operation is applied or failed with an error.
* @throws ScopeExistsException (async) if the scope already exists.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
*/
public CompletableFuture createScope(final String scopeName, final CreateScopeOptions options) {
return coreCollectionManager.createScope(scopeName, options.build());
}
/**
* Updates a collection with custom options.
*
* @param scopeName name of scope to update collection in
* @param collectionName name of collection to update
* @param settings the collection settings
* @return a {@link CompletableFuture} completing when the operation is applied or failed with an error.
* @throws ScopeNotFoundException (async) if the specified scope does not exist.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
*/
@Stability.Volatile
public CompletableFuture updateCollection(final String scopeName, final String collectionName, final UpdateCollectionSettings settings) {
return updateCollection(scopeName, collectionName, settings, updateCollectionOptions());
}
/**
* Updates a collection with custom options.
*
* @param scopeName name of scope to update collection in
* @param collectionName name of collection to update
* @param settings the collection settings
* @param options the custom options to apply.
* @return a {@link CompletableFuture} completing when the operation is applied or failed with an error.
* @throws CollectionNotFoundException (async) if the collection does not exist.
* @throws ScopeNotFoundException (async) if the specified scope does not exist.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
*/
@Stability.Volatile
public CompletableFuture updateCollection(final String scopeName, final String collectionName, final UpdateCollectionSettings settings, final UpdateCollectionOptions options) {
return coreCollectionManager.updateCollection(scopeName, collectionName, settings.build(), options.build());
}
/**
* Drops a collection if it exists.
*
* @param collectionSpec the collection spec that contains the properties of the collection.
* @return a {@link CompletableFuture} completing when the operation is applied or failed with an error.
* @throws CollectionNotFoundException (async) if the collection does not exist.
* @throws ScopeNotFoundException (async) if the specified scope does not exist.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
* @deprecated Please use {@link #dropCollection(String, String)} instead.
*/
@Deprecated
public CompletableFuture dropCollection(final CollectionSpec collectionSpec) {
return dropCollection(collectionSpec, dropCollectionOptions());
}
/**
* Drops a collection if it exists with custom options.
*
* @param collectionSpec the collection spec that contains the properties of the collection.
* @param options the custom options to apply.
* @return a {@link CompletableFuture} completing when the operation is applied or failed with an error.
* @throws CollectionNotFoundException (async) if the collection did not exist.
* @throws ScopeNotFoundException (async) if the specified scope does not exist.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
* @deprecated Please use {@link #dropCollection(String, String, DropCollectionOptions)} instead.
*/
@Deprecated
public CompletableFuture dropCollection(final CollectionSpec collectionSpec,
final DropCollectionOptions options) {
return coreCollectionManager.dropCollection(collectionSpec.scopeName(), collectionSpec.name(), options.build());
}
/**
* Drops a collection if it exists.
*
* @param scopeName name of scope to drop collection from
* @param collectionName name of collection to drop
* @return a {@link CompletableFuture} completing when the operation is applied or failed with an error.
* @throws CollectionNotFoundException (async) if the collection did not exist.
* @throws ScopeNotFoundException (async) if the specified scope does not exist.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
*/
@Stability.Volatile
public CompletableFuture dropCollection(final String scopeName,
final String collectionName) {
return dropCollection(scopeName, collectionName, dropCollectionOptions());
}
/**
* Drops a collection if it exists with custom options.
*
* @param scopeName name of scope to drop collection from
* @param collectionName name of collection to drop
* @param options the custom options to apply.
* @return a {@link CompletableFuture} completing when the operation is applied or failed with an error.
* @throws CollectionNotFoundException (async) if the collection did not exist.
* @throws ScopeNotFoundException (async) if the specified scope does not exist.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
*/
@Stability.Volatile
public CompletableFuture dropCollection(final String scopeName,
final String collectionName,
final DropCollectionOptions options) {
return coreCollectionManager.dropCollection(scopeName, collectionName, options.build());
}
/**
* Drops a scope if it exists.
*
* @param scopeName the name of the scope to drop.
* @return a {@link CompletableFuture} completing when the operation is applied or failed with an error.
* @throws ScopeNotFoundException (async) if the scope did not exist.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
*/
public CompletableFuture dropScope(final String scopeName) {
return dropScope(scopeName, dropScopeOptions());
}
/**
* Drops a scope if it exists with custom options.
*
* @param scopeName the name of the scope to drop.
* @param options the custom options to apply.
* @return a {@link CompletableFuture} completing when the operation is applied or failed with an error.
* @throws ScopeNotFoundException (async) if the scope did not exist.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
*/
public CompletableFuture dropScope(final String scopeName, final DropScopeOptions options) {
return coreCollectionManager.dropScope(scopeName, options.build());
}
/**
* Returns the scope if it exists.
*
* @param scopeName the name of the scope.
* @return a {@link CompletableFuture} containing information about the scope.
* @throws ScopeNotFoundException (async) if scope does not exist.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
* @deprecated use {@link #getAllScopes()} instead.
*/
@Deprecated
public CompletableFuture getScope(final String scopeName) {
return getScope(scopeName, getScopeOptions());
}
/**
* Returns the scope if it exists with custom options.
*
* @param scopeName the name of the scope.
* @param options the custom options to apply.
* @return a {@link CompletableFuture} containing information about the scope.
* @throws ScopeNotFoundException (async) if scope does not exist.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
* @deprecated use {@link #getAllScopes(GetAllScopesOptions)} instead.
*/
@Deprecated
public CompletableFuture getScope(final String scopeName, final GetScopeOptions options) {
notNullOrEmpty(scopeName, "ScopeName");
notNull(options, "Options");
GetScopeOptions.Built opts = options.build();
GetAllScopesOptions toPassOptions = getAllScopesOptions();
opts.timeout().ifPresent(toPassOptions::timeout);
opts.retryStrategy().ifPresent(toPassOptions::retryStrategy);
return getAllScopes(toPassOptions).thenApply(scopes -> {
Optional scope = scopes.stream().filter(s -> s.name().equals(scopeName)).findFirst();
if (scope.isPresent()) {
return scope.get();
} else {
throw ScopeNotFoundException.forScope(scopeName);
}
});
}
/**
* Returns all scopes in this bucket.
*
* @return a {@link CompletableFuture} with a (potentially empty) list of scopes in the bucket.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
*/
public CompletableFuture> getAllScopes() {
return getAllScopes(getAllScopesOptions());
}
/**
* Returns all scopes in this bucket with custom options.
*
* @param options the custom options to apply.
* @return a {@link CompletableFuture} with a (potentially empty) list of scopes in the bucket.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
*/
public CompletableFuture> getAllScopes(final GetAllScopesOptions options) {
return coreCollectionManager.getAllScopes(options.build())
// Note that because ns_server returns a different manifest format, we need to do some munching to
// turn this into the same collections manifest format for sanity.
.thenApply(manifest -> manifest.scopes().stream()
.map(s -> ScopeSpec.create(s.name(),
s.collections().stream()
.map(c -> CollectionSpec.internalCreate(c.name(), s.name(), c.maxExpiry() == null ? Duration.ZERO : Duration.ofSeconds(c.maxExpiry()), c.history()))
.collect(Collectors.toSet())))
.collect(Collectors.toList()));
}
}