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

com.mongodb.internal.operation.BaseFindAndModifyOperation Maven / Gradle / Ivy

Go to download

The Java operations layer for the MongoDB Java Driver. Third parties can wrap this layer to provide custom higher-level APIs

There is a newer version: 5.3.0-beta0
Show newest version
/*
 * 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.internal.operation;

import com.mongodb.MongoNamespace;
import com.mongodb.WriteConcern;
import com.mongodb.client.model.Collation;
import com.mongodb.connection.ConnectionDescription;
import com.mongodb.internal.async.SingleResultCallback;
import com.mongodb.internal.binding.AsyncWriteBinding;
import com.mongodb.internal.binding.WriteBinding;
import com.mongodb.internal.session.SessionContext;
import com.mongodb.lang.Nullable;
import org.bson.BsonDocument;
import org.bson.BsonInt64;
import org.bson.BsonString;
import org.bson.BsonValue;
import org.bson.FieldNameValidator;
import org.bson.codecs.Decoder;

import java.util.concurrent.TimeUnit;

import static com.mongodb.assertions.Assertions.notNull;
import static com.mongodb.internal.operation.AsyncOperationHelper.executeRetryableWriteAsync;
import static com.mongodb.internal.operation.CommandOperationHelper.CommandCreator;
import static com.mongodb.internal.operation.DocumentHelper.putIfNotNull;
import static com.mongodb.internal.operation.DocumentHelper.putIfNotZero;
import static com.mongodb.internal.operation.OperationHelper.isRetryableWrite;
import static com.mongodb.internal.operation.OperationHelper.validateHintForFindAndModify;
import static com.mongodb.internal.operation.SyncOperationHelper.executeRetryableWrite;
import static java.util.concurrent.TimeUnit.MILLISECONDS;

/**
 * Abstract base class for findAndModify-based operations
 *
 * 

This class is not part of the public API and may be removed or changed at any time

*/ public abstract class BaseFindAndModifyOperation implements AsyncWriteOperation, WriteOperation { private final MongoNamespace namespace; private final WriteConcern writeConcern; private final boolean retryWrites; private final Decoder decoder; private BsonDocument filter; private BsonDocument projection; private BsonDocument sort; private long maxTimeMS; private Collation collation; private BsonDocument hint; private String hintString; private BsonValue comment; private BsonDocument variables; protected BaseFindAndModifyOperation(final MongoNamespace namespace, final WriteConcern writeConcern, final boolean retryWrites, final Decoder decoder) { this.namespace = notNull("namespace", namespace); this.writeConcern = notNull("writeConcern", writeConcern); this.retryWrites = retryWrites; this.decoder = notNull("decoder", decoder); } @Override public T execute(final WriteBinding binding) { return executeRetryableWrite(binding, getDatabaseName(), null, getFieldNameValidator(), CommandResultDocumentCodec.create(getDecoder(), "value"), getCommandCreator(binding.getSessionContext()), FindAndModifyHelper.transformer(), cmd -> cmd); } @Override public void executeAsync(final AsyncWriteBinding binding, final SingleResultCallback callback) { executeRetryableWriteAsync(binding, getDatabaseName(), null, getFieldNameValidator(), CommandResultDocumentCodec.create(getDecoder(), "value"), getCommandCreator(binding.getSessionContext()), FindAndModifyHelper.asyncTransformer(), cmd -> cmd, callback); } public MongoNamespace getNamespace() { return namespace; } public WriteConcern getWriteConcern() { return writeConcern; } public Decoder getDecoder() { return decoder; } public boolean isRetryWrites() { return retryWrites; } public BsonDocument getFilter() { return filter; } public BaseFindAndModifyOperation filter(@Nullable final BsonDocument filter) { this.filter = filter; return this; } public BsonDocument getProjection() { return projection; } public BaseFindAndModifyOperation projection(@Nullable final BsonDocument projection) { this.projection = projection; return this; } public long getMaxTime(final TimeUnit timeUnit) { notNull("timeUnit", timeUnit); return timeUnit.convert(maxTimeMS, MILLISECONDS); } public BaseFindAndModifyOperation maxTime(final long maxTime, final TimeUnit timeUnit) { notNull("timeUnit", timeUnit); this.maxTimeMS = MILLISECONDS.convert(maxTime, timeUnit); return this; } public BsonDocument getSort() { return sort; } public BaseFindAndModifyOperation sort(@Nullable final BsonDocument sort) { this.sort = sort; return this; } @Nullable public Collation getCollation() { return collation; } @Nullable public BsonDocument getHint() { return hint; } public BaseFindAndModifyOperation hint(@Nullable final BsonDocument hint) { this.hint = hint; return this; } @Nullable public String getHintString() { return hintString; } public BaseFindAndModifyOperation hintString(@Nullable final String hint) { this.hintString = hint; return this; } public BaseFindAndModifyOperation collation(@Nullable final Collation collation) { this.collation = collation; return this; } public BsonValue getComment() { return comment; } public BaseFindAndModifyOperation comment(@Nullable final BsonValue comment) { this.comment = comment; return this; } public BsonDocument getLet() { return variables; } public BaseFindAndModifyOperation let(@Nullable final BsonDocument variables) { this.variables = variables; return this; } protected abstract FieldNameValidator getFieldNameValidator(); protected abstract void specializeCommand(BsonDocument initialCommand, ConnectionDescription connectionDescription); private CommandCreator getCommandCreator(final SessionContext sessionContext) { return (serverDescription, connectionDescription) -> { BsonDocument commandDocument = new BsonDocument("findAndModify", new BsonString(getNamespace().getCollectionName())); putIfNotNull(commandDocument, "query", getFilter()); putIfNotNull(commandDocument, "fields", getProjection()); putIfNotNull(commandDocument, "sort", getSort()); specializeCommand(commandDocument, connectionDescription); putIfNotZero(commandDocument, "maxTimeMS", getMaxTime(MILLISECONDS)); if (getWriteConcern().isAcknowledged() && !getWriteConcern().isServerDefault() && !sessionContext.hasActiveTransaction()) { commandDocument.put("writeConcern", getWriteConcern().asDocument()); } if (getCollation() != null) { commandDocument.put("collation", getCollation().asDocument()); } if (getHint() != null || getHintString() != null) { validateHintForFindAndModify(connectionDescription, getWriteConcern()); if (getHint() != null) { commandDocument.put("hint", getHint()); } else { commandDocument.put("hint", new BsonString(getHintString())); } } putIfNotNull(commandDocument, "comment", getComment()); putIfNotNull(commandDocument, "let", getLet()); if (isRetryableWrite(isRetryWrites(), getWriteConcern(), connectionDescription, sessionContext)) { commandDocument.put("txnNumber", new BsonInt64(sessionContext.advanceTransactionNumber())); } return commandDocument; }; } private String getDatabaseName() { return getNamespace().getDatabaseName(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy