com.couchbase.client.java.Bucket Maven / Gradle / Ivy
/*
* Copyright (c) 2018 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;
import com.couchbase.client.core.Core;
import com.couchbase.client.core.annotation.Stability;
import com.couchbase.client.core.diagnostics.ClusterState;
import com.couchbase.client.core.diagnostics.PingResult;
import com.couchbase.client.core.error.CouchbaseException;
import com.couchbase.client.core.error.TimeoutException;
import com.couchbase.client.core.error.ViewNotFoundException;
import com.couchbase.client.core.io.CollectionIdentifier;
import com.couchbase.client.java.diagnostics.PingOptions;
import com.couchbase.client.java.diagnostics.WaitUntilReadyOptions;
import com.couchbase.client.java.env.ClusterEnvironment;
import com.couchbase.client.java.manager.collection.CollectionManager;
import com.couchbase.client.java.manager.view.ViewIndexManager;
import com.couchbase.client.java.view.ViewOptions;
import com.couchbase.client.java.view.ViewResult;
import java.time.Duration;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
import static com.couchbase.client.java.AsyncUtils.block;
import static com.couchbase.client.java.ReactiveBucket.DEFAULT_VIEW_OPTIONS;
/**
* Provides access to a Couchbase bucket in a blocking fashion.
*/
public class Bucket {
/**
* Holds the underlying async bucket reference.
*/
private final AsyncBucket asyncBucket;
/**
* Holds the adjacent reactive bucket reference.
*/
private final ReactiveBucket reactiveBucket;
/**
* Stores already opened scopes for reuse.
*/
private final Map scopeCache = new ConcurrentHashMap<>();
/**
* Constructs a new {@link Bucket}.
*
* @param asyncBucket the underlying async bucket.
*/
Bucket(final AsyncBucket asyncBucket) {
this.asyncBucket = asyncBucket;
this.reactiveBucket = new ReactiveBucket(asyncBucket);
}
/**
* Provides access to the underlying {@link AsyncBucket}.
*/
public AsyncBucket async() {
return asyncBucket;
}
/**
* Provides access to the related {@link ReactiveBucket}.
*/
public ReactiveBucket reactive() {
return reactiveBucket;
}
/**
* Returns the name of the {@link Bucket}.
*/
public String name() {
return asyncBucket.name();
}
/**
* Returns the attached {@link ClusterEnvironment}.
*/
public ClusterEnvironment environment() {
return asyncBucket.environment();
}
public CollectionManager collections() {
return new CollectionManager(asyncBucket.collections());
}
public ViewIndexManager viewIndexes() {
return new ViewIndexManager(asyncBucket.viewIndexes());
}
/**
* Provides access to the underlying {@link Core}.
*
* This is advanced API, use with care!
*/
@Stability.Volatile
public Core core() {
return asyncBucket.core();
}
/**
* Opens the {@link Scope} with the given name.
*
* @param name the name of the scope.
* @return the {@link Scope} once opened.
*/
public Scope scope(final String name) {
return scopeCache.computeIfAbsent(name, n -> new Scope(asyncBucket.scope(n)));
}
/**
* Opens the default {@link Scope}.
*
* @return the {@link Scope} once opened.
*/
public Scope defaultScope() {
return scopeCache.computeIfAbsent(
CollectionIdentifier.DEFAULT_SCOPE,
n -> new Scope(asyncBucket.defaultScope())
);
}
/**
* Opens the default collection for this {@link Bucket} using the default scope.
*
* This method does not block and the client will try to establish all needed resources in the background. If you
* need to eagerly await until all resources are established before performing an operation, use the
* {@link #waitUntilReady(Duration)} method on the {@link Bucket}.
*
* @return the opened default {@link Collection}.
*/
public Collection defaultCollection() {
return defaultScope().defaultCollection();
}
/**
* Provides access to the collection with the given name for this {@link Bucket} using the default scope.
*
* This method does not block and the client will try to establish all needed resources in the background. If you
* need to eagerly await until all resources are established before performing an operation, use the
* {@link #waitUntilReady(Duration)} method on the {@link Bucket}.
*
* @return the opened named {@link Collection}.
*/
public Collection collection(final String collectionName) {
return defaultScope().collection(collectionName);
}
/**
* Queries a view on the bucket.
*
* @param designDoc the name of the design document in which the view resides.
* @param viewName the name of the view to query.
* @return a {@link ViewResult} once completed.
* @throws ViewNotFoundException if the view or design document is not found on the server.
* @throws TimeoutException if the operation times out before getting a result.
* @throws CouchbaseException for all other error reasons (acts as a base type and catch-all).
*/
public ViewResult viewQuery(final String designDoc, final String viewName) {
return viewQuery(designDoc, viewName, DEFAULT_VIEW_OPTIONS);
}
/**
* Queries a view on the bucket with custom options.
*
* @param designDoc the name of the design document in which the view resides.
* @param viewName the name of the view to query.
* @param options allows to customize view options.
* @return a {@link ViewResult} once completed.
* @throws ViewNotFoundException if the view or design document is not found on the server.
* @throws TimeoutException if the operation times out before getting a result.
* @throws CouchbaseException for all other error reasons (acts as a base type and catch-all).
*/
public ViewResult viewQuery(final String designDoc, final String viewName, final ViewOptions options) {
return block(asyncBucket.viewQuery(designDoc, viewName, options));
}
/**
* Performs application-level ping requests against services in the couchbase cluster.
*
* @return the {@link PingResult} once complete.
*/
public PingResult ping() {
return block(asyncBucket.ping());
}
/**
* Performs application-level ping requests with custom options against services in the couchbase cluster.
*
* @return the {@link PingResult} once complete.
*/
public PingResult ping(final PingOptions options) {
return block(asyncBucket.ping(options));
}
/**
* Waits until the desired {@link ClusterState} is reached.
*
* This method will wait until either the cluster state is "online", or the timeout is reached. Since the SDK is
* bootstrapping lazily, this method allows to eagerly check during bootstrap if all of the services are online
* and usable before moving on.
*
* @param timeout the maximum time to wait until readiness.
*/
public void waitUntilReady(final Duration timeout) {
block(asyncBucket.waitUntilReady(timeout));
}
/**
* Waits until the desired {@link ClusterState} is reached.
*
* This method will wait until either the cluster state is "online" by default, or the timeout is reached. Since the
* SDK is bootstrapping lazily, this method allows to eagerly check during bootstrap if all of the services are online
* and usable before moving on. You can tune the properties through {@link WaitUntilReadyOptions}.
*
* @param timeout the maximum time to wait until readiness.
* @param options the options to customize the readiness waiting.
*/
public void waitUntilReady(final Duration timeout, final WaitUntilReadyOptions options) {
block(asyncBucket.waitUntilReady(timeout, options));
}
}