Class ReactiveCollection
ReactiveCollection provides sophisticated asynchronous access to all collection APIs.
 This API provides more sophisticated async controls over the AsyncCollection, but
 it also comes with a little more overhead. For most use cases we recommend using this API
 over the other one, unless you really need that last drop of performance and can live with the
 significantly reduced functionality (in terms of the richness of operators). For example, this
 ReactiveCollection is built on top of the AsyncCollection.
- Since:
- 3.0.0
- 
Method SummaryModifier and TypeMethodDescriptionasync()Provides access to the underlyingAsyncCollection.binary()Provides access to the binary APIs, not used for JSON documents.Returns the name of the bucket associated with this collection.core()Provides access to the underlyingCore.Provides access to the underlyingClusterEnvironment.reactor.core.publisher.Mono<ExistsResult> Checks if the given document ID exists on the active partition with default options.reactor.core.publisher.Mono<ExistsResult> exists(String id, ExistsOptions options) Checks if the given document ID exists on the active partition with custom options.reactor.core.publisher.Mono<GetResult> Fetches a Document from a collection with default options.reactor.core.publisher.Mono<GetResult> get(String id, GetOptions options) Fetches a Document from a collection with custom options.reactor.core.publisher.Flux<GetReplicaResult> getAllReplicas(String id) Reads all available replicas, including the active, and returns the results as a flux.reactor.core.publisher.Flux<GetReplicaResult> getAllReplicas(String id, GetAllReplicasOptions options) Reads all available replicas, including the active, and returns the results as a flux.reactor.core.publisher.Mono<GetResult> getAndLock(String id, Duration lockTime) Fetches a full document and write-locks it for the given duration with default options.reactor.core.publisher.Mono<GetResult> getAndLock(String id, Duration lockTime, GetAndLockOptions options) Fetches a full document and write-locks it for the given duration with custom options.reactor.core.publisher.Mono<GetResult> getAndTouch(String id, Duration expiry) Fetches a full document and resets its expiration time to the value provided with default options.reactor.core.publisher.Mono<GetResult> getAndTouch(String id, Duration expiry, GetAndTouchOptions options) Fetches a full document and resets its expiration time to the value provided with custom options.reactor.core.publisher.Mono<GetResult> getAndTouch(String id, Instant expiry) Fetches a full document and resets its expiration time to the value provided with default options.reactor.core.publisher.Mono<GetResult> getAndTouch(String id, Instant expiry, GetAndTouchOptions options) Fetches a full document and resets its expiration time to the value provided with custom options.reactor.core.publisher.Mono<GetReplicaResult> getAnyReplica(String id) Reads all available replicas, and returns the first found.reactor.core.publisher.Mono<GetReplicaResult> getAnyReplica(String id, GetAnyReplicaOptions options) Reads all available replicas, and returns the first found.reactor.core.publisher.Mono<MutationResult> Inserts a full document which does not exist yet with default options.reactor.core.publisher.Mono<MutationResult> insert(String id, Object content, InsertOptions options) Inserts a full document which does not exist yet with custom options.reactor.core.publisher.Mono<LookupInResult> lookupIn(String id, List<LookupInSpec> specs) Performs lookups to document fragments with default options.reactor.core.publisher.Mono<LookupInResult> lookupIn(String id, List<LookupInSpec> specs, LookupInOptions options) Performs lookups to document fragments with custom options.reactor.core.publisher.Flux<LookupInReplicaResult> lookupInAllReplicas(String id, List<LookupInSpec> lookupInSpecs) Reads all available replicas, including the active, and returns the results as a flux.reactor.core.publisher.Flux<LookupInReplicaResult> lookupInAllReplicas(String id, List<LookupInSpec> lookupInSpecs, LookupInAllReplicasOptions options) Reads all available replicas, including the active, and returns the results as a flux.reactor.core.publisher.Mono<LookupInReplicaResult> lookupInAnyReplica(String id, List<LookupInSpec> lookupInSpecs) Reads all available replicas, and returns the first found.reactor.core.publisher.Mono<LookupInReplicaResult> lookupInAnyReplica(String id, List<LookupInSpec> lookupInSpecs, LookupInAnyReplicaOptions options) Reads all available replicas, and returns the first found.reactor.core.publisher.Mono<MutateInResult> mutateIn(String id, List<MutateInSpec> specs) Performs mutations to document fragments with default options.reactor.core.publisher.Mono<MutateInResult> mutateIn(String id, List<MutateInSpec> specs, MutateInOptions options) Performs mutations to document fragments with custom options.name()Returns the name of this collection.Provides access to query index management at the ReactiveCollection level.reactor.core.publisher.Mono<MutationResult> Removes a Document from a collection with default options.reactor.core.publisher.Mono<MutationResult> remove(String id, RemoveOptions options) Removes a Document from a collection with custom options.reactor.core.publisher.Mono<MutationResult> Replaces a full document which already exists with default options.reactor.core.publisher.Mono<MutationResult> replace(String id, Object content, ReplaceOptions options) Replaces a full document which already exists with custom options.reactor.core.publisher.Flux<ScanResult> Returns a stream ofScanResultsperforming a Key-Value range scan with default options.reactor.core.publisher.Flux<ScanResult> scan(ScanType scanType, ScanOptions options) Returns a stream ofScanResultsperforming a Key-Value range scan with custom options.Returns the name of the scope associated with this collection.reactor.core.publisher.Mono<MutationResult> Updates the expiry of the document with the given id with default options.reactor.core.publisher.Mono<MutationResult> touch(String id, Duration expiry, TouchOptions options) Updates the expiry of the document with the given id with custom options.reactor.core.publisher.Mono<MutationResult> Updates the expiry of the document with the given id with default options.reactor.core.publisher.Mono<MutationResult> touch(String id, Instant expiry, TouchOptions options) Updates the expiry of the document with the given id with custom options.reactor.core.publisher.Mono<Void> Unlocks a document if it has been locked previously, with default options.reactor.core.publisher.Mono<Void> unlock(String id, long cas, UnlockOptions options) Unlocks a document if it has been locked previously, with custom options.reactor.core.publisher.Mono<MutationResult> Upserts a full document which might or might not exist yet with default options.reactor.core.publisher.Mono<MutationResult> upsert(String id, Object content, UpsertOptions options) Upserts a full document which might or might not exist yet with custom options.
- 
Method Details- 
asyncProvides access to the underlyingAsyncCollection.- Returns:
- returns the underlying AsyncCollection.
 
- 
nameReturns the name of this collection.
- 
bucketNameReturns the name of the bucket associated with this collection.
- 
scopeNameReturns the name of the scope associated with this collection.
- 
coreProvides access to the underlyingCore.
- 
environmentProvides access to the underlyingClusterEnvironment.
- 
binaryProvides access to the binary APIs, not used for JSON documents.- Returns:
- the ReactiveBinaryCollection.
 
- 
queryIndexesProvides access to query index management at the ReactiveCollection level.
- 
getFetches a Document from a collection with default options.- Parameters:
- id- the document id which is used to uniquely identify it.
- Returns:
- a Monoindicating once loaded or failed.
 
- 
getFetches a Document from a collection with custom options.- Parameters:
- id- the document id which is used to uniquely identify it.
- options- custom options to change the default behavior.
- Returns:
- a Monoindicating once loaded or failed
 
- 
getAndLockFetches a full document and write-locks it for the given duration with default options.Note that the client does not enforce an upper limit on the DurationlockTime. The maximum lock time by default on the server is 30 seconds. Any value larger than 30 seconds will be capped down by the server to the default lock time, which is 15 seconds unless modified on the server side.- Parameters:
- id- the document id which is used to uniquely identify it.
- lockTime- how long to write-lock the document for (any duration > 30s will be capped to server default of 15s).
- Returns:
- a Monocompleting once loaded or failed.
 
- 
getAndLockpublic reactor.core.publisher.Mono<GetResult> getAndLock(String id, Duration lockTime, GetAndLockOptions options) Fetches a full document and write-locks it for the given duration with custom options.Note that the client does not enforce an upper limit on the DurationlockTime. The maximum lock time by default on the server is 30 seconds. Any value larger than 30 seconds will be capped down by the server to the default lock time, which is 15 seconds unless modified on the server side.- Parameters:
- id- the document id which is used to uniquely identify it.
- lockTime- how long to write-lock the document for (any duration > 30s will be capped to server default of 15s).
- options- custom options to change the default behavior.
- Returns:
- a Monocompleting once loaded or failed.
 
- 
getAndTouchFetches a full document and resets its expiration time to the value provided with default options.- Parameters:
- id- the document id which is used to uniquely identify it.
- expiry- the new expiration time for the document.
- Returns:
- a Monocompleting once loaded or failed.
 
- 
getAndTouchpublic reactor.core.publisher.Mono<GetResult> getAndTouch(String id, Duration expiry, GetAndTouchOptions options) Fetches a full document and resets its expiration time to the value provided with custom options.- Parameters:
- id- the document id which is used to uniquely identify it.
- expiry- the new expiration time for the document.
- options- custom options to change the default behavior.
- Returns:
- a Monocompleting once loaded or failed.
 
- 
getAndTouchFetches a full document and resets its expiration time to the value provided with default options.- Parameters:
- id- the document id which is used to uniquely identify it.
- expiry- the new expiration time for the document.
- Returns:
- a Monocompleting once loaded or failed.
 
- 
getAndTouchpublic reactor.core.publisher.Mono<GetResult> getAndTouch(String id, Instant expiry, GetAndTouchOptions options) Fetches a full document and resets its expiration time to the value provided with custom options.- Parameters:
- id- the document id which is used to uniquely identify it.
- expiry- the new expiration time for the document.
- options- custom options to change the default behavior.
- Returns:
- a Monocompleting once loaded or failed.
 
- 
getAllReplicasReads all available replicas, including the active, and returns the results as a flux.Note that individual errors are ignored, so you can think of this API as a best effort approach which explicitly emphasises availability over consistency. If the read requests all fail, the flux emits nothing. - Parameters:
- id- the document id.
- Returns:
- a flux of results from all replicas
 
- 
getAllReplicaspublic reactor.core.publisher.Flux<GetReplicaResult> getAllReplicas(String id, GetAllReplicasOptions options) Reads all available replicas, including the active, and returns the results as a flux.Note that individual errors are ignored, so you can think of this API as a best effort approach which explicitly emphasises availability over consistency. If the read requests all fail, the flux emits nothing. - Parameters:
- id- the document id.
- options- the custom options.
- Returns:
- a flux of results from all replicas
 
- 
getAnyReplicaReads all available replicas, and returns the first found.If the read requests all fail, the mono emits nothing. - Parameters:
- id- the document id.
- Returns:
- a mono containing the first available replica.
 
- 
getAnyReplicapublic reactor.core.publisher.Mono<GetReplicaResult> getAnyReplica(String id, GetAnyReplicaOptions options) Reads all available replicas, and returns the first found.If the read requests all fail, the mono emits nothing. - Parameters:
- id- the document id.
- options- the custom options.
- Returns:
- a mono containing the first available replica.
 
- 
existsChecks if the given document ID exists on the active partition with default options.- Parameters:
- id- the document ID
- Returns:
- a Monocompleting once loaded or failed.
 
- 
existsChecks if the given document ID exists on the active partition with custom options.- Parameters:
- id- the document ID
- options- to modify the default behavior
- Returns:
- a Monocompleting once loaded or failed.
 
- 
removeRemoves a Document from a collection with default options.- Parameters:
- id- the id of the document to remove.
- Returns:
- a Monocompleting once removed or failed.
 
- 
removeRemoves a Document from a collection with custom options.- Parameters:
- id- the id of the document to remove.
- options- custom options to change the default behavior.
- Returns:
- a Monocompleting once removed or failed.
 
- 
insertInserts a full document which does not exist yet with default options.- Parameters:
- id- the document id to insert.
- content- the document content to insert.
- Returns:
- a Monocompleting once inserted or failed.
 
- 
insertpublic reactor.core.publisher.Mono<MutationResult> insert(String id, Object content, InsertOptions options) Inserts a full document which does not exist yet with custom options.- Parameters:
- id- the document id to insert.
- content- the document content to insert.
- options- custom options to customize the insert behavior.
- Returns:
- a Monocompleting once inserted or failed.
 
- 
upsertUpserts a full document which might or might not exist yet with default options.- Parameters:
- id- the document id to upsert.
- content- the document content to upsert.
- Returns:
- a Monocompleting once upserted or failed.
 
- 
upsertpublic reactor.core.publisher.Mono<MutationResult> upsert(String id, Object content, UpsertOptions options) Upserts a full document which might or might not exist yet with custom options.- Parameters:
- id- the document id to upsert.
- content- the document content to upsert.
- options- custom options to customize the upsert behavior.
- Returns:
- a Monocompleting once upserted or failed.
 
- 
replaceReplaces a full document which already exists with default options.- Parameters:
- id- the document id to replace.
- content- the document content to replace.
- Returns:
- a Monocompleting once replaced or failed.
 
- 
replacepublic reactor.core.publisher.Mono<MutationResult> replace(String id, Object content, ReplaceOptions options) Replaces a full document which already exists with custom options.- Parameters:
- id- the document id to replace.
- content- the document content to replace.
- options- custom options to customize the replace behavior.
- Returns:
- a Monocompleting once replaced or failed.
 
- 
touchUpdates the expiry of the document with the given id with default options.- Parameters:
- id- the id of the document to update.
- expiry- the new expiry for the document.
- Returns:
- a MutationResultonce the operation completes.
 
- 
touchpublic reactor.core.publisher.Mono<MutationResult> touch(String id, Duration expiry, TouchOptions options) Updates the expiry of the document with the given id with custom options.- Parameters:
- id- the id of the document to update.
- expiry- the new expiry for the document.
- options- the custom options.
- Returns:
- a MutationResultonce the operation completes.
 
- 
touchUpdates the expiry of the document with the given id with default options.- Parameters:
- id- the id of the document to update.
- expiry- the new expiry for the document.
- Returns:
- a MutationResultonce the operation completes.
 
- 
touchpublic reactor.core.publisher.Mono<MutationResult> touch(String id, Instant expiry, TouchOptions options) Updates the expiry of the document with the given id with custom options.- Parameters:
- id- the id of the document to update.
- expiry- the new expiry for the document.
- options- the custom options.
- Returns:
- a MutationResultonce the operation completes.
 
- 
unlockUnlocks a document if it has been locked previously, with default options.- Parameters:
- id- the id of the document.
- cas- the CAS value which is needed to unlock it.
- Returns:
- the mono which completes once a response has been received.
 
- 
unlockUnlocks a document if it has been locked previously, with custom options.- Parameters:
- id- the id of the document.
- cas- the CAS value which is needed to unlock it.
- options- the options to customize.
- Returns:
- the mono which completes once a response has been received.
 
- 
lookupInPerforms lookups to document fragments with default options.- Parameters:
- id- the outer document ID.
- specs- the spec which specifies the type of lookups to perform.
- Returns:
- the LookupInResultonce the lookup has been performed or failed.
 
- 
lookupInpublic reactor.core.publisher.Mono<LookupInResult> lookupIn(String id, List<LookupInSpec> specs, LookupInOptions options) Performs lookups to document fragments with custom options.- Parameters:
- id- the outer document ID.
- specs- the spec which specifies the type of lookups to perform.
- options- custom options to modify the lookup options.
- Returns:
- the LookupInResultonce the lookup has been performed or failed.
 
- 
mutateInPerforms mutations to document fragments with default options.- Parameters:
- id- the outer document ID.
- specs- the spec which specifies the type of mutations to perform.
- Returns:
- the MutateInResultonce the mutation has been performed or failed.
 
- 
mutateInpublic reactor.core.publisher.Mono<MutateInResult> mutateIn(String id, List<MutateInSpec> specs, MutateInOptions options) Performs mutations to document fragments with custom options.- Parameters:
- id- the outer document ID.
- specs- the spec which specifies the type of mutations to perform.
- options- custom options to modify the mutation options.
- Returns:
- the MutateInResultonce the mutation has been performed or failed.
 
- 
scanReturns a stream ofScanResultsperforming a Key-Value range scan with default options.CAVEAT: This method is suitable for use cases that require relatively low concurrency and tolerate relatively high latency. If your application does many scans at once, or requires low latency results, we recommend using SQL++ (with a primary index on the collection) instead. - Parameters:
- scanType- the type or range scan to perform.
- Returns:
- a Flux of ScanResults(potentially empty).
- Throws:
- TimeoutException- if the operation times out before getting a result.
- CouchbaseException- for all other error reasons (acts as a base type and catch-all).
 
- 
scan@SinceCouchbase("7.6") public reactor.core.publisher.Flux<ScanResult> scan(ScanType scanType, ScanOptions options) Returns a stream ofScanResultsperforming a Key-Value range scan with custom options.CAVEAT: This method is suitable for use cases that require relatively low concurrency and tolerate relatively high latency. If your application does many scans at once, or requires low latency results, we recommend using SQL++ (with a primary index on the collection) instead. - Parameters:
- scanType- the type or range scan to perform.
- options- a- ScanOptionsto customize the behavior of the scan operation.
- Returns:
- a Flux of ScanResults(potentially empty).
- Throws:
- TimeoutException- if the operation times out before getting a result.
- CouchbaseException- for all other error reasons (acts as a base type and catch-all).
 
- 
lookupInAllReplicas@SinceCouchbase("7.6") public reactor.core.publisher.Flux<LookupInReplicaResult> lookupInAllReplicas(String id, List<LookupInSpec> lookupInSpecs) Reads all available replicas, including the active, and returns the results as a flux.Note that individual errors are ignored, so you can think of this API as a best effort approach which explicitly emphasises availability over consistency. If the read requests all fail, the flux emits nothing. - Parameters:
- id- the document id.
- lookupInSpecs-
- Returns:
- a flux of results from all replicas
 
- 
lookupInAllReplicas@SinceCouchbase("7.6") public reactor.core.publisher.Flux<LookupInReplicaResult> lookupInAllReplicas(String id, List<LookupInSpec> lookupInSpecs, LookupInAllReplicasOptions options) Reads all available replicas, including the active, and returns the results as a flux.Note that individual errors are ignored, so you can think of this API as a best effort approach which explicitly emphasises availability over consistency. If the read requests all fail, the flux emits nothing. - Parameters:
- id- the document id.
- Returns:
- a flux of results from all replicas
 
- 
lookupInAnyReplica@SinceCouchbase("7.6") public reactor.core.publisher.Mono<LookupInReplicaResult> lookupInAnyReplica(String id, List<LookupInSpec> lookupInSpecs) Reads all available replicas, and returns the first found.If the read requests all fail, the mono emits nothing. - Parameters:
- id- the document id.
- Returns:
- a mono containing the first available replica.
 
- 
lookupInAnyReplica@SinceCouchbase("7.6") public reactor.core.publisher.Mono<LookupInReplicaResult> lookupInAnyReplica(String id, List<LookupInSpec> lookupInSpecs, LookupInAnyReplicaOptions options) Reads all available replicas, and returns the first found.If the read requests all fail, the mono emits nothing. - Parameters:
- id- the document id.
- options- the custom options.
- Returns:
- a mono containing the first available replica.
 
 
-