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

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> getAllBuckets() { return reactor.publishOnUserScheduler(async::getAllBuckets); } /** * Loads the properties of all buckets the current user has access to from the cluster. * * @param options the custom options to apply. * @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> getAllBuckets(final GetAllBucketOptions options) { return reactor.publishOnUserScheduler(() -> async.getAllBuckets(options)); } /** * Deletes all documents from ("flushes") a bucket. *

* Flush needs to be enabled on the bucket in order to perform the operation. Enabling flush is not recommended * in a production cluster and can lead to data loss! *

* Keep in mind that flush is not an atomic operation, the server will need some time to clean the partitions * out completely. If isolation is preferred in an integration-test scenario, creating individual buckets might * provide a better user experience. * * @param bucketName the name of the bucket to flush. * @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 BucketNotFlushableException (async) if flush is not enabled on the bucket. * @throws CouchbaseException (async) if any other generic unhandled/unexpected errors. */ public Mono flushBucket(final String bucketName) { return reactor.publishOnUserScheduler(() -> async.flushBucket(bucketName)); } /** * Deletes all documents from ("flushes") a bucket with custom options. *

* Flush needs to be enabled on the bucket in order to perform the operation. Enabling flush is not recommended * in a production cluster and can lead to data loss! *

* Keep in mind that flush is not an atomic operation, the server will need some time to clean the partitions * out completely. If isolation is preferred in an integration-test scenario, creating individual buckets might * provide a better user experience. * * @param bucketName the name of the bucket to flush. * @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 BucketNotFlushableException (async) if flush is not enabled on the bucket. * @throws CouchbaseException (async) if any other generic unhandled/unexpected errors. */ public Mono flushBucket(final String bucketName, final FlushBucketOptions options) { return reactor.publishOnUserScheduler(() -> async.flushBucket(bucketName, options)); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy