com.mongodb.ClientSessionOptions Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of mongo-java-driver Show documentation
Show all versions of mongo-java-driver Show documentation
The MongoDB Java Driver uber-artifact, containing mongodb-driver, mongodb-driver-core, and bson
/*
* 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 {@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.
*
* @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.
*
* @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
*
* @return a builder instance
*/
public static Builder builder() {
return new Builder();
}
/**
* 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 {@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.
*
* @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.
*
* @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.
*
* @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;
}
}