/* Copyright 2010-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. */ using System; using System.Collections.Generic; using System.Linq; using MongoDB.Driver.Core.Misc; namespace MongoDB.Driver { /// /// Options for a findAndModify command to update an object. /// /// The type of the document. /// The type of the projection (same as TDocument if there is no projection). public class FindOneAndUpdateOptions { // fields private IEnumerable _arrayFilters; private bool? _bypassDocumentValidation; private Collation _collation; private bool _isUpsert; private TimeSpan? _maxTime; private ProjectionDefinition _projection; private ReturnDocument _returnDocument; private SortDefinition _sort; // constructors /// /// Initializes a new instance of the class. /// public FindOneAndUpdateOptions() { _returnDocument = ReturnDocument.Before; } // properties /// /// Gets or sets the array filters. /// /// /// The array filters. /// public IEnumerable ArrayFilters { get { return _arrayFilters; } set { _arrayFilters = value; } } /// /// Gets or sets a value indicating whether to bypass document validation. /// public bool? BypassDocumentValidation { get { return _bypassDocumentValidation; } set { _bypassDocumentValidation = value; } } /// /// Gets or sets the collation. /// public Collation Collation { get { return _collation; } set { _collation = value; } } /// /// Gets or sets a value indicating whether to insert the document if it doesn't already exist. /// public bool IsUpsert { get { return _isUpsert; } set { _isUpsert = value; } } /// /// Gets or sets the maximum time. /// public TimeSpan? MaxTime { get { return _maxTime; } set { _maxTime = Ensure.IsNullOrInfiniteOrGreaterThanOrEqualToZero(value, nameof(value)); } } /// /// Gets or sets the projection. /// public ProjectionDefinition Projection { get { return _projection; } set { _projection = value; } } /// /// Gets or sets which version of the document to return. /// public ReturnDocument ReturnDocument { get { return _returnDocument; } set { _returnDocument = value; } } /// /// Gets or sets the sort. /// public SortDefinition Sort { get { return _sort; } set { _sort = value; } } } /// /// Options for a findAndModify command to update an object. /// /// The type of the document and the result. public class FindOneAndUpdateOptions : FindOneAndUpdateOptions { } }