// Copyright (C) MongoDB, Inc. 2017-present. // // 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 package options // DefaultOrdered is the default order for a BulkWriteOptions struct created from BulkWrite. var DefaultOrdered = true // BulkWriteOptions represent all possible options for a bulkWrite operation. type BulkWriteOptions struct { BypassDocumentValidation *bool // If true, allows the write to opt out of document-level validation. Ordered *bool // If true, when a write fails, return without performing remaining writes. Defaults to true. } // BulkWrite creates a new *BulkWriteOptions func BulkWrite() *BulkWriteOptions { return &BulkWriteOptions{ Ordered: &DefaultOrdered, } } // SetOrdered configures the ordered option. If true, when a write fails, the function will return without attempting // remaining writes. Defaults to true. func (b *BulkWriteOptions) SetOrdered(ordered bool) *BulkWriteOptions { b.Ordered = &ordered return b } // SetBypassDocumentValidation specifies if the write should opt out of document-level validation. // Valid for server versions >= 3.2. For servers < 3.2, this option is ignored. func (b *BulkWriteOptions) SetBypassDocumentValidation(bypass bool) *BulkWriteOptions { b.BypassDocumentValidation = &bypass return b } // MergeBulkWriteOptions combines the given *BulkWriteOptions into a single *BulkWriteOptions in a last one wins fashion. func MergeBulkWriteOptions(opts ...*BulkWriteOptions) *BulkWriteOptions { b := BulkWrite() for _, opt := range opts { if opt == nil { continue } if opt.Ordered != nil { b.Ordered = opt.Ordered } if opt.BypassDocumentValidation != nil { b.BypassDocumentValidation = opt.BypassDocumentValidation } } return b }