com.couchbase.client.java.manager.bucket.ReactiveBucketManager 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.bucket;
import com.couchbase.client.core.annotation.Stability;
import com.couchbase.client.core.error.BucketExistsException;
import com.couchbase.client.core.error.BucketNotFlushableException;
import com.couchbase.client.core.error.BucketNotFoundException;
import com.couchbase.client.core.error.CouchbaseException;
import com.couchbase.client.core.util.ReactorOps;
import com.couchbase.client.java.ReactiveCluster;
import reactor.core.publisher.Mono;
import java.util.Map;
import static java.util.Objects.requireNonNull;
/**
* Performs (reactive) management operations on Buckets.
*
* All mutating operations on this manager are eventually consistent, which means that as soon as the call returns
* the operation is accepted by the server, but it does not mean that the operation has been applied to all nodes
* in the cluster yet. In the future, APIs will be provided which allow to assert the propagation state.
*/
public class ReactiveBucketManager {
/**
* Holds the underlying async bucket manager.
*/
private final AsyncBucketManager async;
private final ReactorOps reactor;
/**
* Creates a new {@link ReactiveBucketManager}.
*
* This API is not intended to be called by the user directly, use {@link ReactiveCluster#buckets()}
* instead.
*
* @param async the underlying async manager that performs the ops.
*/
@Stability.Internal
public ReactiveBucketManager(final ReactorOps reactor, final AsyncBucketManager async) {
this.reactor = requireNonNull(reactor);
this.async = requireNonNull(async);
}
/**
* Provides access to the {@link AsyncBucketManager} for convenience.
*/
public AsyncBucketManager async() {
return async;
}
/**
* Creates a new bucket on the server.
*
* The SDK will not perform any logical validation on correct combination of the settings - the server will return
* an error on invalid combinations. As an example, a magma bucket needs at least 1024 MiB of bucket quota - otherwise
* the server will reject it.
*
* @param settings the {@link BucketSettings} describing the properties of the bucket.
* @return a {@link Mono} completing when the operation is applied or has failed with an error.
* @throws BucketExistsException (async) if the bucket already exists.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
*/
public Mono createBucket(final BucketSettings settings) {
return reactor.publishOnUserScheduler(() -> async.createBucket(settings));
}
/**
* Creates a new bucket on the server with custom options.
*
* The SDK will not perform any logical validation on correct combination of the settings - the server will return
* an error on invalid combinations. As an example, a magma bucket needs at least 1024 MiB of bucket quota - otherwise
* the server will reject it.
*
* @param settings the {@link BucketSettings} describing the properties of the bucket.
* @param options the custom options to apply.
* @return a {@link Mono} completing when the operation is applied or has failed with an error.
* @throws BucketExistsException (async) if the bucket already exists.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
*/
public Mono createBucket(final BucketSettings settings, final CreateBucketOptions options) {
return reactor.publishOnUserScheduler(() -> async.createBucket(settings, options));
}
/**
* Updates the settings of a bucket which already exists.
*
* Not all properties of a bucket can be changed on an update. Notably, the following properties are ignored
* by the SDK on update and so will not produce an error but also not change anything on the server side:
*
* - {@link BucketSettings#name()}
* - {@link BucketSettings#bucketType(BucketType)}
* - {@link BucketSettings#conflictResolutionType(ConflictResolutionType)}
* - {@link BucketSettings#replicaIndexes(boolean)}
* - {@link BucketSettings#storageBackend(StorageBackend)}
*
*
* The SDK will not perform any logical validation on correct combination of the settings - the server will return
* an error on invalid combinations. As an example, a magma bucket needs at least 1024 MiB of bucket quota - otherwise
* the server will reject it.
*
* @param settings the {@link BucketSettings} describing the properties of the bucket.
* @return a {@link Mono} completing when the operation is applied or has failed with an error.
* @throws BucketNotFoundException (async) if the specified bucket does not exist.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
*/
public Mono updateBucket(final BucketSettings settings) {
return reactor.publishOnUserScheduler(() -> async.updateBucket(settings));
}
/**
* Updates the settings of a bucket which already exists with custom options.
*
* Not all properties of a bucket can be changed on an update. Notably, the following properties are ignored
* by the SDK on update and so will not produce an error but also not change anything on the server side:
*
* - {@link BucketSettings#name()}
* - {@link BucketSettings#bucketType(BucketType)}
* - {@link BucketSettings#conflictResolutionType(ConflictResolutionType)}
* - {@link BucketSettings#replicaIndexes(boolean)}
* - {@link BucketSettings#storageBackend(StorageBackend)}
*
*
* The SDK will not perform any logical validation on correct combination of the settings - the server will return
* an error on invalid combinations. As an example, a magma bucket needs at least 1024 MiB of bucket quota - otherwise
* the server will reject it.
*
* @param settings the {@link BucketSettings} describing the properties of the bucket.
* @param options the custom options to apply.
* @return a {@link Mono} completing when the operation is applied or has failed with an error.
* @throws BucketNotFoundException (async) if the specified bucket does not exist.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
*/
public Mono updateBucket(final BucketSettings settings, final UpdateBucketOptions options) {
return reactor.publishOnUserScheduler(() -> async.updateBucket(settings, options));
}
/**
* Drops ("deletes") a bucket from the cluster.
*
* @param bucketName the name of the bucket to drop.
* @return a {@link Mono} completing when the operation is applied or has failed with an error.
* @throws BucketNotFoundException (async) if the specified bucket does not exist.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
*/
public Mono dropBucket(final String bucketName) {
return reactor.publishOnUserScheduler(() -> async.dropBucket(bucketName));
}
/**
* Drops ("deletes") a bucket from the cluster with custom options.
*
* @param bucketName the name of the bucket to drop.
* @param options the custom options to apply.
* @return a {@link Mono} completing when the operation is applied or has failed with an error.
* @throws BucketNotFoundException (async) if the specified bucket does not exist.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
*/
public Mono dropBucket(final String bucketName, final DropBucketOptions options) {
return reactor.publishOnUserScheduler(() -> async.dropBucket(bucketName, options));
}
/**
* Loads the properties of a bucket from the cluster.
*
* @param bucketName the name of the bucket for which the settings should be loaded.
* @return a {@link Mono} completing with the bucket settings or if the operation has failed.
* @throws BucketNotFoundException (async) if the specified bucket does not exist.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
*/
public Mono getBucket(final String bucketName) {
return reactor.publishOnUserScheduler(() -> async.getBucket(bucketName));
}
/**
* Loads the properties of a bucket from the cluster with custom options.
*
* @param bucketName the name of the bucket for which the settings should be loaded.
* @param options the custom options to apply.
* @return a {@link Mono} completing with the bucket settings or if the operation has failed.
* @throws BucketNotFoundException (async) if the specified bucket does not exist.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
*/
public Mono getBucket(final String bucketName, final GetBucketOptions options) {
return reactor.publishOnUserScheduler(() -> async.getBucket(bucketName, options));
}
/**
* Loads the properties of all buckets the current user has access to from the cluster.
*
* @return a {@link Mono} completing with all bucket settings or if the operation has failed.
* @throws CouchbaseException (async) if any other generic unhandled/unexpected errors.
*/
public Mono