/*
 * Copyright 2008-present MongoDB, 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.mongodb;

import com.mongodb.annotations.Immutable;
import com.mongodb.annotations.NotThreadSafe;
import com.mongodb.lang.Nullable;
import com.mongodb.session.ClientSession;

import static com.mongodb.assertions.Assertions.notNull;

The options to apply to a ClientSession.
See Also:
@mongodb.server.release3.6
Since:3.6
@mongodb.driver.dochubcore/causal-consistency Causal Consistency
/** * The options to apply to a {@code ClientSession}. * * @mongodb.server.release 3.6 * @since 3.6 * @see ClientSession * @mongodb.driver.dochub core/causal-consistency Causal Consistency */
@Immutable public final class ClientSessionOptions { private final Boolean causallyConsistent; private final TransactionOptions defaultTransactionOptions;
Whether operations using the session should causally consistent with each other.
Returns:whether operations using the session should be causally consistent. A null value indicates to use the global default, which is currently true.
@mongodb.driver.dochubcore/causal-consistency Causal Consistency
/** * Whether operations using the session should causally consistent with each other. * * @return whether operations using the session should be causally consistent. A null value indicates to use the global default, * which is currently true. * @mongodb.driver.dochub core/causal-consistency Causal Consistency */
@Nullable public Boolean isCausallyConsistent() { return causallyConsistent; }
Gets the default transaction options for the session.
Returns:the default transaction options for the session
Since:3.8
@mongodb.server.release4.0
/** * Gets the default transaction options for the session. * * @return the default transaction options for the session * @since 3.8 * @mongodb.server.release 4.0 */
public TransactionOptions getDefaultTransactionOptions() { return defaultTransactionOptions; } @Override public boolean equals(final Object o) { if (this == o) { return true; } if (o == null || getClass() != o.getClass()) { return false; } ClientSessionOptions that = (ClientSessionOptions) o; if (causallyConsistent != null ? !causallyConsistent.equals(that.causallyConsistent) : that.causallyConsistent != null) { return false; } if (defaultTransactionOptions != null ? !defaultTransactionOptions.equals(that.defaultTransactionOptions) : that.defaultTransactionOptions != null) { return false; } return true; } @Override public int hashCode() { int result = causallyConsistent != null ? causallyConsistent.hashCode() : 0; result = 31 * result + (defaultTransactionOptions != null ? defaultTransactionOptions.hashCode() : 0); return result; } @Override public String toString() { return "ClientSessionOptions{" + "causallyConsistent=" + causallyConsistent + ", defaultTransactionOptions=" + defaultTransactionOptions + '}'; }
Gets an instance of a builder
Returns:a builder instance
/** * Gets an instance of a builder * * @return a builder instance */
public static Builder builder() { return new Builder(); }
Gets an instance of a builder initialized with the given options
Params:
  • options – the options with which to initialize the builder
Returns:a builder instance
Since:3.8
/** * Gets an instance of a builder initialized with the given options * * @param options the options with which to initialize the builder * @return a builder instance * @since 3.8 */
public static Builder builder(final ClientSessionOptions options) { notNull("options", options); Builder builder = new Builder(); builder.causallyConsistent = options.isCausallyConsistent(); builder.defaultTransactionOptions = options.getDefaultTransactionOptions(); return builder; }
A builder for instances of ClientSession
/** * A builder for instances of {@code ClientSession} */
@NotThreadSafe public static final class Builder { private Boolean causallyConsistent; private TransactionOptions defaultTransactionOptions = TransactionOptions.builder().build();
Sets whether operations using the session should causally consistent with each other.
Params:
  • causallyConsistent – whether operations using the session should be causally consistent
Returns:this
@mongodb.driver.dochubcore/causal-consistency Causal Consistency
/** * Sets whether operations using the session should causally consistent with each other. * * @param causallyConsistent whether operations using the session should be causally consistent * @return this * @mongodb.driver.dochub core/causal-consistency Causal Consistency */
public Builder causallyConsistent(final boolean causallyConsistent) { this.causallyConsistent = causallyConsistent; return this; }
Sets whether operations using the session should causally consistent with each other.
Params:
  • defaultTransactionOptions – the default transaction options to use for all transactions on this session,
Returns:this
Since:3.8
@mongodb.server.release4.0
/** * Sets whether operations using the session should causally consistent with each other. * * @param defaultTransactionOptions the default transaction options to use for all transactions on this session, * @return this * @since 3.8 * @mongodb.server.release 4.0 */
public Builder defaultTransactionOptions(final TransactionOptions defaultTransactionOptions) { this.defaultTransactionOptions = notNull("defaultTransactionOptions", defaultTransactionOptions); return this; }
Build the session options instance.
Returns:The ClientSessionOptions
/** * Build the session options instance. * * @return The {@code ClientSessionOptions} */
public ClientSessionOptions build() { return new ClientSessionOptions(this); } private Builder() { } } private ClientSessionOptions(final Builder builder) { this.causallyConsistent = builder.causallyConsistent; this.defaultTransactionOptions = builder.defaultTransactionOptions; } }