Documentation ¶
Index ¶
- Variables
- type AggregateOptions
- func (ao *AggregateOptions) SetAllowDiskUse(b bool) *AggregateOptions
- func (ao *AggregateOptions) SetBatchSize(i int32) *AggregateOptions
- func (ao *AggregateOptions) SetBypassDocumentValidation(b bool) *AggregateOptions
- func (ao *AggregateOptions) SetCollation(c *Collation) *AggregateOptions
- func (ao *AggregateOptions) SetComment(s string) *AggregateOptions
- func (ao *AggregateOptions) SetHint(h interface{}) *AggregateOptions
- func (ao *AggregateOptions) SetMaxAwaitTime(d time.Duration) *AggregateOptions
- func (ao *AggregateOptions) SetMaxTime(d time.Duration) *AggregateOptions
- type ArrayFilters
- type AutoEncryptionOptions
- func (a *AutoEncryptionOptions) SetBypassAutoEncryption(bypass bool) *AutoEncryptionOptions
- func (a *AutoEncryptionOptions) SetExtraOptions(extraOpts map[string]interface{}) *AutoEncryptionOptions
- func (a *AutoEncryptionOptions) SetKeyVaultClientOptions(opts *ClientOptions) *AutoEncryptionOptions
- func (a *AutoEncryptionOptions) SetKeyVaultNamespace(ns string) *AutoEncryptionOptions
- func (a *AutoEncryptionOptions) SetKmsProviders(providers map[string]map[string]interface{}) *AutoEncryptionOptions
- func (a *AutoEncryptionOptions) SetSchemaMap(schemaMap map[string]interface{}) *AutoEncryptionOptions
- type BucketOptions
- func (b *BucketOptions) SetChunkSizeBytes(i int32) *BucketOptions
- func (b *BucketOptions) SetName(name string) *BucketOptions
- func (b *BucketOptions) SetReadConcern(rc *readconcern.ReadConcern) *BucketOptions
- func (b *BucketOptions) SetReadPreference(rp *readpref.ReadPref) *BucketOptions
- func (b *BucketOptions) SetWriteConcern(wc *writeconcern.WriteConcern) *BucketOptions
- type BulkWriteOptions
- type ChangeStreamOptions
- func (cso *ChangeStreamOptions) SetBatchSize(i int32) *ChangeStreamOptions
- func (cso *ChangeStreamOptions) SetCollation(c Collation) *ChangeStreamOptions
- func (cso *ChangeStreamOptions) SetFullDocument(fd FullDocument) *ChangeStreamOptions
- func (cso *ChangeStreamOptions) SetMaxAwaitTime(d time.Duration) *ChangeStreamOptions
- func (cso *ChangeStreamOptions) SetResumeAfter(rt interface{}) *ChangeStreamOptions
- func (cso *ChangeStreamOptions) SetStartAfter(sa interface{}) *ChangeStreamOptions
- func (cso *ChangeStreamOptions) SetStartAtOperationTime(t *primitive.Timestamp) *ChangeStreamOptions
- type ClientEncryptionOptions
- type ClientOptions
- func (c *ClientOptions) ApplyURI(uri string) *ClientOptions
- func (c *ClientOptions) SetAppName(s string) *ClientOptions
- func (c *ClientOptions) SetAuth(auth Credential) *ClientOptions
- func (c *ClientOptions) SetAutoEncryptionOptions(opts *AutoEncryptionOptions) *ClientOptions
- func (c *ClientOptions) SetCompressors(comps []string) *ClientOptions
- func (c *ClientOptions) SetConnectTimeout(d time.Duration) *ClientOptions
- func (c *ClientOptions) SetDialer(d ContextDialer) *ClientOptions
- func (c *ClientOptions) SetDirect(b bool) *ClientOptions
- func (c *ClientOptions) SetHeartbeatInterval(d time.Duration) *ClientOptions
- func (c *ClientOptions) SetHosts(s []string) *ClientOptions
- func (c *ClientOptions) SetLocalThreshold(d time.Duration) *ClientOptions
- func (c *ClientOptions) SetMaxConnIdleTime(d time.Duration) *ClientOptions
- func (c *ClientOptions) SetMaxPoolSize(u uint64) *ClientOptions
- func (c *ClientOptions) SetMinPoolSize(u uint64) *ClientOptions
- func (c *ClientOptions) SetMonitor(m *event.CommandMonitor) *ClientOptions
- func (c *ClientOptions) SetPoolMonitor(m *event.PoolMonitor) *ClientOptions
- func (c *ClientOptions) SetReadConcern(rc *readconcern.ReadConcern) *ClientOptions
- func (c *ClientOptions) SetReadPreference(rp *readpref.ReadPref) *ClientOptions
- func (c *ClientOptions) SetRegistry(registry *bsoncodec.Registry) *ClientOptions
- func (c *ClientOptions) SetReplicaSet(s string) *ClientOptions
- func (c *ClientOptions) SetRetryReads(b bool) *ClientOptions
- func (c *ClientOptions) SetRetryWrites(b bool) *ClientOptions
- func (c *ClientOptions) SetServerSelectionTimeout(d time.Duration) *ClientOptions
- func (c *ClientOptions) SetSocketTimeout(d time.Duration) *ClientOptions
- func (c *ClientOptions) SetTLSConfig(cfg *tls.Config) *ClientOptions
- func (c *ClientOptions) SetWriteConcern(wc *writeconcern.WriteConcern) *ClientOptions
- func (c *ClientOptions) SetZlibLevel(level int) *ClientOptions
- func (c *ClientOptions) SetZstdLevel(level int) *ClientOptions
- func (c *ClientOptions) Validate() error
- type Collation
- type CollectionOptions
- func (c *CollectionOptions) SetReadConcern(rc *readconcern.ReadConcern) *CollectionOptions
- func (c *CollectionOptions) SetReadPreference(rp *readpref.ReadPref) *CollectionOptions
- func (c *CollectionOptions) SetRegistry(r *bsoncodec.Registry) *CollectionOptions
- func (c *CollectionOptions) SetWriteConcern(wc *writeconcern.WriteConcern) *CollectionOptions
- type ContextDialer
- type CountOptions
- func (co *CountOptions) SetCollation(c *Collation) *CountOptions
- func (co *CountOptions) SetHint(h interface{}) *CountOptions
- func (co *CountOptions) SetLimit(i int64) *CountOptions
- func (co *CountOptions) SetMaxTime(d time.Duration) *CountOptions
- func (co *CountOptions) SetSkip(i int64) *CountOptions
- type CreateIndexesOptions
- type Credential
- type CursorType
- type DataKeyOptions
- type DatabaseOptions
- func (d *DatabaseOptions) SetReadConcern(rc *readconcern.ReadConcern) *DatabaseOptions
- func (d *DatabaseOptions) SetReadPreference(rp *readpref.ReadPref) *DatabaseOptions
- func (d *DatabaseOptions) SetRegistry(r *bsoncodec.Registry) *DatabaseOptions
- func (d *DatabaseOptions) SetWriteConcern(wc *writeconcern.WriteConcern) *DatabaseOptions
- type DeleteOptions
- type DistinctOptions
- type DropIndexesOptions
- type EncryptOptions
- type EstimatedDocumentCountOptions
- type FindOneAndDeleteOptions
- func (f *FindOneAndDeleteOptions) SetCollation(collation *Collation) *FindOneAndDeleteOptions
- func (f *FindOneAndDeleteOptions) SetMaxTime(d time.Duration) *FindOneAndDeleteOptions
- func (f *FindOneAndDeleteOptions) SetProjection(projection interface{}) *FindOneAndDeleteOptions
- func (f *FindOneAndDeleteOptions) SetSort(sort interface{}) *FindOneAndDeleteOptions
- type FindOneAndReplaceOptions
- func (f *FindOneAndReplaceOptions) SetBypassDocumentValidation(b bool) *FindOneAndReplaceOptions
- func (f *FindOneAndReplaceOptions) SetCollation(collation *Collation) *FindOneAndReplaceOptions
- func (f *FindOneAndReplaceOptions) SetHint(hint interface{}) *FindOneAndReplaceOptions
- func (f *FindOneAndReplaceOptions) SetMaxTime(d time.Duration) *FindOneAndReplaceOptions
- func (f *FindOneAndReplaceOptions) SetProjection(projection interface{}) *FindOneAndReplaceOptions
- func (f *FindOneAndReplaceOptions) SetReturnDocument(rd ReturnDocument) *FindOneAndReplaceOptions
- func (f *FindOneAndReplaceOptions) SetSort(sort interface{}) *FindOneAndReplaceOptions
- func (f *FindOneAndReplaceOptions) SetUpsert(b bool) *FindOneAndReplaceOptions
- type FindOneAndUpdateOptions
- func (f *FindOneAndUpdateOptions) SetArrayFilters(filters ArrayFilters) *FindOneAndUpdateOptions
- func (f *FindOneAndUpdateOptions) SetBypassDocumentValidation(b bool) *FindOneAndUpdateOptions
- func (f *FindOneAndUpdateOptions) SetCollation(collation *Collation) *FindOneAndUpdateOptions
- func (f *FindOneAndUpdateOptions) SetHint(hint interface{}) *FindOneAndUpdateOptions
- func (f *FindOneAndUpdateOptions) SetMaxTime(d time.Duration) *FindOneAndUpdateOptions
- func (f *FindOneAndUpdateOptions) SetProjection(projection interface{}) *FindOneAndUpdateOptions
- func (f *FindOneAndUpdateOptions) SetReturnDocument(rd ReturnDocument) *FindOneAndUpdateOptions
- func (f *FindOneAndUpdateOptions) SetSort(sort interface{}) *FindOneAndUpdateOptions
- func (f *FindOneAndUpdateOptions) SetUpsert(b bool) *FindOneAndUpdateOptions
- type FindOneOptions
- func (f *FindOneOptions) SetAllowPartialResults(b bool) *FindOneOptions
- func (f *FindOneOptions) SetBatchSize(i int32) *FindOneOptions
- func (f *FindOneOptions) SetCollation(collation *Collation) *FindOneOptions
- func (f *FindOneOptions) SetComment(comment string) *FindOneOptions
- func (f *FindOneOptions) SetCursorType(ct CursorType) *FindOneOptions
- func (f *FindOneOptions) SetHint(hint interface{}) *FindOneOptions
- func (f *FindOneOptions) SetMax(max interface{}) *FindOneOptions
- func (f *FindOneOptions) SetMaxAwaitTime(d time.Duration) *FindOneOptions
- func (f *FindOneOptions) SetMaxTime(d time.Duration) *FindOneOptions
- func (f *FindOneOptions) SetMin(min interface{}) *FindOneOptions
- func (f *FindOneOptions) SetNoCursorTimeout(b bool) *FindOneOptions
- func (f *FindOneOptions) SetOplogReplay(b bool) *FindOneOptions
- func (f *FindOneOptions) SetProjection(projection interface{}) *FindOneOptions
- func (f *FindOneOptions) SetReturnKey(b bool) *FindOneOptions
- func (f *FindOneOptions) SetShowRecordID(b bool) *FindOneOptions
- func (f *FindOneOptions) SetSkip(i int64) *FindOneOptions
- func (f *FindOneOptions) SetSnapshot(b bool) *FindOneOptions
- func (f *FindOneOptions) SetSort(sort interface{}) *FindOneOptions
- type FindOptions
- func (f *FindOptions) SetAllowDiskUse(b bool) *FindOptions
- func (f *FindOptions) SetAllowPartialResults(b bool) *FindOptions
- func (f *FindOptions) SetBatchSize(i int32) *FindOptions
- func (f *FindOptions) SetCollation(collation *Collation) *FindOptions
- func (f *FindOptions) SetComment(comment string) *FindOptions
- func (f *FindOptions) SetCursorType(ct CursorType) *FindOptions
- func (f *FindOptions) SetHint(hint interface{}) *FindOptions
- func (f *FindOptions) SetLimit(i int64) *FindOptions
- func (f *FindOptions) SetMax(max interface{}) *FindOptions
- func (f *FindOptions) SetMaxAwaitTime(d time.Duration) *FindOptions
- func (f *FindOptions) SetMaxTime(d time.Duration) *FindOptions
- func (f *FindOptions) SetMin(min interface{}) *FindOptions
- func (f *FindOptions) SetNoCursorTimeout(b bool) *FindOptions
- func (f *FindOptions) SetOplogReplay(b bool) *FindOptions
- func (f *FindOptions) SetProjection(projection interface{}) *FindOptions
- func (f *FindOptions) SetReturnKey(b bool) *FindOptions
- func (f *FindOptions) SetShowRecordID(b bool) *FindOptions
- func (f *FindOptions) SetSkip(i int64) *FindOptions
- func (f *FindOptions) SetSnapshot(b bool) *FindOptions
- func (f *FindOptions) SetSort(sort interface{}) *FindOptions
- type FullDocument
- type GridFSFindOptions
- func (f *GridFSFindOptions) SetAllowDiskUse(b bool) *GridFSFindOptions
- func (f *GridFSFindOptions) SetBatchSize(i int32) *GridFSFindOptions
- func (f *GridFSFindOptions) SetLimit(i int32) *GridFSFindOptions
- func (f *GridFSFindOptions) SetMaxTime(d time.Duration) *GridFSFindOptions
- func (f *GridFSFindOptions) SetNoCursorTimeout(b bool) *GridFSFindOptions
- func (f *GridFSFindOptions) SetSkip(i int32) *GridFSFindOptions
- func (f *GridFSFindOptions) SetSort(sort interface{}) *GridFSFindOptions
- type IndexOptions
- func (i *IndexOptions) SetBackground(background bool) *IndexOptions
- func (i *IndexOptions) SetBits(bits int32) *IndexOptions
- func (i *IndexOptions) SetBucketSize(bucketSize int32) *IndexOptions
- func (i *IndexOptions) SetCollation(collation *Collation) *IndexOptions
- func (i *IndexOptions) SetDefaultLanguage(language string) *IndexOptions
- func (i *IndexOptions) SetExpireAfterSeconds(seconds int32) *IndexOptions
- func (i *IndexOptions) SetLanguageOverride(override string) *IndexOptions
- func (i *IndexOptions) SetMax(max float64) *IndexOptions
- func (i *IndexOptions) SetMin(min float64) *IndexOptions
- func (i *IndexOptions) SetName(name string) *IndexOptions
- func (i *IndexOptions) SetPartialFilterExpression(expression interface{}) *IndexOptions
- func (i *IndexOptions) SetSparse(sparse bool) *IndexOptions
- func (i *IndexOptions) SetSphereVersion(version int32) *IndexOptions
- func (i *IndexOptions) SetStorageEngine(engine interface{}) *IndexOptions
- func (i *IndexOptions) SetTextVersion(version int32) *IndexOptions
- func (i *IndexOptions) SetUnique(unique bool) *IndexOptions
- func (i *IndexOptions) SetVersion(version int32) *IndexOptions
- func (i *IndexOptions) SetWeights(weights interface{}) *IndexOptions
- func (i *IndexOptions) SetWildcardProjection(wildcardProjection interface{}) *IndexOptions
- type InsertManyOptions
- type InsertOneOptions
- type ListCollectionsOptions
- type ListDatabasesOptions
- type ListIndexesOptions
- type MarshalError
- type NameOptions
- type ReplaceOptions
- type ReturnDocument
- type RunCmdOptions
- type SessionOptions
- func (s *SessionOptions) SetCausalConsistency(b bool) *SessionOptions
- func (s *SessionOptions) SetDefaultMaxCommitTime(mct *time.Duration) *SessionOptions
- func (s *SessionOptions) SetDefaultReadConcern(rc *readconcern.ReadConcern) *SessionOptions
- func (s *SessionOptions) SetDefaultReadPreference(rp *readpref.ReadPref) *SessionOptions
- func (s *SessionOptions) SetDefaultWriteConcern(wc *writeconcern.WriteConcern) *SessionOptions
- type TransactionOptions
- func (t *TransactionOptions) SetMaxCommitTime(mct *time.Duration) *TransactionOptions
- func (t *TransactionOptions) SetReadConcern(rc *readconcern.ReadConcern) *TransactionOptions
- func (t *TransactionOptions) SetReadPreference(rp *readpref.ReadPref) *TransactionOptions
- func (t *TransactionOptions) SetWriteConcern(wc *writeconcern.WriteConcern) *TransactionOptions
- type UpdateOptions
- func (uo *UpdateOptions) SetArrayFilters(af ArrayFilters) *UpdateOptions
- func (uo *UpdateOptions) SetBypassDocumentValidation(b bool) *UpdateOptions
- func (uo *UpdateOptions) SetCollation(c *Collation) *UpdateOptions
- func (uo *UpdateOptions) SetHint(h interface{}) *UpdateOptions
- func (uo *UpdateOptions) SetUpsert(b bool) *UpdateOptions
- type UploadOptions
Constants ¶
This section is empty.
Variables ¶
var DefaultCausalConsistency = true
DefaultCausalConsistency is the default value for the CausalConsistency option.
var DefaultChunkSize int32 = 255 * 1024
DefaultChunkSize is the default size of each file chunk in bytes (255 KiB).
var DefaultName = "fs"
DefaultName is the default name for a GridFS bucket.
var DefaultOrdered = true
DefaultOrdered is the default value for the Ordered option in BulkWriteOptions.
var DefaultRevision int32 = -1
DefaultRevision is the default revision number for a download by name operation.
Functions ¶
This section is empty.
Types ¶
type AggregateOptions ¶ added in v0.1.0
type AggregateOptions struct { // If true, the operation can write to temporary files in the _tmp subdirectory of the database directory path on // the server. The default value is false. AllowDiskUse *bool // The maximum number of documents to be included in each batch returned by the server. BatchSize *int32 // If true, writes executed as part of the operation will opt out of document-level validation on the server. This // option is valid for MongoDB versions >= 3.2 and is ignored for previous server versions. The default value is // false. See https://docs.mongodb.com/manual/core/schema-validation/ for more information about document // validation. BypassDocumentValidation *bool // Specifies a collation to use for string comparisons during the operation. This option is only valid for MongoDB // versions >= 3.4. For previous server versions, the driver will return an error if this option is used. The // default value is nil, which means the default collation of the collection will be used. Collation *Collation // The maximum amount of time that the query can run on the server. The default value is nil, meaning that there // is no time limit for query execution. MaxTime *time.Duration // The maximum amount of time that the server should wait for new documents to satisfy a tailable cursor query. // This option is only valid for MongoDB versions >= 3.2 and is ignored for previous server versions. MaxAwaitTime *time.Duration // A string that will be included in server logs, profiling logs, and currentOp queries to help trace the operation. // The default is the empty string, which means that no comment will be included in the logs. Comment *string // The index to use for the aggregation. This should either be the index name as a string or the index specification // as a document. The hint does not apply to $lookup and $graphLookup aggregation stages. The default value is nil, // which means that no hint will be sent. Hint interface{} }
AggregateOptions represents options that can be used to configure an Aggregate operation.
func Aggregate ¶ added in v0.1.0
func Aggregate() *AggregateOptions
Aggregate creates a new AggregateOptions instance.
func MergeAggregateOptions ¶ added in v0.1.0
func MergeAggregateOptions(opts ...*AggregateOptions) *AggregateOptions
MergeAggregateOptions combines the given AggregateOptions instances into a single AggregateOptions in a last-one-wins fashion.
func (*AggregateOptions) SetAllowDiskUse ¶ added in v0.1.0
func (ao *AggregateOptions) SetAllowDiskUse(b bool) *AggregateOptions
SetAllowDiskUse sets the value for the AllowDiskUse field.
func (*AggregateOptions) SetBatchSize ¶ added in v0.1.0
func (ao *AggregateOptions) SetBatchSize(i int32) *AggregateOptions
SetBatchSize sets the value for the BatchSize field.
func (*AggregateOptions) SetBypassDocumentValidation ¶ added in v0.1.0
func (ao *AggregateOptions) SetBypassDocumentValidation(b bool) *AggregateOptions
SetBypassDocumentValidation sets the value for the BypassDocumentValidation field.
func (*AggregateOptions) SetCollation ¶ added in v0.1.0
func (ao *AggregateOptions) SetCollation(c *Collation) *AggregateOptions
SetCollation sets the value for the Collation field.
func (*AggregateOptions) SetComment ¶ added in v0.1.0
func (ao *AggregateOptions) SetComment(s string) *AggregateOptions
SetComment sets the value for the Comment field.
func (*AggregateOptions) SetHint ¶ added in v0.1.0
func (ao *AggregateOptions) SetHint(h interface{}) *AggregateOptions
SetHint sets the value for the Hint field.
func (*AggregateOptions) SetMaxAwaitTime ¶ added in v0.1.0
func (ao *AggregateOptions) SetMaxAwaitTime(d time.Duration) *AggregateOptions
SetMaxAwaitTime sets the value for the MaxAwaitTime field.
func (*AggregateOptions) SetMaxTime ¶ added in v0.1.0
func (ao *AggregateOptions) SetMaxTime(d time.Duration) *AggregateOptions
SetMaxTime sets the value for the MaxTime field.
type ArrayFilters ¶ added in v0.1.0
type ArrayFilters struct { Registry *bsoncodec.Registry // The registry to use for converting filters. Defaults to bson.DefaultRegistry. Filters []interface{} // The filters to apply }
ArrayFilters is used to hold filters for the array filters CRUD option. If a registry is nil, bson.DefaultRegistry will be used when converting the filter interfaces to BSON.
func (*ArrayFilters) ToArray ¶ added in v0.1.0
func (af *ArrayFilters) ToArray() ([]bson.Raw, error)
ToArray builds a []bson.Raw from the provided ArrayFilters.
func (*ArrayFilters) ToArrayDocument ¶ added in v1.1.0
func (af *ArrayFilters) ToArrayDocument() (bson.Raw, error)
ToArrayDocument builds a BSON array for the array filters CRUD option. If the registry for af is nil, bson.DefaultRegistry will be used when converting the filter interfaces to BSON.
type AutoEncryptionOptions ¶ added in v1.2.0
type AutoEncryptionOptions struct { KeyVaultClientOptions *ClientOptions KeyVaultNamespace string KmsProviders map[string]map[string]interface{} SchemaMap map[string]interface{} BypassAutoEncryption *bool ExtraOptions map[string]interface{} }
AutoEncryptionOptions represents options used to configure auto encryption/decryption behavior for a mongo.Client instance.
Automatic encryption is an enterprise only feature that only applies to operations on a collection. Automatic encryption is not supported for operations on a database or view, and operations that are not bypassed will result in error. Too bypass automatic encryption for all operations, set BypassAutoEncryption=true.
Auto encryption requires the authenticated user to have the listCollections privilege action.
If automatic encryption fails on an operation, use a MongoClient configured with bypassAutoEncryption=true and use ClientEncryption.encrypt() to manually encrypt values.
Enabling Client Side Encryption reduces the maximum document and message size (using a maxBsonObjectSize of 2MiB and maxMessageSizeBytes of 6MB) and may have a negative performance impact.
func AutoEncryption ¶ added in v1.2.0
func AutoEncryption() *AutoEncryptionOptions
AutoEncryption creates a new AutoEncryptionOptions configured with default values.
func MergeAutoEncryptionOptions ¶ added in v1.2.0
func MergeAutoEncryptionOptions(opts ...*AutoEncryptionOptions) *AutoEncryptionOptions
MergeAutoEncryptionOptions combines the argued AutoEncryptionOptions in a last-one wins fashion.
func (*AutoEncryptionOptions) SetBypassAutoEncryption ¶ added in v1.2.0
func (a *AutoEncryptionOptions) SetBypassAutoEncryption(bypass bool) *AutoEncryptionOptions
SetBypassAutoEncryption specifies whether or not auto encryption should be done.
func (*AutoEncryptionOptions) SetExtraOptions ¶ added in v1.2.0
func (a *AutoEncryptionOptions) SetExtraOptions(extraOpts map[string]interface{}) *AutoEncryptionOptions
SetExtraOptions specifies a map of options to configure the mongocryptd process.
func (*AutoEncryptionOptions) SetKeyVaultClientOptions ¶ added in v1.2.0
func (a *AutoEncryptionOptions) SetKeyVaultClientOptions(opts *ClientOptions) *AutoEncryptionOptions
SetKeyVaultClientOptions specifies options for the client used to communicate with the key vault collection. If this is not set, the client used to do encryption will be re-used for key vault communication.
func (*AutoEncryptionOptions) SetKeyVaultNamespace ¶ added in v1.2.0
func (a *AutoEncryptionOptions) SetKeyVaultNamespace(ns string) *AutoEncryptionOptions
SetKeyVaultNamespace specifies the namespace of the key vault collection. This is required.
func (*AutoEncryptionOptions) SetKmsProviders ¶ added in v1.2.0
func (a *AutoEncryptionOptions) SetKmsProviders(providers map[string]map[string]interface{}) *AutoEncryptionOptions
SetKmsProviders specifies options for KMS providers. This is required.
func (*AutoEncryptionOptions) SetSchemaMap ¶ added in v1.2.0
func (a *AutoEncryptionOptions) SetSchemaMap(schemaMap map[string]interface{}) *AutoEncryptionOptions
SetSchemaMap specifies a map from namespace to local schema document. Schemas supplied in the schemaMap only apply to configuring automatic encryption for client side encryption. Other validation rules in the JSON schema will not be enforced by the driver and will result in an error.
Supplying a schemaMap provides more security than relying on JSON Schemas obtained from the server. It protects against a malicious server advertising a false JSON Schema, which could trick the client into sending unencrypted data that should be encrypted.
type BucketOptions ¶ added in v0.1.0
type BucketOptions struct { // The name of the bucket. The default value is "fs". Name *string // The number of bytes in each chunk in the bucket. The default value is 255 KiB. ChunkSizeBytes *int32 // The write concern for the bucket. The default value is the write concern of the database from which the bucket // is created. WriteConcern *writeconcern.WriteConcern // The read concern for the bucket. The default value is the read concern of the database from which the bucket // is created. ReadConcern *readconcern.ReadConcern // The read preference for the bucket. The default value is the read preference of the database from which the // bucket is created. ReadPreference *readpref.ReadPref }
BucketOptions represents options that can be used to configure GridFS bucket.
func GridFSBucket ¶ added in v0.1.0
func GridFSBucket() *BucketOptions
GridFSBucket creates a new BucketOptions instance.
func MergeBucketOptions ¶ added in v0.1.0
func MergeBucketOptions(opts ...*BucketOptions) *BucketOptions
MergeBucketOptions combines the given BucketOptions instances into a single BucketOptions in a last-one-wins fashion.
func (*BucketOptions) SetChunkSizeBytes ¶ added in v0.1.0
func (b *BucketOptions) SetChunkSizeBytes(i int32) *BucketOptions
SetChunkSizeBytes sets the value for the ChunkSize field.
func (*BucketOptions) SetName ¶ added in v0.1.0
func (b *BucketOptions) SetName(name string) *BucketOptions
SetName sets the value for the Name field.
func (*BucketOptions) SetReadConcern ¶ added in v0.1.0
func (b *BucketOptions) SetReadConcern(rc *readconcern.ReadConcern) *BucketOptions
SetReadConcern sets the value for the ReadConcern field.
func (*BucketOptions) SetReadPreference ¶ added in v0.1.0
func (b *BucketOptions) SetReadPreference(rp *readpref.ReadPref) *BucketOptions
SetReadPreference sets the value for the ReadPreference field.
func (*BucketOptions) SetWriteConcern ¶ added in v0.1.0
func (b *BucketOptions) SetWriteConcern(wc *writeconcern.WriteConcern) *BucketOptions
SetWriteConcern sets the value for the WriteConcern field.
type BulkWriteOptions ¶ added in v0.1.0
type BulkWriteOptions struct { // If true, writes executed as part of the operation will opt out of document-level validation on the server. This // option is valid for MongoDB versions >= 3.2 and is ignored for previous server versions. The default value is // false. See https://docs.mongodb.com/manual/core/schema-validation/ for more information about document // validation. BypassDocumentValidation *bool // If true, no writes will be executed after one fails. The default value is true. Ordered *bool }
BulkWriteOptions represents options that can be used to configure a BulkWrite operation.
func BulkWrite ¶ added in v0.1.0
func BulkWrite() *BulkWriteOptions
BulkWrite creates a new *BulkWriteOptions instance.
func MergeBulkWriteOptions ¶ added in v0.1.0
func MergeBulkWriteOptions(opts ...*BulkWriteOptions) *BulkWriteOptions
MergeBulkWriteOptions combines the given BulkWriteOptions instances into a single BulkWriteOptions in a last-one-wins fashion.
func (*BulkWriteOptions) SetBypassDocumentValidation ¶ added in v0.1.0
func (b *BulkWriteOptions) SetBypassDocumentValidation(bypass bool) *BulkWriteOptions
SetBypassDocumentValidation sets the value for the BypassDocumentValidation field.
func (*BulkWriteOptions) SetOrdered ¶ added in v0.1.0
func (b *BulkWriteOptions) SetOrdered(ordered bool) *BulkWriteOptions
SetOrdered sets the value for the Ordered field.
type ChangeStreamOptions ¶ added in v0.1.0
type ChangeStreamOptions struct { // The maximum number of documents to be included in each batch returned by the server. BatchSize *int32 // Specifies a collation to use for string comparisons during the operation. This option is only valid for MongoDB // versions >= 3.4. For previous server versions, the driver will return an error if this option is used. The // default value is nil, which means the default collation of the collection will be used. Collation *Collation // Specifies whether the updated document should be returned in change notifications for update operations along // with the deltas describing the changes made to the document. The default is options.Default, which means that // the updated document will not be included in the change notification. FullDocument *FullDocument // The maximum amount of time that the server should wait for new documents to satisfy a tailable cursor query. MaxAwaitTime *time.Duration // A document specifying the logical starting point for the change stream. Only changes corresponding to an oplog // entry immediately after the resume token will be returned. If this is specified, StartAtOperationTime and // StartAfter must not be set. ResumeAfter interface{} // If specified, the change stream will only return changes that occurred at or after the given timestamp. This // option is only valid for MongoDB versions >= 4.0. If this is specified, ResumeAfter and StartAfter must not be // set. StartAtOperationTime *primitive.Timestamp // A document specifying the logical starting point for the change stream. This is similar to the ResumeAfter // option, but allows a resume token from an "invalidate" notification to be used. This allows a change stream on a // collection to be resumed after the collection has been dropped and recreated or renamed. Only changes // corresponding to an oplog entry immediately after the specified token will be returned. If this is specified, // ResumeAfter and StartAtOperationTime must not be set. This option is only valid for MongoDB versions >= 4.1.1. StartAfter interface{} }
ChangeStreamOptions represents options that can be used to configure a Watch operation.
func ChangeStream ¶ added in v0.1.0
func ChangeStream() *ChangeStreamOptions
ChangeStream creates a new ChangeStreamOptions instance.
func MergeChangeStreamOptions ¶ added in v0.1.0
func MergeChangeStreamOptions(opts ...*ChangeStreamOptions) *ChangeStreamOptions
MergeChangeStreamOptions combines the given ChangeStreamOptions instances into a single ChangeStreamOptions in a last-one-wins fashion.
func (*ChangeStreamOptions) SetBatchSize ¶ added in v0.1.0
func (cso *ChangeStreamOptions) SetBatchSize(i int32) *ChangeStreamOptions
SetBatchSize sets the value for the BatchSize field.
func (*ChangeStreamOptions) SetCollation ¶ added in v0.1.0
func (cso *ChangeStreamOptions) SetCollation(c Collation) *ChangeStreamOptions
SetCollation sets the value for the Collation field.
func (*ChangeStreamOptions) SetFullDocument ¶ added in v0.1.0
func (cso *ChangeStreamOptions) SetFullDocument(fd FullDocument) *ChangeStreamOptions
SetFullDocument sets the value for the FullDocument field.
func (*ChangeStreamOptions) SetMaxAwaitTime ¶ added in v0.1.0
func (cso *ChangeStreamOptions) SetMaxAwaitTime(d time.Duration) *ChangeStreamOptions
SetMaxAwaitTime sets the value for the MaxAwaitTime field.
func (*ChangeStreamOptions) SetResumeAfter ¶ added in v0.1.0
func (cso *ChangeStreamOptions) SetResumeAfter(rt interface{}) *ChangeStreamOptions
SetResumeAfter sets the value for the ResumeAfter field.
func (*ChangeStreamOptions) SetStartAfter ¶ added in v1.1.0
func (cso *ChangeStreamOptions) SetStartAfter(sa interface{}) *ChangeStreamOptions
SetStartAfter sets the value for the StartAfter field.
func (*ChangeStreamOptions) SetStartAtOperationTime ¶ added in v0.1.0
func (cso *ChangeStreamOptions) SetStartAtOperationTime(t *primitive.Timestamp) *ChangeStreamOptions
SetStartAtOperationTime sets the value for the StartAtOperationTime field.
type ClientEncryptionOptions ¶ added in v1.2.0
type ClientEncryptionOptions struct { KeyVaultNamespace string KmsProviders map[string]map[string]interface{} }
ClientEncryptionOptions represents all possible options used to configure a ClientEncryption instance.
func ClientEncryption ¶ added in v1.2.0
func ClientEncryption() *ClientEncryptionOptions
ClientEncryption creates a new ClientEncryptionOptions instance.
func MergeClientEncryptionOptions ¶ added in v1.2.0
func MergeClientEncryptionOptions(opts ...*ClientEncryptionOptions) *ClientEncryptionOptions
MergeClientEncryptionOptions combines the argued ClientEncryptionOptions in a last-one wins fashion.
func (*ClientEncryptionOptions) SetKeyVaultNamespace ¶ added in v1.2.0
func (c *ClientEncryptionOptions) SetKeyVaultNamespace(ns string) *ClientEncryptionOptions
SetKeyVaultNamespace specifies the namespace of the key vault collection. This is required.
func (*ClientEncryptionOptions) SetKmsProviders ¶ added in v1.2.0
func (c *ClientEncryptionOptions) SetKmsProviders(providers map[string]map[string]interface{}) *ClientEncryptionOptions
SetKmsProviders specifies options for KMS providers. This is required.
type ClientOptions ¶ added in v0.1.0
type ClientOptions struct { AppName *string Auth *Credential ConnectTimeout *time.Duration Compressors []string Dialer ContextDialer HeartbeatInterval *time.Duration Hosts []string LocalThreshold *time.Duration MaxConnIdleTime *time.Duration MaxPoolSize *uint64 MinPoolSize *uint64 PoolMonitor *event.PoolMonitor Monitor *event.CommandMonitor ReadConcern *readconcern.ReadConcern ReadPreference *readpref.ReadPref Registry *bsoncodec.Registry ReplicaSet *string RetryWrites *bool RetryReads *bool ServerSelectionTimeout *time.Duration Direct *bool SocketTimeout *time.Duration TLSConfig *tls.Config WriteConcern *writeconcern.WriteConcern ZlibLevel *int ZstdLevel *int AutoEncryptionOptions *AutoEncryptionOptions // These options are for internal use only and should not be set. They are deprecated and are // not part of the stability guarantee. They may be removed in the future. AuthenticateToAnything *bool Deployment driver.Deployment // contains filtered or unexported fields }
ClientOptions contains options to configure a Client instance. Each option can be set through setter functions. See documentation for each setter function for an explanation of the option.
func Client ¶ added in v0.1.0
func Client() *ClientOptions
Client creates a new ClientOptions instance.
func MergeClientOptions ¶ added in v0.1.0
func MergeClientOptions(opts ...*ClientOptions) *ClientOptions
MergeClientOptions combines the given *ClientOptions into a single *ClientOptions in a last one wins fashion. The specified options are merged with the existing options on the collection, with the specified options taking precedence.
func (*ClientOptions) ApplyURI ¶ added in v1.0.0
func (c *ClientOptions) ApplyURI(uri string) *ClientOptions
ApplyURI parses the given URI and sets options accordingly. The URI can contain host names, IPv4/IPv6 literals, or an SRV record that will be resolved when the Client is created. When using an SRV record, TLS support is implictly enabled. Specify the "tls=false" URI option to override this.
If the connection string contains any options that have previously been set, it will overwrite them. Options that correspond to multiple URI parameters, such as WriteConcern, will be completely overwritten if any of the query parameters are specified. If an option is set on ClientOptions after this method is called, that option will override any option applied via the connection string.
If the URI format is incorrect or there are conflicing options specified in the URI an error will be recorded and can be retrieved by calling Validate.
For more information about the URI format, see https://docs.mongodb.com/manual/reference/connection-string/. See mongo.Connect documentation for examples of using URIs for different Client configurations.
func (*ClientOptions) SetAppName ¶ added in v0.1.0
func (c *ClientOptions) SetAppName(s string) *ClientOptions
SetAppName specifies an application name that is sent to the server when creating new connections. It is used by the server to log connection and profiling information (e.g. slow query logs). This can also be set through the "appName" URI option (e.g "appName=example_application"). The default is empty, meaning no app name will be sent.
func (*ClientOptions) SetAuth ¶ added in v0.1.0
func (c *ClientOptions) SetAuth(auth Credential) *ClientOptions
SetAuth specifies a Credential containing options for configuring authentication. See the options.Credential documentation for more information about Credential fields. The default is an empty Credential, meaning no authentication will be configured.
func (*ClientOptions) SetAutoEncryptionOptions ¶ added in v1.2.0
func (c *ClientOptions) SetAutoEncryptionOptions(opts *AutoEncryptionOptions) *ClientOptions
SetAutoEncryptionOptions specifies an AutoEncryptionOptions instance to automatically encrypt and decrypt commands and their results. See the options.AutoEncryptionOptions documentation for more information about the supported options.
func (*ClientOptions) SetCompressors ¶ added in v1.0.0
func (c *ClientOptions) SetCompressors(comps []string) *ClientOptions
SetCompressors sets the compressors that can be used when communicating with a server. Valid values are:
1. "snappy" - requires server version >= 3.4
2. "zlib" - requires server version >= 3.6
- "zstd" - requires server version >= 4.2, and driver version >= 1.2.0 with cgo support enabled or driver version >= 1.3.0 without cgo
To use compression, it must be enabled on the server as well. If this option is specified, the driver will perform a negotiation with the server to determine a common list of of compressors and will use the first one in that list when performing operations. See https://docs.mongodb.com/manual/reference/program/mongod/#cmdoption-mongod-networkmessagecompressors for more information about how to enable this feature on the server.
This can also be set through the "compressors" URI option (e.g. "compressors=zstd,zlib,snappy"). The default is an empty slice, meaning no compression will be enabled.
func (*ClientOptions) SetConnectTimeout ¶ added in v0.1.0
func (c *ClientOptions) SetConnectTimeout(d time.Duration) *ClientOptions
SetConnectTimeout specifies a timeout that is used for creating connections to the server. If a custom Dialer is specified through SetDialer, this option must not be used. This can be set through ApplyURI with the "connectTimeoutMS" (e.g "connectTimeoutMS=30") option. If set to 0, no timeout will be used. The default is 30 seconds.
func (*ClientOptions) SetDialer ¶ added in v0.1.0
func (c *ClientOptions) SetDialer(d ContextDialer) *ClientOptions
SetDialer specifies a custom ContextDialer to be used to create new connections to the server. The default is a net.Dialer instance with a 300 second keepalive time.
func (*ClientOptions) SetDirect ¶ added in v1.0.0
func (c *ClientOptions) SetDirect(b bool) *ClientOptions
SetDirect specifies whether or not a direct connect should be made. To use this option, a URI with a single host must be specified through ApplyURI. If set to true, the driver will only connect to the host provided in the URI and will not discover other hosts in the cluster. This can also be set through the "connect" URI option with the following values:
1. "connect=direct" for direct connections
2. "connect=automatic" for automatic discovery.
The default is false ("automatic" in the connection string).
func (*ClientOptions) SetHeartbeatInterval ¶ added in v0.1.0
func (c *ClientOptions) SetHeartbeatInterval(d time.Duration) *ClientOptions
SetHeartbeatInterval specifies the amount of time to wait between periodic background server checks. This can also be set through the "heartbeatIntervalMS" URI option (e.g. "heartbeatIntervalMS=10000"). The default is 10 seconds.
func (*ClientOptions) SetHosts ¶ added in v0.1.0
func (c *ClientOptions) SetHosts(s []string) *ClientOptions
SetHosts specifies a list of host names or IP addresses for servers in a cluster. Both IPv4 and IPv6 addresses are supported. IPv6 literals must be enclosed in '[]' following RFC-2732 syntax.
Hosts can also be specified as a comma-separated list in a URI. For example, to include "localhost:27017" and "localhost:27018", a URI could be "mongodb://localhost:27017,localhost:27018". The default is ["localhost:27017"]
func (*ClientOptions) SetLocalThreshold ¶ added in v0.1.0
func (c *ClientOptions) SetLocalThreshold(d time.Duration) *ClientOptions
SetLocalThreshold specifies the width of the 'latency window': when choosing between multiple suitable servers for an operation, this is the acceptable non-negative delta between shortest and longest average round-trip times. A server within the latency window is selected randomly. This can also be set through the "localThresholdMS" URI option (e.g. "localThresholdMS=15000"). The default is 15 milliseconds.
func (*ClientOptions) SetMaxConnIdleTime ¶ added in v0.1.0
func (c *ClientOptions) SetMaxConnIdleTime(d time.Duration) *ClientOptions
SetMaxConnIdleTime specifies the maximum amount of time that a connection will remain idle in a connection pool before it is removed from the pool and closed. This can also be set through the "maxIdleTimeMS" URI option (e.g. "maxIdleTimeMS=10000"). The default is 0, meaning a connection can remain unused indefinitely.
func (*ClientOptions) SetMaxPoolSize ¶ added in v0.1.0
func (c *ClientOptions) SetMaxPoolSize(u uint64) *ClientOptions
SetMaxPoolSize specifies that maximum number of connections allowed in the driver's connection pool to each server. Requests to a server will block if this maximum is reached. This can also be set through the "maxPoolSize" URI option (e.g. "maxPoolSize=100"). The default is 100. If this is 0, it will be set to math.MaxInt64.
func (*ClientOptions) SetMinPoolSize ¶ added in v1.1.0
func (c *ClientOptions) SetMinPoolSize(u uint64) *ClientOptions
SetMinPoolSize specifies the minimum number of connections allowed in the driver's connection pool to each server. If this is non-zero, each server's pool will be maintained in the background to ensure that the size does not fall below the minimum. This can also be set through the "minPoolSize" URI option (e.g. "minPoolSize=100"). The default is 0.
func (*ClientOptions) SetMonitor ¶ added in v0.1.0
func (c *ClientOptions) SetMonitor(m *event.CommandMonitor) *ClientOptions
SetMonitor specifies a CommandMonitor to receive command events. See the event.CommandMonitor documentation for more information about the structure of the monitor and events that can be received.
func (*ClientOptions) SetPoolMonitor ¶ added in v1.1.0
func (c *ClientOptions) SetPoolMonitor(m *event.PoolMonitor) *ClientOptions
SetPoolMonitor specifies a PoolMonitor to receive connection pool events. See the event.PoolMonitor documentation for more information about the structure of the monitor and events that can be received.
func (*ClientOptions) SetReadConcern ¶ added in v0.1.0
func (c *ClientOptions) SetReadConcern(rc *readconcern.ReadConcern) *ClientOptions
SetReadConcern specifies the read concern to use for read operations. A read concern level can also be set through the "readConcernLevel" URI option (e.g. "readConcernLevel=majority"). The default is nil, meaning the server will use its configured default.
func (*ClientOptions) SetReadPreference ¶ added in v0.1.0
func (c *ClientOptions) SetReadPreference(rp *readpref.ReadPref) *ClientOptions
SetReadPreference specifies the read preference to use for read operations. This can also be set through the following URI options:
1. "readPreference" - Specifiy the read preference mode (e.g. "readPreference=primary").
2. "readPreferenceTags": Specify one or more read preference tags (e.g. "readPreferenceTags=region:south,datacenter:A").
3. "maxStalenessSeconds" (or "maxStaleness"): Specify a maximum replication lag for reads from secondaries in a replica set (e.g. "maxStalenessSeconds=10").
The default is readpref.Primary(). See https://docs.mongodb.com/manual/core/read-preference/#read-preference for more information about read preferences.
func (*ClientOptions) SetRegistry ¶ added in v0.1.0
func (c *ClientOptions) SetRegistry(registry *bsoncodec.Registry) *ClientOptions
SetRegistry specifies the BSON registry to use for BSON marshalling/unmarshalling operations. The default is bson.DefaultRegistry.
func (*ClientOptions) SetReplicaSet ¶ added in v0.1.0
func (c *ClientOptions) SetReplicaSet(s string) *ClientOptions
SetReplicaSet specifies the replica set name for the cluster. If specified, the cluster will be treated as a replica set and the driver will automatically discover all servers in the set, starting with the nodes specified through ApplyURI or SetHosts. All nodes in the replica set must have the same replica set name, or they will not be considered as part of the set by the Client. This can also be set through the "replicaSet" URI option (e.g. "replicaSet=replset"). The default is empty.
func (*ClientOptions) SetRetryReads ¶ added in v1.2.0
func (c *ClientOptions) SetRetryReads(b bool) *ClientOptions
SetRetryReads specifies whether supported read operations should be retried once on certain errors, such as network errors.
Supported operations are Find, FindOne, Aggregate without a $out stage, Distinct, CountDocuments, EstimatedDocumentCount, Watch (for Client, Database, and Collection), ListCollections, and ListDatabases. Note that operations run through RunCommand are not retried.
This option requires server version >= 3.6 and driver version >= 1.1.0. The default is true.
func (*ClientOptions) SetRetryWrites ¶ added in v0.1.0
func (c *ClientOptions) SetRetryWrites(b bool) *ClientOptions
SetRetryWrites specifies whether supported write operations should be retried once on certain errors, such as network errors.
Supported operations are InsertOne, UpdateOne, ReplaceOne, DeleteOne, FindOneAndDelete, FindOneAndReplace, FindOneAndDelete, InsertMany, and BulkWrite. Note that BulkWrite requests must not include UpdateManyModel or DeleteManyModel instances to be considered retryable. Unacknowledged writes will not be retried, even if this option is set to true.
This option requires server version >= 3.6 and a replica set or sharded cluster and will be ignored for any other cluster type. This can also be set through the "retryWrites" URI option (e.g. "retryWrites=true"). The default is true.
func (*ClientOptions) SetServerSelectionTimeout ¶ added in v0.1.0
func (c *ClientOptions) SetServerSelectionTimeout(d time.Duration) *ClientOptions
SetServerSelectionTimeout specifies how long the driver will wait to find an available, suitable server to execute an operation. This can also be set through the "serverSelectionTimeoutMS" URI option (e.g. "serverSelectionTimeoutMS=30000"). The default value is 30 seconds.
func (*ClientOptions) SetSocketTimeout ¶ added in v0.1.0
func (c *ClientOptions) SetSocketTimeout(d time.Duration) *ClientOptions
SetSocketTimeout specifies how long the driver will wait for a socket read or write to return before returning a network error. This can also be set through the "socketTimeoutMS" URI option (e.g. "socketTimeoutMS=1000"). The default value is 0, meaning no timeout is used and socket operations can block indefinitely.
func (*ClientOptions) SetTLSConfig ¶ added in v1.0.0
func (c *ClientOptions) SetTLSConfig(cfg *tls.Config) *ClientOptions
SetTLSConfig specifies a tls.Config instance to use use to configure TLS on all connections created to the cluster. This can also be set through the following URI options:
1. "tls" (or "ssl"): Specify if TLS should be used (e.g. "tls=true").
2. Either "tlsCertificateKeyFile" (or "sslClientCertificateKeyFile") or a combination of "tlsCertificateFile" and "tlsPrivateKeyFile". The "tlsCertificateKeyFile" option specifies a path to the client certificate and private key, which must be concatenated into one file. The "tlsCertificateFile" and "tlsPrivateKey" combination specifies separate paths to the client certificate and private key, respectively. Note that if "tlsCertificateKeyFile" is used, the other two options must not be specified.
3. "tlsCertificateKeyFilePassword" (or "sslClientCertificateKeyPassword"): Specify the password to decrypt the client private key file (e.g. "tlsCertificateKeyFilePassword=password").
4. "tlsCaFile" (or "sslCertificateAuthorityFile"): Specify the path to a single or bundle of certificate authorities to be considered trusted when making a TLS connection (e.g. "tlsCaFile=/path/to/caFile").
5. "tlsInsecure" (or "sslInsecure"): Specifies whether or not certificates and hostnames received from the server should be validated. If true (e.g. "tlsInsecure=true"), the TLS library will accept any certificate presented by the server and any host name in that certificate. Note that setting this to true makes TLS susceptible to man-in-the-middle attacks and should only be done for testing.
The default is nil, meaning no TLS will be enabled.
func (*ClientOptions) SetWriteConcern ¶ added in v0.1.0
func (c *ClientOptions) SetWriteConcern(wc *writeconcern.WriteConcern) *ClientOptions
SetWriteConcern specifies the write concern to use to for write operations. This can also be set through the following URI options:
1. "w": Specify the number of nodes in the cluster that must acknowledge write operations before the operation returns or "majority" to specify that a majority of the nodes must acknowledge writes. This can either be an integer (e.g. "w=10") or the string "majority" (e.g. "w=majority").
2. "wTimeoutMS": Specify how long write operations should wait for the correct number of nodes to acknowledge the operation (e.g. "wTimeoutMS=1000").
3. "journal": Specifies whether or not write operations should be written to an on-disk journal on the server before returning (e.g. "journal=true").
The default is nil, meaning the server will use its configured default.
func (*ClientOptions) SetZlibLevel ¶ added in v1.0.0
func (c *ClientOptions) SetZlibLevel(level int) *ClientOptions
SetZlibLevel specifies the level for the zlib compressor. This option is ignored if zlib is not specified as a compressor through ApplyURI or SetCompressors. Supported values are -1 through 9, inclusive. -1 tells the zlib library to use its default, 0 means no compression, 1 means best speed, and 9 means best compression. This can also be set through the "zlibCompressionLevel" URI option (e.g. "zlibCompressionLevel=-1"). Defaults to -1.
func (*ClientOptions) SetZstdLevel ¶ added in v1.2.0
func (c *ClientOptions) SetZstdLevel(level int) *ClientOptions
SetZstdLevel sets the level for the zstd compressor. This option is ignored if zstd is not specified as a compressor through ApplyURI or SetCompressors. Supported values are 1 through 20, inclusive. 1 means best speed and 20 means best compression. This can also be set through the "zstdCompressionLevel" URI option. Defaults to 6.
func (*ClientOptions) Validate ¶ added in v1.0.0
func (c *ClientOptions) Validate() error
Validate validates the client options. This method will return the first error found.
type Collation ¶ added in v0.1.0
type Collation struct { Locale string `bson:",omitempty"` // The locale CaseLevel bool `bson:",omitempty"` // The case level CaseFirst string `bson:",omitempty"` // The case ordering Strength int `bson:",omitempty"` // The number of comparision levels to use NumericOrdering bool `bson:",omitempty"` // Whether to order numbers based on numerical order and not collation order Alternate string `bson:",omitempty"` // Whether spaces and punctuation are considered base characters MaxVariable string `bson:",omitempty"` // Which characters are affected by alternate: "shifted" Normalization bool `bson:",omitempty"` // Causes text to be normalized into Unicode NFD Backwards bool `bson:",omitempty"` // Causes secondary differences to be considered in reverse order, as it is done in the French language }
Collation allows users to specify language-specific rules for string comparison, such as rules for lettercase and accent marks.
func (*Collation) ToDocument ¶ added in v0.1.0
ToDocument converts the Collation to a bson.Raw.
type CollectionOptions ¶ added in v0.1.0
type CollectionOptions struct { // The read concern to use for operations executed on the Collection. The default value is nil, which means that // the read concern of the database used to configure the Collection will be used. ReadConcern *readconcern.ReadConcern // The write concern to use for operations executed on the Collection. The default value is nil, which means that // the write concern of the database used to configure the Collection will be used. WriteConcern *writeconcern.WriteConcern // The read preference to use for operations executed on the Collection. The default value is nil, which means that // the read preference of the database used to configure the Collection will be used. ReadPreference *readpref.ReadPref // The BSON registry to marshal and unmarshal documents for operations executed on the Collection. The default value // is nil, which means that the registry of the database used to configure the Collection will be used. Registry *bsoncodec.Registry }
CollectionOptions represents options that can be used to configure a Collection.
func Collection ¶ added in v0.1.0
func Collection() *CollectionOptions
Collection creates a new CollectionOptions instance.
func MergeCollectionOptions ¶ added in v0.1.0
func MergeCollectionOptions(opts ...*CollectionOptions) *CollectionOptions
MergeCollectionOptions combines the given CollectionOptions instances into a single *CollectionOptions in a last-one-wins fashion.
func (*CollectionOptions) SetReadConcern ¶ added in v0.1.0
func (c *CollectionOptions) SetReadConcern(rc *readconcern.ReadConcern) *CollectionOptions
SetReadConcern sets the value for the ReadConcern field.
func (*CollectionOptions) SetReadPreference ¶ added in v0.1.0
func (c *CollectionOptions) SetReadPreference(rp *readpref.ReadPref) *CollectionOptions
SetReadPreference sets the value for the ReadPreference field.
func (*CollectionOptions) SetRegistry ¶ added in v0.1.0
func (c *CollectionOptions) SetRegistry(r *bsoncodec.Registry) *CollectionOptions
SetRegistry sets the value for the Registry field.
func (*CollectionOptions) SetWriteConcern ¶ added in v0.1.0
func (c *CollectionOptions) SetWriteConcern(wc *writeconcern.WriteConcern) *CollectionOptions
SetWriteConcern sets the value for the WriteConcern field.
type ContextDialer ¶ added in v0.1.0
type ContextDialer interface {
DialContext(ctx context.Context, network, address string) (net.Conn, error)
}
ContextDialer is an interface that can be implemented by types that can create connections. It should be used to provide a custom dialer when configuring a Client.
DialContext should return a connection to the provided address on the given network.
type CountOptions ¶ added in v0.1.0
type CountOptions struct { // Specifies a collation to use for string comparisons during the operation. This option is only valid for MongoDB // versions >= 3.4. For previous server versions, the driver will return an error if this option is used. The // default value is nil, which means the default collation of the collection will be used. Collation *Collation // The index to use for the aggregation. This should either be the index name as a string or the index specification // as a document. The default value is nil, which means that no hint will be sent. Hint interface{} // The maximum number of documents to count. The default value is 0, which means that there is no limit and all // documents matching the filter will be counted. Limit *int64 // The maximum amount of time that the query can run on the server. The default value is nil, meaning that there is // no time limit for query execution. MaxTime *time.Duration // The number of documents to skip before counting. The default value is 0. Skip *int64 }
CountOptions represents options that can be used to configure a CountDocuments operation.
func MergeCountOptions ¶ added in v0.1.0
func MergeCountOptions(opts ...*CountOptions) *CountOptions
MergeCountOptions combines the given CountOptions instances into a single CountOptions in a last-one-wins fashion.
func (*CountOptions) SetCollation ¶ added in v0.1.0
func (co *CountOptions) SetCollation(c *Collation) *CountOptions
SetCollation sets the value for the Collation field.
func (*CountOptions) SetHint ¶ added in v0.1.0
func (co *CountOptions) SetHint(h interface{}) *CountOptions
SetHint sets the value for the Hint field.
func (*CountOptions) SetLimit ¶ added in v0.1.0
func (co *CountOptions) SetLimit(i int64) *CountOptions
SetLimit sets the value for the Limit field.
func (*CountOptions) SetMaxTime ¶ added in v0.1.0
func (co *CountOptions) SetMaxTime(d time.Duration) *CountOptions
SetMaxTime sets the value for the MaxTime field.
func (*CountOptions) SetSkip ¶ added in v0.1.0
func (co *CountOptions) SetSkip(i int64) *CountOptions
SetSkip sets the value for the Skip field.
type CreateIndexesOptions ¶ added in v0.1.0
type CreateIndexesOptions struct { // The maximum amount of time that the query can run on the server. The default value is nil, meaning that there // is no time limit for query execution. MaxTime *time.Duration }
CreateIndexesOptions represents options that can be used to configure IndexView.CreateOne and IndexView.CreateMany operations.
func CreateIndexes ¶ added in v0.1.0
func CreateIndexes() *CreateIndexesOptions
CreateIndexes creates a new CreateIndexesOptions instance.
func MergeCreateIndexesOptions ¶ added in v0.1.0
func MergeCreateIndexesOptions(opts ...*CreateIndexesOptions) *CreateIndexesOptions
MergeCreateIndexesOptions combines the given CreateIndexesOptions into a single CreateIndexesOptions in a last one wins fashion.
func (*CreateIndexesOptions) SetMaxTime ¶ added in v0.1.0
func (c *CreateIndexesOptions) SetMaxTime(d time.Duration) *CreateIndexesOptions
SetMaxTime sets the value for the MaxTime field.
type Credential ¶ added in v0.1.0
type Credential struct { AuthMechanism string AuthMechanismProperties map[string]string AuthSource string Username string Password string PasswordSet bool }
Credential can be used to provide authentication options when configuring a Client.
AuthMechanism: the mechanism to use for authentication. Supported values include "SCRAM-SHA-256", "SCRAM-SHA-1", "MONGODB-CR", "PLAIN", "GSSAPI", and "MONGODB-X509". This can also be set through the "authMechanism" URI option. (e.g. "authMechanism=PLAIN"). For more information, see https://docs.mongodb.com/manual/core/authentication-mechanisms/.
AuthMechanismProperties can be used to specify additional configuration options for certain mechanisms. They can also be set through the "authMechanismProperites" URI option (e.g. "authMechanismProperties=SERVICE_NAME:service,CANONICALIZE_HOST_NAME:true"). Supported properties are:
1. SERVICE_NAME: The service name to use for GSSAPI authentication. The default is "mongodb".
2. CANONICALIZE_HOST_NAME: If "true", the driver will canonicalize the host name for GSSAPI authentication. The default is "false".
3. SERVICE_REALM: The service realm for GSSAPI authentication.
4. SERVICE_HOST: The host name to use for GSSAPI authentication. This should be specified if the host name to use for authentication is different than the one given for Client construction.
The SERVICE_HOST and CANONICALIZE_HOST_NAME properties must not be used at the same time on Linux and Darwin systems.
AuthSource: the name of the database to use for authentication. This defaults to "$external" for MONGODB-X509, GSSAPI, and PLAIN and "admin" for all other mechanisms. This can also be set through the "authSource" URI option (e.g. "authSource=otherDb").
Username: the username for authentication. This can also be set through the URI as a username:password pair before the first @ character. For example, a URI for user "user", password "pwd", and host "localhost:27017" would be "mongodb://user:pwd@localhost:27017". This is optional for X509 authentication and will be extracted from the client certificate if not specified.
Password: the password for authentication. This must not be specified for X509 and is optional for GSSAPI authentication.
PasswordSet: For GSSAPI, this must be true if a password is specified, even if the password is the empty string, and false if no password is specified, indicating that the password should be taken from the context of the running process. For other mechanisms, this field is ignored.
type CursorType ¶
type CursorType int8
CursorType specifies whether a cursor should close when the last data is retrieved. See NonTailable, Tailable, and TailableAwait.
const ( // NonTailable specifies that a cursor should close after retrieving the last data. NonTailable CursorType = iota // Tailable specifies that a cursor should not close when the last data is retrieved and can be resumed later. Tailable // TailableAwait specifies that a cursor should not close when the last data is retrieved and // that it should block for a certain amount of time for new data before returning no data. TailableAwait )
type DataKeyOptions ¶ added in v1.2.0
type DataKeyOptions struct { MasterKey interface{} KeyAltNames []string }
DataKeyOptions represents all possible options used to create a new data key.
func DataKey ¶ added in v1.2.0
func DataKey() *DataKeyOptions
DataKey creates a new DataKeyOptions instance.
func MergeDataKeyOptions ¶ added in v1.2.0
func MergeDataKeyOptions(opts ...*DataKeyOptions) *DataKeyOptions
MergeDataKeyOptions combines the argued DataKeyOptions in a last-one wins fashion.
func (*DataKeyOptions) SetKeyAltNames ¶ added in v1.2.0
func (dk *DataKeyOptions) SetKeyAltNames(keyAltNames []string) *DataKeyOptions
SetKeyAltNames specifies an optional list of string alternate names used to reference a key. If a key is created' with alternate names, encryption may refer to the key by a unique alternate name instead of by _id.
func (*DataKeyOptions) SetMasterKey ¶ added in v1.2.0
func (dk *DataKeyOptions) SetMasterKey(masterKey interface{}) *DataKeyOptions
SetMasterKey specifies a KMS-specific key used to encrypt the new data key.
If being used with the AWS KMS provider, this option is required and must be a document with the following format: {region: string, key: string}.
If being used with a local KMS provider, this option is not applicable and should not be specified.
type DatabaseOptions ¶ added in v0.1.0
type DatabaseOptions struct { // The read concern to use for operations executed on the Database. The default value is nil, which means that // the read concern of the client used to configure the Database will be used. ReadConcern *readconcern.ReadConcern // The write concern to use for operations executed on the Database. The default value is nil, which means that the // write concern of the client used to configure the Database will be used. WriteConcern *writeconcern.WriteConcern // The read preference to use for operations executed on the Database. The default value is nil, which means that // the read preference of the client used to configure the Database will be used. ReadPreference *readpref.ReadPref // The BSON registry to marshal and unmarshal documents for operations executed on the Database. The default value // is nil, which means that the registry of the client used to configure the Database will be used. Registry *bsoncodec.Registry }
DatabaseOptions represents options that can be used to configure a Database.
func Database ¶ added in v0.1.0
func Database() *DatabaseOptions
Database creates a new DatabaseOptions instance.
func MergeDatabaseOptions ¶ added in v0.1.0
func MergeDatabaseOptions(opts ...*DatabaseOptions) *DatabaseOptions
MergeDatabaseOptions combines the given DatabaseOptions instances into a single DatabaseOptions in a last-one-wins fashion.
func (*DatabaseOptions) SetReadConcern ¶ added in v0.1.0
func (d *DatabaseOptions) SetReadConcern(rc *readconcern.ReadConcern) *DatabaseOptions
SetReadConcern sets the value for the ReadConcern field.
func (*DatabaseOptions) SetReadPreference ¶ added in v0.1.0
func (d *DatabaseOptions) SetReadPreference(rp *readpref.ReadPref) *DatabaseOptions
SetReadPreference sets the value for the ReadPreference field.
func (*DatabaseOptions) SetRegistry ¶ added in v0.1.0
func (d *DatabaseOptions) SetRegistry(r *bsoncodec.Registry) *DatabaseOptions
SetRegistry sets the value for the Registry field.
func (*DatabaseOptions) SetWriteConcern ¶ added in v0.1.0
func (d *DatabaseOptions) SetWriteConcern(wc *writeconcern.WriteConcern) *DatabaseOptions
SetWriteConcern sets the value for the WriteConcern field.
type DeleteOptions ¶ added in v0.1.0
type DeleteOptions struct { // Specifies a collation to use for string comparisons during the operation. This option is only valid for MongoDB // versions >= 3.4. For previous server versions, the driver will return an error if this option is used. The // default value is nil, which means the default collation of the collection will be used. Collation *Collation }
DeleteOptions represents options that can be used to configure DeleteOne and DeleteMany operations.
func Delete ¶ added in v0.1.0
func Delete() *DeleteOptions
Delete creates a new DeleteOptions instance.
func MergeDeleteOptions ¶ added in v0.1.0
func MergeDeleteOptions(opts ...*DeleteOptions) *DeleteOptions
MergeDeleteOptions combines the given DeleteOptions instances into a single DeleteOptions in a last-one-wins fashion.
func (*DeleteOptions) SetCollation ¶ added in v0.1.0
func (do *DeleteOptions) SetCollation(c *Collation) *DeleteOptions
SetCollation sets the value for the Collation field.
type DistinctOptions ¶ added in v0.1.0
type DistinctOptions struct { // Specifies a collation to use for string comparisons during the operation. This option is only valid for MongoDB // versions >= 3.4. For previous server versions, the driver will return an error if this option is used. The // default value is nil, which means the default collation of the collection will be used. Collation *Collation // The maximum amount of time that the query can run on the server. The default value is nil, meaning that there // is no time limit for query execution. MaxTime *time.Duration }
DistinctOptions represents options that can be used to configure a Distinct operation.
func Distinct ¶ added in v0.1.0
func Distinct() *DistinctOptions
Distinct creates a new DistinctOptions instance.
func MergeDistinctOptions ¶ added in v0.1.0
func MergeDistinctOptions(opts ...*DistinctOptions) *DistinctOptions
MergeDistinctOptions combines the given DistinctOptions instances into a single DistinctOptions in a last-one-wins fashion.
func (*DistinctOptions) SetCollation ¶ added in v0.1.0
func (do *DistinctOptions) SetCollation(c *Collation) *DistinctOptions
SetCollation sets the value for the Collation field.
func (*DistinctOptions) SetMaxTime ¶ added in v0.1.0
func (do *DistinctOptions) SetMaxTime(d time.Duration) *DistinctOptions
SetMaxTime sets the value for the MaxTime field.
type DropIndexesOptions ¶ added in v0.1.0
type DropIndexesOptions struct { // The maximum amount of time that the query can run on the server. The default value is nil, meaning that there // is no time limit for query execution. MaxTime *time.Duration }
DropIndexesOptions represents options that can be used to configure IndexView.DropOne and IndexView.DropAll operations.
func DropIndexes ¶ added in v0.1.0
func DropIndexes() *DropIndexesOptions
DropIndexes creates a new DropIndexesOptions instance.
func MergeDropIndexesOptions ¶ added in v0.1.0
func MergeDropIndexesOptions(opts ...*DropIndexesOptions) *DropIndexesOptions
MergeDropIndexesOptions combines the given DropIndexesOptions into a single DropIndexesOptions in a last-one-wins fashion.
func (*DropIndexesOptions) SetMaxTime ¶ added in v0.1.0
func (d *DropIndexesOptions) SetMaxTime(duration time.Duration) *DropIndexesOptions
SetMaxTime sets the value for the MaxTime field.
type EncryptOptions ¶ added in v1.2.0
EncryptOptions represents options to explicitly encrypt a value.
func Encrypt ¶ added in v1.2.0
func Encrypt() *EncryptOptions
Encrypt creates a new EncryptOptions instance.
func MergeEncryptOptions ¶ added in v1.2.0
func MergeEncryptOptions(opts ...*EncryptOptions) *EncryptOptions
MergeEncryptOptions combines the argued EncryptOptions in a last-one wins fashion.
func (*EncryptOptions) SetAlgorithm ¶ added in v1.2.0
func (e *EncryptOptions) SetAlgorithm(algorithm string) *EncryptOptions
SetAlgorithm specifies an algorithm to use for encryption. This should be AEAD_AES_256_CBC_HMAC_SHA_512-Deterministic or AEAD_AES_256_CBC_HMAC_SHA_512-Random. This is required.
func (*EncryptOptions) SetKeyAltName ¶ added in v1.2.0
func (e *EncryptOptions) SetKeyAltName(keyAltName string) *EncryptOptions
SetKeyAltName identifies a key vault document by 'keyAltName'.
func (*EncryptOptions) SetKeyID ¶ added in v1.2.0
func (e *EncryptOptions) SetKeyID(keyID primitive.Binary) *EncryptOptions
SetKeyID specifies an _id of a data key. This should be a UUID (a primitive.Binary with subtype 4).
type EstimatedDocumentCountOptions ¶ added in v0.1.0
type EstimatedDocumentCountOptions struct { // The maximum amount of time that the query can run on the server. The default value is nil, meaning that there // is no time limit for query execution. MaxTime *time.Duration }
EstimatedDocumentCountOptions represents options that can be used to configure an EstimatedDocumentCount operation.
func EstimatedDocumentCount ¶ added in v0.1.0
func EstimatedDocumentCount() *EstimatedDocumentCountOptions
EstimatedDocumentCount creates a new EstimatedDocumentCountOptions instance.
func MergeEstimatedDocumentCountOptions ¶ added in v0.1.0
func MergeEstimatedDocumentCountOptions(opts ...*EstimatedDocumentCountOptions) *EstimatedDocumentCountOptions
MergeEstimatedDocumentCountOptions combines the given EstimatedDocumentCountOptions instances into a single EstimatedDocumentCountOptions in a last-one-wins fashion.
func (*EstimatedDocumentCountOptions) SetMaxTime ¶ added in v0.1.0
func (eco *EstimatedDocumentCountOptions) SetMaxTime(d time.Duration) *EstimatedDocumentCountOptions
SetMaxTime sets the value for the MaxTime field.
type FindOneAndDeleteOptions ¶ added in v0.1.0
type FindOneAndDeleteOptions struct { // Specifies a collation to use for string comparisons during the operation. This option is only valid for MongoDB // versions >= 3.4. For previous server versions, the driver will return an error if this option is used. The // default value is nil, which means the default collation of the collection will be used. Collation *Collation // The maximum amount of time that the query can run on the server. The default value is nil, meaning that there // is no time limit for query execution. MaxTime *time.Duration // A document describing which fields will be included in the document returned by the operation. The default value // is nil, which means all fields will be included. Projection interface{} // A document specifying which document should be replaced if the filter used by the operation matches multiple // documents in the collection. If set, the first document in the sorted order will be selected for replacement. // The default value is nil. Sort interface{} }
FindOneAndDeleteOptions represents options that can be used to configure a FindOneAndDelete operation.
func FindOneAndDelete ¶ added in v0.1.0
func FindOneAndDelete() *FindOneAndDeleteOptions
FindOneAndDelete creates a new FindOneAndDeleteOptions instance.
func MergeFindOneAndDeleteOptions ¶ added in v0.1.0
func MergeFindOneAndDeleteOptions(opts ...*FindOneAndDeleteOptions) *FindOneAndDeleteOptions
MergeFindOneAndDeleteOptions combines the given FindOneAndDeleteOptions instances into a single FindOneAndDeleteOptions in a last-one-wins fashion.
func (*FindOneAndDeleteOptions) SetCollation ¶ added in v0.1.0
func (f *FindOneAndDeleteOptions) SetCollation(collation *Collation) *FindOneAndDeleteOptions
SetCollation sets the value for the Collation field.
func (*FindOneAndDeleteOptions) SetMaxTime ¶ added in v0.1.0
func (f *FindOneAndDeleteOptions) SetMaxTime(d time.Duration) *FindOneAndDeleteOptions
SetMaxTime sets the value for the MaxTime field.
func (*FindOneAndDeleteOptions) SetProjection ¶ added in v0.1.0
func (f *FindOneAndDeleteOptions) SetProjection(projection interface{}) *FindOneAndDeleteOptions
SetProjection sets the value for the Projection field.
func (*FindOneAndDeleteOptions) SetSort ¶ added in v0.1.0
func (f *FindOneAndDeleteOptions) SetSort(sort interface{}) *FindOneAndDeleteOptions
SetSort sets the value for the Sort field.
type FindOneAndReplaceOptions ¶ added in v0.1.0
type FindOneAndReplaceOptions struct { // If true, writes executed as part of the operation will opt out of document-level validation on the server. This // option is valid for MongoDB versions >= 3.2 and is ignored for previous server versions. The default value is // false. See https://docs.mongodb.com/manual/core/schema-validation/ for more information about document // validation. BypassDocumentValidation *bool // Specifies a collation to use for string comparisons during the operation. This option is only valid for MongoDB // versions >= 3.4. For previous server versions, the driver will return an error if this option is used. The // default value is nil, which means the default collation of the collection will be used. Collation *Collation // The maximum amount of time that the query can run on the server. The default value is nil, meaning that there // is no time limit for query execution. MaxTime *time.Duration // A document describing which fields will be included in the document returned by the operation. The default value // is nil, which means all fields will be included. Projection interface{} // Specifies whether the original or replaced document should be returned by the operation. The default value is // Before, which means the original document will be returned from before the replacement is performed. ReturnDocument *ReturnDocument // A document specifying which document should be replaced if the filter used by the operation matches multiple // documents in the collection. If set, the first document in the sorted order will be replaced. // The default value is nil. Sort interface{} // If true, a new document will be inserted if the filter does not match any documents in the collection. The // default value is false. Upsert *bool // The index to use for the operation. This should either be the index name as a string or the index specification // as a document. The default value is nil, which means that no hint will be sent. This option is only valid for // MongoDB versions >= 4.4. MongoDB version 4.2 will report an error if this option is set. For MongoDB versions < // 4.2, the driver will return an error if this option is set. Hint interface{} }
FindOneAndReplaceOptions represents options that can be used to configure a FindOneAndReplace instance.
func FindOneAndReplace ¶ added in v0.1.0
func FindOneAndReplace() *FindOneAndReplaceOptions
FindOneAndReplace creates a new FindOneAndReplaceOptions instance.
func MergeFindOneAndReplaceOptions ¶ added in v0.1.0
func MergeFindOneAndReplaceOptions(opts ...*FindOneAndReplaceOptions) *FindOneAndReplaceOptions
MergeFindOneAndReplaceOptions combines the given FindOneAndReplaceOptions instances into a single FindOneAndReplaceOptions in a last-one-wins fashion.
func (*FindOneAndReplaceOptions) SetBypassDocumentValidation ¶ added in v0.1.0
func (f *FindOneAndReplaceOptions) SetBypassDocumentValidation(b bool) *FindOneAndReplaceOptions
SetBypassDocumentValidation sets the value for the BypassDocumentValidation field.
func (*FindOneAndReplaceOptions) SetCollation ¶ added in v0.1.0
func (f *FindOneAndReplaceOptions) SetCollation(collation *Collation) *FindOneAndReplaceOptions
SetCollation sets the value for the Collation field.
func (*FindOneAndReplaceOptions) SetHint ¶ added in v1.3.1
func (f *FindOneAndReplaceOptions) SetHint(hint interface{}) *FindOneAndReplaceOptions
SetHint sets the value for the Hint field.
func (*FindOneAndReplaceOptions) SetMaxTime ¶ added in v0.1.0
func (f *FindOneAndReplaceOptions) SetMaxTime(d time.Duration) *FindOneAndReplaceOptions
SetMaxTime sets the value for the MaxTime field.
func (*FindOneAndReplaceOptions) SetProjection ¶ added in v0.1.0
func (f *FindOneAndReplaceOptions) SetProjection(projection interface{}) *FindOneAndReplaceOptions
SetProjection sets the value for the Projection field.
func (*FindOneAndReplaceOptions) SetReturnDocument ¶ added in v0.1.0
func (f *FindOneAndReplaceOptions) SetReturnDocument(rd ReturnDocument) *FindOneAndReplaceOptions
SetReturnDocument sets the value for the ReturnDocument field.
func (*FindOneAndReplaceOptions) SetSort ¶ added in v0.1.0
func (f *FindOneAndReplaceOptions) SetSort(sort interface{}) *FindOneAndReplaceOptions
SetSort sets the value for the Sort field.
func (*FindOneAndReplaceOptions) SetUpsert ¶ added in v0.1.0
func (f *FindOneAndReplaceOptions) SetUpsert(b bool) *FindOneAndReplaceOptions
SetUpsert sets the value for the Upsert field.
type FindOneAndUpdateOptions ¶ added in v0.1.0
type FindOneAndUpdateOptions struct { // A set of filters specifying to which array elements an update should apply. This option is only valid for MongoDB // versions >= 3.6. For previous server versions, the driver will return an error if this option is used. The // default value is nil, which means the update will apply to all array elements. ArrayFilters *ArrayFilters // If true, writes executed as part of the operation will opt out of document-level validation on the server. This // option is valid for MongoDB versions >= 3.2 and is ignored for previous server versions. The default value is // false. See https://docs.mongodb.com/manual/core/schema-validation/ for more information about document // validation. BypassDocumentValidation *bool // Specifies a collation to use for string comparisons during the operation. This option is only valid for MongoDB // versions >= 3.4. For previous server versions, the driver will return an error if this option is used. The // default value is nil, which means the default collation of the collection will be used. Collation *Collation // The maximum amount of time that the query can run on the server. The default value is nil, meaning that there // is no time limit for query execution. MaxTime *time.Duration // A document describing which fields will be included in the document returned by the operation. The default value // is nil, which means all fields will be included. Projection interface{} // Specifies whether the original or replaced document should be returned by the operation. The default value is // Before, which means the original document will be returned before the replacement is performed. ReturnDocument *ReturnDocument // A document specifying which document should be updated if the filter used by the operation matches multiple // documents in the collection. If set, the first document in the sorted order will be updated. // The default value is nil. Sort interface{} // If true, a new document will be inserted if the filter does not match any documents in the collection. The // default value is false. Upsert *bool // The index to use for the operation. This should either be the index name as a string or the index specification // as a document. The default value is nil, which means that no hint will be sent. This option is only valid for // MongoDB versions >= 4.4. MongoDB version 4.2 will report an error if this option is set. For MongoDB versions < // 4.2, the driver will return an error if this option is set. Hint interface{} }
FindOneAndUpdateOptions represents options that can be used to configure a FindOneAndUpdate options.
func FindOneAndUpdate ¶ added in v0.1.0
func FindOneAndUpdate() *FindOneAndUpdateOptions
FindOneAndUpdate creates a new FindOneAndUpdateOptions instance.
func MergeFindOneAndUpdateOptions ¶ added in v0.1.0
func MergeFindOneAndUpdateOptions(opts ...*FindOneAndUpdateOptions) *FindOneAndUpdateOptions
MergeFindOneAndUpdateOptions combines the given FindOneAndUpdateOptions instances into a single FindOneAndUpdateOptions in a last-one-wins fashion.
func (*FindOneAndUpdateOptions) SetArrayFilters ¶ added in v0.1.0
func (f *FindOneAndUpdateOptions) SetArrayFilters(filters ArrayFilters) *FindOneAndUpdateOptions
SetArrayFilters sets the value for the ArrayFilters field.
func (*FindOneAndUpdateOptions) SetBypassDocumentValidation ¶ added in v0.1.0
func (f *FindOneAndUpdateOptions) SetBypassDocumentValidation(b bool) *FindOneAndUpdateOptions
SetBypassDocumentValidation sets the value for the BypassDocumentValidation field.
func (*FindOneAndUpdateOptions) SetCollation ¶ added in v0.1.0
func (f *FindOneAndUpdateOptions) SetCollation(collation *Collation) *FindOneAndUpdateOptions
SetCollation sets the value for the Collation field.
func (*FindOneAndUpdateOptions) SetHint ¶ added in v1.3.1
func (f *FindOneAndUpdateOptions) SetHint(hint interface{}) *FindOneAndUpdateOptions
SetHint sets the value for the Hint field.
func (*FindOneAndUpdateOptions) SetMaxTime ¶ added in v0.1.0
func (f *FindOneAndUpdateOptions) SetMaxTime(d time.Duration) *FindOneAndUpdateOptions
SetMaxTime sets the value for the MaxTime field.
func (*FindOneAndUpdateOptions) SetProjection ¶ added in v0.1.0
func (f *FindOneAndUpdateOptions) SetProjection(projection interface{}) *FindOneAndUpdateOptions
SetProjection sets the value for the Projection field.
func (*FindOneAndUpdateOptions) SetReturnDocument ¶ added in v0.1.0
func (f *FindOneAndUpdateOptions) SetReturnDocument(rd ReturnDocument) *FindOneAndUpdateOptions
SetReturnDocument sets the value for the ReturnDocument field.
func (*FindOneAndUpdateOptions) SetSort ¶ added in v0.1.0
func (f *FindOneAndUpdateOptions) SetSort(sort interface{}) *FindOneAndUpdateOptions
SetSort sets the value for the Sort field.
func (*FindOneAndUpdateOptions) SetUpsert ¶ added in v0.1.0
func (f *FindOneAndUpdateOptions) SetUpsert(b bool) *FindOneAndUpdateOptions
SetUpsert sets the value for the Upsert field.
type FindOneOptions ¶ added in v0.1.0
type FindOneOptions struct { // If true, an operation on a sharded cluster can return partial results if some shards are down rather than // returning an error. The default value is false. AllowPartialResults *bool // The maximum number of documents to be included in each batch returned by the server. BatchSize *int32 // Specifies a collation to use for string comparisons during the operation. This option is only valid for MongoDB // versions >= 3.4. For previous server versions, the driver will return an error if this option is used. The // default value is nil, which means the default collation of the collection will be used. Collation *Collation // A string that will be included in server logs, profiling logs, and currentOp queries to help trace the operation. // The default is the empty string, which means that no comment will be included in the logs. Comment *string // Specifies the type of cursor that should be created for the operation. The default is NonTailable, which means // that the cursor will be closed by the server when the last batch of documents is retrieved. CursorType *CursorType // The index to use for the aggregation. This should either be the index name as a string or the index specification // as a document. The default value is nil, which means that no hint will be sent. Hint interface{} // A document specifying the exclusive upper bound for a specific index. The default value is nil, which means that // there is no maximum value. Max interface{} // The maximum amount of time that the server should wait for new documents to satisfy a tailable cursor query. // This option is only valid for tailable await cursors (see the CursorType option for more information) and // MongoDB versions >= 3.2. For other cursor types or previous server versions, this option is ignored. MaxAwaitTime *time.Duration // The maximum amount of time that the query can run on the server. The default value is nil, meaning that there // is no time limit for query execution. MaxTime *time.Duration // A document specifying the inclusive lower bound for a specific index. The default value is 0, which means that // there is no minimum value. Min interface{} // If true, the cursor created by the operation will not timeout after a period of inactivity. The default value // is false. NoCursorTimeout *bool // This option is for internal replication use only and should not be set. OplogReplay *bool // A document describing which fields will be included in the document returned by the operation. The default value // is nil, which means all fields will be included. Projection interface{} // If true, the document returned by the operation will only contain fields corresponding to the index used. The // default value is false. ReturnKey *bool // If true, a $recordId field with a record identifier will be included in the document returned by the operation. // The default value is false. ShowRecordID *bool // The number of documents to skip before selecting the document to be returned. The default value is 0. Skip *int64 // If true, the cursor will not return a document more than once because of an intervening write operation. This // option has been deprecated in MongoDB version 4.0. The default value is false. Snapshot *bool // A document specifying the sort order to apply to the query. The first document in the sorted order will be // returned. Sort interface{} }
FindOneOptions represents options that can be used to configure a FindOne operation.
func FindOne ¶ added in v0.1.0
func FindOne() *FindOneOptions
FindOne creates a new FindOneOptions instance.
func MergeFindOneOptions ¶ added in v0.1.0
func MergeFindOneOptions(opts ...*FindOneOptions) *FindOneOptions
MergeFindOneOptions combines the given FindOneOptions instances into a single FindOneOptions in a last-one-wins fashion.
func (*FindOneOptions) SetAllowPartialResults ¶ added in v0.1.0
func (f *FindOneOptions) SetAllowPartialResults(b bool) *FindOneOptions
SetAllowPartialResults sets the value for the AllowPartialResults field.
func (*FindOneOptions) SetBatchSize ¶ added in v0.1.0
func (f *FindOneOptions) SetBatchSize(i int32) *FindOneOptions
SetBatchSize sets the value for the BatchSize field.
func (*FindOneOptions) SetCollation ¶ added in v0.1.0
func (f *FindOneOptions) SetCollation(collation *Collation) *FindOneOptions
SetCollation sets the value for the Collation field.
func (*FindOneOptions) SetComment ¶ added in v0.1.0
func (f *FindOneOptions) SetComment(comment string) *FindOneOptions
SetComment sets the value for the Comment field.
func (*FindOneOptions) SetCursorType ¶ added in v0.1.0
func (f *FindOneOptions) SetCursorType(ct CursorType) *FindOneOptions
SetCursorType sets the value for the CursorType field.
func (*FindOneOptions) SetHint ¶ added in v0.1.0
func (f *FindOneOptions) SetHint(hint interface{}) *FindOneOptions
SetHint sets the value for the Hint field.
func (*FindOneOptions) SetMax ¶ added in v0.1.0
func (f *FindOneOptions) SetMax(max interface{}) *FindOneOptions
SetMax sets the value for the Max field.
func (*FindOneOptions) SetMaxAwaitTime ¶ added in v0.1.0
func (f *FindOneOptions) SetMaxAwaitTime(d time.Duration) *FindOneOptions
SetMaxAwaitTime sets the value for the MaxAwaitTime field.
func (*FindOneOptions) SetMaxTime ¶ added in v0.1.0
func (f *FindOneOptions) SetMaxTime(d time.Duration) *FindOneOptions
SetMaxTime sets the value for the MaxTime field.
func (*FindOneOptions) SetMin ¶ added in v0.1.0
func (f *FindOneOptions) SetMin(min interface{}) *FindOneOptions
SetMin sets the value for the Min field.
func (*FindOneOptions) SetNoCursorTimeout ¶ added in v0.1.0
func (f *FindOneOptions) SetNoCursorTimeout(b bool) *FindOneOptions
SetNoCursorTimeout sets the value for the NoCursorTimeout field.
func (*FindOneOptions) SetOplogReplay ¶ added in v0.1.0
func (f *FindOneOptions) SetOplogReplay(b bool) *FindOneOptions
SetOplogReplay sets the value for the OplogReplay field.
func (*FindOneOptions) SetProjection ¶ added in v0.1.0
func (f *FindOneOptions) SetProjection(projection interface{}) *FindOneOptions
SetProjection sets the value for the Projection field.
func (*FindOneOptions) SetReturnKey ¶ added in v0.1.0
func (f *FindOneOptions) SetReturnKey(b bool) *FindOneOptions
SetReturnKey sets the value for the ReturnKey field.
func (*FindOneOptions) SetShowRecordID ¶ added in v0.1.0
func (f *FindOneOptions) SetShowRecordID(b bool) *FindOneOptions
SetShowRecordID sets the value for the ShowRecordID field.
func (*FindOneOptions) SetSkip ¶ added in v0.1.0
func (f *FindOneOptions) SetSkip(i int64) *FindOneOptions
SetSkip sets the value for the Skip field.
func (*FindOneOptions) SetSnapshot ¶ added in v0.1.0
func (f *FindOneOptions) SetSnapshot(b bool) *FindOneOptions
SetSnapshot sets the value for the Snapshot field.
func (*FindOneOptions) SetSort ¶ added in v0.1.0
func (f *FindOneOptions) SetSort(sort interface{}) *FindOneOptions
SetSort sets the value for the Sort field.
type FindOptions ¶ added in v0.1.0
type FindOptions struct { // If true, the server can write temporary data to disk while executing the find operation. The default value // is false. This option is only valid for MongoDB versions >= 4.4. Older servers >= 3.2 will report an error for // using this option. For servers < 3.2, this setting is ignored. AllowDiskUse *bool // If true, an operation on a sharded cluster can return partial results if some shards are down rather than // returning an error. The default value is false. AllowPartialResults *bool // The maximum number of documents to be included in each batch returned by the server. BatchSize *int32 // Specifies a collation to use for string comparisons during the operation. This option is only valid for MongoDB // versions >= 3.4. For previous server versions, the driver will return an error if this option is used. The // default value is nil, which means the default collation of the collection will be used. Collation *Collation // A string that will be included in server logs, profiling logs, and currentOp queries to help trace the operation. // The default is the empty string, which means that no comment will be included in the logs. Comment *string // Specifies the type of cursor that should be created for the operation. The default is NonTailable, which means // that the cursor will be closed by the server when the last batch of documents is retrieved. CursorType *CursorType // The index to use for the operation. This should either be the index name as a string or the index specification // as a document. The default value is nil, which means that no hint will be sent. Hint interface{} // The maximum number of documents to return. The default value is 0, which means that all documents matching the // filter will be returned. A negative limit specifies that the resulting documents should be returned in a single // batch. The default value is 0. Limit *int64 // A document specifying the exclusive upper bound for a specific index. The default value is nil, which means that // there is no maximum value. Max interface{} // The maximum amount of time that the server should wait for new documents to satisfy a tailable cursor query. // This option is only valid for tailable await cursors (see the CursorType option for more information) and // MongoDB versions >= 3.2. For other cursor types or previous server versions, this option is ignored. MaxAwaitTime *time.Duration // The maximum amount of time that the query can run on the server. The default value is nil, meaning that there // is no time limit for query execution. MaxTime *time.Duration // A document specifying the inclusive lower bound for a specific index. The default value is 0, which means that // there is no minimum value. Min interface{} // If true, the cursor created by the operation will not timeout after a period of inactivity. The default value // is false. NoCursorTimeout *bool // This option is for internal replication use only and should not be set. This option has been deprecated in // MongoDB version 4.4 and will be ignored by the server if it is set. OplogReplay *bool // A document describing which fields will be included in the documents returned by the operation. The default value // is nil, which means all fields will be included. Projection interface{} // If true, the documents returned by the operation will only contain fields corresponding to the index used. The // default value is false. ReturnKey *bool // If true, a $recordId field with a record identifier will be included in the documents returned by the operation. // The default value is false. ShowRecordID *bool // The number of documents to skip before adding documents to the result. The default value is 0. Skip *int64 // If true, the cursor will not return a document more than once because of an intervening write operation. This // option has been deprecated in MongoDB version 4.0. The default value is false. Snapshot *bool // A document specifying the order in which documents should be returned. Sort interface{} }
FindOptions represents options that can be used to configure a Find operation.
func MergeFindOptions ¶ added in v0.1.0
func MergeFindOptions(opts ...*FindOptions) *FindOptions
MergeFindOptions combines the given FindOptions instances into a single FindOptions in a last-one-wins fashion.
func (*FindOptions) SetAllowDiskUse ¶ added in v1.3.1
func (f *FindOptions) SetAllowDiskUse(b bool) *FindOptions
SetAllowDiskUse sets the value for the AllowDiskUse field.
func (*FindOptions) SetAllowPartialResults ¶ added in v0.1.0
func (f *FindOptions) SetAllowPartialResults(b bool) *FindOptions
SetAllowPartialResults sets the value for the AllowPartialResults field.
func (*FindOptions) SetBatchSize ¶ added in v0.1.0
func (f *FindOptions) SetBatchSize(i int32) *FindOptions
SetBatchSize sets the value for the BatchSize field.
func (*FindOptions) SetCollation ¶ added in v0.1.0
func (f *FindOptions) SetCollation(collation *Collation) *FindOptions
SetCollation sets the value for the Collation field.
func (*FindOptions) SetComment ¶ added in v0.1.0
func (f *FindOptions) SetComment(comment string) *FindOptions
SetComment sets the value for the Comment field.
func (*FindOptions) SetCursorType ¶ added in v0.1.0
func (f *FindOptions) SetCursorType(ct CursorType) *FindOptions
SetCursorType sets the value for the CursorType field.
func (*FindOptions) SetHint ¶ added in v0.1.0
func (f *FindOptions) SetHint(hint interface{}) *FindOptions
SetHint sets the value for the Hint field.
func (*FindOptions) SetLimit ¶ added in v0.1.0
func (f *FindOptions) SetLimit(i int64) *FindOptions
SetLimit sets the value for the Limit field.
func (*FindOptions) SetMax ¶ added in v0.1.0
func (f *FindOptions) SetMax(max interface{}) *FindOptions
SetMax sets the value for the Max field.
func (*FindOptions) SetMaxAwaitTime ¶ added in v0.1.0
func (f *FindOptions) SetMaxAwaitTime(d time.Duration) *FindOptions
SetMaxAwaitTime sets the value for the MaxAwaitTime field.
func (*FindOptions) SetMaxTime ¶ added in v0.1.0
func (f *FindOptions) SetMaxTime(d time.Duration) *FindOptions
SetMaxTime specifies the max time to allow the query to run.
func (*FindOptions) SetMin ¶ added in v0.1.0
func (f *FindOptions) SetMin(min interface{}) *FindOptions
SetMin sets the value for the Min field.
func (*FindOptions) SetNoCursorTimeout ¶ added in v0.1.0
func (f *FindOptions) SetNoCursorTimeout(b bool) *FindOptions
SetNoCursorTimeout sets the value for the NoCursorTimeout field.
func (*FindOptions) SetOplogReplay ¶ added in v0.1.0
func (f *FindOptions) SetOplogReplay(b bool) *FindOptions
SetOplogReplay sets the value for the OplogReplay field.
func (*FindOptions) SetProjection ¶ added in v0.1.0
func (f *FindOptions) SetProjection(projection interface{}) *FindOptions
SetProjection sets the value for the Projection field.
func (*FindOptions) SetReturnKey ¶ added in v0.1.0
func (f *FindOptions) SetReturnKey(b bool) *FindOptions
SetReturnKey sets the value for the ReturnKey field.
func (*FindOptions) SetShowRecordID ¶ added in v0.1.0
func (f *FindOptions) SetShowRecordID(b bool) *FindOptions
SetShowRecordID sets the value for the ShowRecordID field.
func (*FindOptions) SetSkip ¶ added in v0.1.0
func (f *FindOptions) SetSkip(i int64) *FindOptions
SetSkip sets the value for the Skip field.
func (*FindOptions) SetSnapshot ¶ added in v0.1.0
func (f *FindOptions) SetSnapshot(b bool) *FindOptions
SetSnapshot sets the value for the Snapshot field.
func (*FindOptions) SetSort ¶ added in v0.1.0
func (f *FindOptions) SetSort(sort interface{}) *FindOptions
SetSort sets the value for the Sort field.
type FullDocument ¶ added in v0.1.0
type FullDocument string
FullDocument specifies whether a change stream should include a copy of the entire document that was changed from some time after the change occurred.
const ( // Default does not include a document copy Default FullDocument = "default" // UpdateLookup includes a delta describing the changes to the document and a copy of the entire document that // was changed UpdateLookup FullDocument = "updateLookup" )
type GridFSFindOptions ¶ added in v0.1.0
type GridFSFindOptions struct { // If true, the server can write temporary data to disk while executing the find operation. The default value // is false. This option is only valid for MongoDB versions >= 4.4. For previous server versions, the server will // return an error if this option is used. AllowDiskUse *bool // The maximum number of documents to be included in each batch returned by the server. BatchSize *int32 // The maximum number of documents to return. The default value is 0, which means that all documents matching the // filter will be returned. A negative limit specifies that the resulting documents should be returned in a single // batch. The default value is 0. Limit *int32 // The maximum amount of time that the query can run on the server. The default value is nil, meaning that there // is no time limit for query execution. MaxTime *time.Duration // If true, the cursor created by the operation will not timeout after a period of inactivity. The default value // is false. NoCursorTimeout *bool // The number of documents to skip before adding documents to the result. The default value is 0. Skip *int32 // A document specifying the order in which documents should be returned. Sort interface{} }
GridFSFindOptions represents options that can be used to configure a GridFS Find operation.
func GridFSFind ¶ added in v0.1.0
func GridFSFind() *GridFSFindOptions
GridFSFind creates a new GridFSFindOptions instance.
func MergeGridFSFindOptions ¶ added in v0.1.0
func MergeGridFSFindOptions(opts ...*GridFSFindOptions) *GridFSFindOptions
MergeGridFSFindOptions combines the given GridFSFindOptions instances into a single GridFSFindOptions in a last-one-wins fashion.
func (*GridFSFindOptions) SetAllowDiskUse ¶ added in v1.3.1
func (f *GridFSFindOptions) SetAllowDiskUse(b bool) *GridFSFindOptions
SetAllowDiskUse sets the value for the AllowDiskUse field.
func (*GridFSFindOptions) SetBatchSize ¶ added in v0.1.0
func (f *GridFSFindOptions) SetBatchSize(i int32) *GridFSFindOptions
SetBatchSize sets the value for the BatchSize field.
func (*GridFSFindOptions) SetLimit ¶ added in v0.1.0
func (f *GridFSFindOptions) SetLimit(i int32) *GridFSFindOptions
SetLimit sets the value for the Limit field.
func (*GridFSFindOptions) SetMaxTime ¶ added in v0.1.0
func (f *GridFSFindOptions) SetMaxTime(d time.Duration) *GridFSFindOptions
SetMaxTime sets the value for the MaxTime field.
func (*GridFSFindOptions) SetNoCursorTimeout ¶ added in v0.1.0
func (f *GridFSFindOptions) SetNoCursorTimeout(b bool) *GridFSFindOptions
SetNoCursorTimeout sets the value for the NoCursorTimeout field.
func (*GridFSFindOptions) SetSkip ¶ added in v0.1.0
func (f *GridFSFindOptions) SetSkip(i int32) *GridFSFindOptions
SetSkip sets the value for the Skip field.
func (*GridFSFindOptions) SetSort ¶ added in v0.1.0
func (f *GridFSFindOptions) SetSort(sort interface{}) *GridFSFindOptions
SetSort sets the value for the Sort field.
type IndexOptions ¶ added in v0.2.0
type IndexOptions struct { // If true, the index will be built in the background on the server and will not block other tasks. The default // value is false. Background *bool // The length of time, in seconds, for documents to remain in the collection. The default value is 0, which means // that documents will remain in the collection until they're explicitly deleted or the collection is dropped. ExpireAfterSeconds *int32 // The name of the index. The default value is "[field1]_[direction1]_[field2]_[direction2]...". For example, an // index with the specification {name: 1, age: -1} will be named "name_1_age_-1". Name *string // If true, the index will only reference documents that contain the fields specified in the index. The default is // false. Sparse *bool // Specifies the storage engine to use for the index. The value must be a document in the form // {<storage engine name>: <options>}. The default value is nil, which means that the default storage engine // will be used. This option is only applicable for MongoDB versions >= 3.0 and is ignored for previous server // versions. StorageEngine interface{} // If true, the collection will not accept insertion or update of documents where the index key value matches an // existing value in the index. The default is false. Unique *bool // The index version number, either 0 or 1. Version *int32 // The language that determines the list of stop words and the rules for the stemmer and tokenizer. This option // is only applicable for text indexes and is ignored for other index types. The default value is "english". DefaultLanguage *string // The name of the field in the collection's documents that contains the override language for the document. This // option is only applicable for text indexes and is ignored for other index types. The default value is the value // of the DefaultLanguage option. LanguageOverride *string // The index version number for a text index. See https://docs.mongodb.com/manual/core/index-text/#text-versions for // information about different version numbers. TextVersion *int32 // A document that contains field and weight pairs. The weight is an integer ranging from 1 to 99,999, inclusive, // indicating the significance of the field relative to the other indexed fields in terms of the score. This option // is only applicable for text indexes and is ignored for other index types. The default value is nil, which means // that every field will have a weight of 1. Weights interface{} // The index version number for a 2D sphere index. See https://docs.mongodb.com/manual/core/2dsphere/#dsphere-v2 for // information about different version numbers. SphereVersion *int32 // The precision of the stored geohash value of the location data. This option only applies to 2D indexes and is // ignored for other index types. The value must be between 1 and 32, inclusive. The default value is 26. Bits *int32 // The upper inclusive boundary for longitude and latitude values. This option is only applicable to 2D indexes and // is ignored for other index types. The default value is 180.0. Max *float64 // The lower inclusive boundary for longitude and latitude values. This option is only applicable to 2D indexes and // is ignored for other index types. The default value is -180.0. Min *float64 // The number of units within which to group location values. Location values that are within BucketSize units of // each other will be grouped in the same bucket. This option is only applicable to geoHaystack indexes and is // ignored for other index types. The value must be greater than 0. BucketSize *int32 // A document that defines which collection documents the index should reference. This option is only valid for // MongoDB versions >= 3.2 and is ignored for previous server versions. PartialFilterExpression interface{} // The collation to use for string comparisons for the index. This option is only valid for MongoDB versions >= 3.4. // For previous server versions, the driver will return an error if this option is used. Collation *Collation // A document that defines the wildcard projection for the index. WildcardProjection interface{} }
IndexOptions represents options that can be used to configure a new index created through the IndexView.CreateOne or IndexView.CreateMany operations.
func MergeIndexOptions ¶ added in v0.2.0
func MergeIndexOptions(opts ...*IndexOptions) *IndexOptions
MergeIndexOptions combines the given IndexOptions into a single IndexOptions in a last-one-wins fashion.
func (*IndexOptions) SetBackground ¶ added in v0.2.0
func (i *IndexOptions) SetBackground(background bool) *IndexOptions
SetBackground sets value for the Background field.
func (*IndexOptions) SetBits ¶ added in v0.2.0
func (i *IndexOptions) SetBits(bits int32) *IndexOptions
SetBits sets the value for the Bits field.
func (*IndexOptions) SetBucketSize ¶ added in v0.2.0
func (i *IndexOptions) SetBucketSize(bucketSize int32) *IndexOptions
SetBucketSize sets the value for the BucketSize field
func (*IndexOptions) SetCollation ¶ added in v0.2.0
func (i *IndexOptions) SetCollation(collation *Collation) *IndexOptions
SetCollation sets the value for the Collation field.
func (*IndexOptions) SetDefaultLanguage ¶ added in v0.2.0
func (i *IndexOptions) SetDefaultLanguage(language string) *IndexOptions
SetDefaultLanguage sets the value for the DefaultLanguage field.
func (*IndexOptions) SetExpireAfterSeconds ¶ added in v0.2.0
func (i *IndexOptions) SetExpireAfterSeconds(seconds int32) *IndexOptions
SetExpireAfterSeconds sets value for the ExpireAfterSeconds field.
func (*IndexOptions) SetLanguageOverride ¶ added in v0.2.0
func (i *IndexOptions) SetLanguageOverride(override string) *IndexOptions
SetLanguageOverride sets the value of the LanguageOverride field.
func (*IndexOptions) SetMax ¶ added in v0.2.0
func (i *IndexOptions) SetMax(max float64) *IndexOptions
SetMax sets the value for the Max field.
func (*IndexOptions) SetMin ¶ added in v0.2.0
func (i *IndexOptions) SetMin(min float64) *IndexOptions
SetMin sets the value for the Min field.
func (*IndexOptions) SetName ¶ added in v0.2.0
func (i *IndexOptions) SetName(name string) *IndexOptions
SetName sets the value for the Name field.
func (*IndexOptions) SetPartialFilterExpression ¶ added in v0.2.0
func (i *IndexOptions) SetPartialFilterExpression(expression interface{}) *IndexOptions
SetPartialFilterExpression sets the value for the PartialFilterExpression field.
func (*IndexOptions) SetSparse ¶ added in v0.2.0
func (i *IndexOptions) SetSparse(sparse bool) *IndexOptions
SetSparse sets the value of the Sparse field.
func (*IndexOptions) SetSphereVersion ¶ added in v0.2.0
func (i *IndexOptions) SetSphereVersion(version int32) *IndexOptions
SetSphereVersion sets the value for the SphereVersion field.
func (*IndexOptions) SetStorageEngine ¶ added in v0.2.0
func (i *IndexOptions) SetStorageEngine(engine interface{}) *IndexOptions
SetStorageEngine sets the value for the StorageEngine field.
func (*IndexOptions) SetTextVersion ¶ added in v0.2.0
func (i *IndexOptions) SetTextVersion(version int32) *IndexOptions
SetTextVersion sets the value for the TextVersion field.
func (*IndexOptions) SetUnique ¶ added in v0.2.0
func (i *IndexOptions) SetUnique(unique bool) *IndexOptions
SetUnique sets the value for the Unique field.
func (*IndexOptions) SetVersion ¶ added in v0.2.0
func (i *IndexOptions) SetVersion(version int32) *IndexOptions
SetVersion sets the value for the Version field.
func (*IndexOptions) SetWeights ¶ added in v0.2.0
func (i *IndexOptions) SetWeights(weights interface{}) *IndexOptions
SetWeights sets the value for the Weights field.
func (*IndexOptions) SetWildcardProjection ¶ added in v1.1.0
func (i *IndexOptions) SetWildcardProjection(wildcardProjection interface{}) *IndexOptions
SetWildcardProjection sets the value for the WildcardProjection field.
type InsertManyOptions ¶ added in v0.1.0
type InsertManyOptions struct { // If true, writes executed as part of the operation will opt out of document-level validation on the server. This // option is valid for MongoDB versions >= 3.2 and is ignored for previous server versions. The default value is // false. See https://docs.mongodb.com/manual/core/schema-validation/ for more information about document // validation. BypassDocumentValidation *bool // If true, no writes will be executed after one fails. The default value is true. Ordered *bool }
InsertManyOptions represents options that can be used to configure an InsertMany operation.
func InsertMany ¶ added in v0.1.0
func InsertMany() *InsertManyOptions
InsertMany creates a new InsertManyOptions instance.
func MergeInsertManyOptions ¶ added in v0.1.0
func MergeInsertManyOptions(opts ...*InsertManyOptions) *InsertManyOptions
MergeInsertManyOptions combines the givent InsertManyOptions instances into a single InsertManyOptions in a last one wins fashion.
func (*InsertManyOptions) SetBypassDocumentValidation ¶ added in v0.1.0
func (imo *InsertManyOptions) SetBypassDocumentValidation(b bool) *InsertManyOptions
SetBypassDocumentValidation sets the value for the BypassDocumentValidation field.
func (*InsertManyOptions) SetOrdered ¶ added in v0.1.0
func (imo *InsertManyOptions) SetOrdered(b bool) *InsertManyOptions
SetOrdered sets the value for the Ordered field.
type InsertOneOptions ¶ added in v0.1.0
type InsertOneOptions struct { // If true, writes executed as part of the operation will opt out of document-level validation on the server. This // option is valid for MongoDB versions >= 3.2 and is ignored for previous server versions. The default value is // false. See https://docs.mongodb.com/manual/core/schema-validation/ for more information about document // validation. BypassDocumentValidation *bool }
InsertOneOptions represents options that can be used to configure an InsertOne operation.
func InsertOne ¶ added in v0.1.0
func InsertOne() *InsertOneOptions
InsertOne creates a new InsertOneOptions instance.
func MergeInsertOneOptions ¶ added in v0.1.0
func MergeInsertOneOptions(opts ...*InsertOneOptions) *InsertOneOptions
MergeInsertOneOptions combines the given InsertOneOptions instances into a single InsertOneOptions in a last-one-wins fashion.
func (*InsertOneOptions) SetBypassDocumentValidation ¶ added in v0.1.0
func (ioo *InsertOneOptions) SetBypassDocumentValidation(b bool) *InsertOneOptions
SetBypassDocumentValidation sets the value for the BypassDocumentValidation field.
type ListCollectionsOptions ¶ added in v0.1.0
type ListCollectionsOptions struct { // If true, each collection document will only contain a field for the collection name. The default value is false. NameOnly *bool }
ListCollectionsOptions represents options that can be used to configure a ListCollections operation.
func ListCollections ¶ added in v0.1.0
func ListCollections() *ListCollectionsOptions
ListCollections creates a new ListCollectionsOptions instance.
func MergeListCollectionsOptions ¶ added in v0.1.0
func MergeListCollectionsOptions(opts ...*ListCollectionsOptions) *ListCollectionsOptions
MergeListCollectionsOptions combines the given ListCollectionsOptions instances into a single *ListCollectionsOptions in a last-one-wins fashion.
func (*ListCollectionsOptions) SetNameOnly ¶ added in v0.1.0
func (lc *ListCollectionsOptions) SetNameOnly(b bool) *ListCollectionsOptions
SetNameOnly sets the value for the NameOnly field.
type ListDatabasesOptions ¶ added in v0.1.0
type ListDatabasesOptions struct { // If true, only the Name field of the returned DatabaseSpecification objects will be populated. The default value // is false. NameOnly *bool }
ListDatabasesOptions represents options that can be used to configure a ListDatabases operation.
func ListDatabases ¶ added in v0.1.0
func ListDatabases() *ListDatabasesOptions
ListDatabases creates a new ListDatabasesOptions instance.
func MergeListDatabasesOptions ¶ added in v0.1.0
func MergeListDatabasesOptions(opts ...*ListDatabasesOptions) *ListDatabasesOptions
MergeListDatabasesOptions combines the given ListDatabasesOptions instances into a single *ListDatabasesOptions in a last-one-wins fashion.
func (*ListDatabasesOptions) SetNameOnly ¶ added in v0.1.0
func (ld *ListDatabasesOptions) SetNameOnly(b bool) *ListDatabasesOptions
SetNameOnly sets the value for the NameOnly field.
type ListIndexesOptions ¶ added in v0.1.0
type ListIndexesOptions struct { // The maximum number of documents to be included in each batch returned by the server. BatchSize *int32 // The maximum amount of time that the query can run on the server. The default value is nil, meaning that there // is no time limit for query execution. MaxTime *time.Duration }
ListIndexesOptions represents options that can be used to configure an IndexView.List operation.
func ListIndexes ¶ added in v0.1.0
func ListIndexes() *ListIndexesOptions
ListIndexes creates a new ListIndexesOptions instance.
func MergeListIndexesOptions ¶ added in v0.1.0
func MergeListIndexesOptions(opts ...*ListIndexesOptions) *ListIndexesOptions
MergeListIndexesOptions combines the given ListIndexesOptions instances into a single *ListIndexesOptions in a last-one-wins fashion.
func (*ListIndexesOptions) SetBatchSize ¶ added in v0.1.0
func (l *ListIndexesOptions) SetBatchSize(i int32) *ListIndexesOptions
SetBatchSize sets the value for the BatchSize field.
func (*ListIndexesOptions) SetMaxTime ¶ added in v0.1.0
func (l *ListIndexesOptions) SetMaxTime(d time.Duration) *ListIndexesOptions
SetMaxTime sets the value for the MaxTime field.
type MarshalError ¶ added in v0.1.0
type MarshalError struct { Value interface{} Err error }
MarshalError is returned when attempting to transform a value into a document results in an error.
func (MarshalError) Error ¶ added in v0.1.0
func (me MarshalError) Error() string
Error implements the error interface.
type NameOptions ¶ added in v0.1.0
type NameOptions struct { // Specifies the revision of the file to retrieve. Revision numbers are defined as follows: // // * 0 = the original stored file // * 1 = the first revision // * 2 = the second revision // * etc.. // * -2 = the second most recent revision // * -1 = the most recent revision. // // The default value is -1 Revision *int32 }
NameOptions represents options that can be used to configure a GridFS DownloadByName operation.
func GridFSName ¶ added in v0.1.0
func GridFSName() *NameOptions
GridFSName creates a new NameOptions instance.
func MergeNameOptions ¶ added in v0.1.0
func MergeNameOptions(opts ...*NameOptions) *NameOptions
MergeNameOptions combines the given NameOptions instances into a single *NameOptions in a last-one-wins fashion.
func (*NameOptions) SetRevision ¶ added in v0.1.0
func (n *NameOptions) SetRevision(r int32) *NameOptions
SetRevision sets the value for the Revision field.
type ReplaceOptions ¶ added in v0.1.0
type ReplaceOptions struct { // If true, writes executed as part of the operation will opt out of document-level validation on the server. This // option is valid for MongoDB versions >= 3.2 and is ignored for previous server versions. The default value is // false. See https://docs.mongodb.com/manual/core/schema-validation/ for more information about document // validation. BypassDocumentValidation *bool // Specifies a collation to use for string comparisons during the operation. This option is only valid for MongoDB // versions >= 3.4. For previous server versions, the driver will return an error if this option is used. The // default value is nil, which means the default collation of the collection will be used. Collation *Collation // The index to use for the operation. This should either be the index name as a string or the index specification // as a document. The default value is nil, which means that no hint will be sent. This option is only supported by // servers >= 4.2. Older servers >= 3.4 will report an error for using this option. For servers < 3.4, the driver // will return an error if this option is used. Hint interface{} // If true, a new document will be inserted if the filter does not match any documents in the collection. The // default value is false. Upsert *bool }
ReplaceOptions represents options that can be used to configure a ReplaceOne operation.
func MergeReplaceOptions ¶ added in v0.1.0
func MergeReplaceOptions(opts ...*ReplaceOptions) *ReplaceOptions
MergeReplaceOptions combines the given ReplaceOptions instances into a single ReplaceOptions in a last-one-wins fashion.
func Replace ¶ added in v0.1.0
func Replace() *ReplaceOptions
Replace creates a new ReplaceOptions instance.
func (*ReplaceOptions) SetBypassDocumentValidation ¶ added in v0.1.0
func (ro *ReplaceOptions) SetBypassDocumentValidation(b bool) *ReplaceOptions
SetBypassDocumentValidation sets the value for the BypassDocumentValidation field.
func (*ReplaceOptions) SetCollation ¶ added in v0.1.0
func (ro *ReplaceOptions) SetCollation(c *Collation) *ReplaceOptions
SetCollation sets the value for the Collation field.
func (*ReplaceOptions) SetHint ¶ added in v1.3.1
func (ro *ReplaceOptions) SetHint(h interface{}) *ReplaceOptions
SetHint sets the value for the Hint field.
func (*ReplaceOptions) SetUpsert ¶ added in v0.1.0
func (ro *ReplaceOptions) SetUpsert(b bool) *ReplaceOptions
SetUpsert sets the value for the Upsert field.
type ReturnDocument ¶
type ReturnDocument int8
ReturnDocument specifies whether a findAndUpdate operation should return the document as it was before the update or as it is after the update.
const ( // Before specifies that findAndUpdate should return the document as it was before the update. Before ReturnDocument = iota // After specifies that findAndUpdate should return the document as it is after the update. After )
type RunCmdOptions ¶ added in v0.1.0
type RunCmdOptions struct { // The read preference to use for the operation. The default value is nil, which means that the primary read // preference will be used. ReadPreference *readpref.ReadPref }
RunCmdOptions represents options that can be used to configure a RunCommand operation.
func MergeRunCmdOptions ¶ added in v0.1.0
func MergeRunCmdOptions(opts ...*RunCmdOptions) *RunCmdOptions
MergeRunCmdOptions combines the given RunCmdOptions instances into one *RunCmdOptions in a last-one-wins fashion.
func RunCmd ¶ added in v0.1.0
func RunCmd() *RunCmdOptions
RunCmd creates a new RunCmdOptions instance.
func (*RunCmdOptions) SetReadPreference ¶ added in v0.1.0
func (rc *RunCmdOptions) SetReadPreference(rp *readpref.ReadPref) *RunCmdOptions
SetReadPreference sets value for the ReadPreference field.
type SessionOptions ¶ added in v0.1.0
type SessionOptions struct { // If true, causal consistency will be enabled for the session. The default value is true. See // https://docs.mongodb.com/manual/core/read-isolation-consistency-recency/#sessions for more information. CausalConsistency *bool // The default read concern for transactions started in the session. The default value is nil, which means that // the read concern of the client used to start the session will be used. DefaultReadConcern *readconcern.ReadConcern // The default read preference for transactions started in the session. The default value is nil, which means that // the read preference of the client used to start the session will be used. DefaultReadPreference *readpref.ReadPref // The default write concern for transactions started in the session. The default value is nil, which means that // the write concern of the client used to start the session will be used. DefaultWriteConcern *writeconcern.WriteConcern // The default maximum amount of time that a CommitTransaction operation executed in the session can run on the // server. The default value is nil, which means that that there is no time limit for execution. DefaultMaxCommitTime *time.Duration }
SessionOptions represents options that can be used to configure a Session.
func MergeSessionOptions ¶ added in v0.1.0
func MergeSessionOptions(opts ...*SessionOptions) *SessionOptions
MergeSessionOptions combines the given SessionOptions instances into a single SessionOptions in a last-one-wins fashion.
func Session ¶ added in v0.1.0
func Session() *SessionOptions
Session creates a new SessionOptions instance.
func (*SessionOptions) SetCausalConsistency ¶ added in v0.1.0
func (s *SessionOptions) SetCausalConsistency(b bool) *SessionOptions
SetCausalConsistency sets the value for the CausalConsistency field.
func (*SessionOptions) SetDefaultMaxCommitTime ¶ added in v1.1.0
func (s *SessionOptions) SetDefaultMaxCommitTime(mct *time.Duration) *SessionOptions
SetDefaultMaxCommitTime sets the value for the DefaultMaxCommitTime field.
func (*SessionOptions) SetDefaultReadConcern ¶ added in v0.1.0
func (s *SessionOptions) SetDefaultReadConcern(rc *readconcern.ReadConcern) *SessionOptions
SetDefaultReadConcern sets the value for the DefaultReadConcern field.
func (*SessionOptions) SetDefaultReadPreference ¶ added in v0.1.0
func (s *SessionOptions) SetDefaultReadPreference(rp *readpref.ReadPref) *SessionOptions
SetDefaultReadPreference sets the value for the DefaultReadPreference field.
func (*SessionOptions) SetDefaultWriteConcern ¶ added in v0.1.0
func (s *SessionOptions) SetDefaultWriteConcern(wc *writeconcern.WriteConcern) *SessionOptions
SetDefaultWriteConcern sets the value for the DefaultWriteConcern field.
type TransactionOptions ¶ added in v0.1.0
type TransactionOptions struct { // The read concern for operations in the transaction. The default value is nil, which means that the default // read concern of the session used to start the transaction will be used. ReadConcern *readconcern.ReadConcern // The read preference for operations in the transaction. The default value is nil, which means that the default // read preference of the session used to start the transaction will be used. ReadPreference *readpref.ReadPref // The write concern for operations in the transaction. The default value is nil, which means that the default // write concern of the session used to start the transaction will be used. WriteConcern *writeconcern.WriteConcern // The maximum amount of time that a CommitTransaction operation can executed in the transaction can run on the // server. The default value is nil, which means that the default maximum commit time of the session used to // start the transaction will be used. MaxCommitTime *time.Duration }
TransactionOptions represents options that can be used to configure a transaction.
func MergeTransactionOptions ¶ added in v0.1.0
func MergeTransactionOptions(opts ...*TransactionOptions) *TransactionOptions
MergeTransactionOptions combines the given TransactionOptions instances into a single TransactionOptions in a last-one-wins fashion.
func Transaction ¶ added in v0.1.0
func Transaction() *TransactionOptions
Transaction creates a new TransactionOptions instance.
func (*TransactionOptions) SetMaxCommitTime ¶ added in v1.1.0
func (t *TransactionOptions) SetMaxCommitTime(mct *time.Duration) *TransactionOptions
SetMaxCommitTime sets the value for the MaxCommitTime field.
func (*TransactionOptions) SetReadConcern ¶ added in v0.1.0
func (t *TransactionOptions) SetReadConcern(rc *readconcern.ReadConcern) *TransactionOptions
SetReadConcern sets the value for the ReadConcern field.
func (*TransactionOptions) SetReadPreference ¶ added in v0.1.0
func (t *TransactionOptions) SetReadPreference(rp *readpref.ReadPref) *TransactionOptions
SetReadPreference sets the value for the ReadPreference field.
func (*TransactionOptions) SetWriteConcern ¶ added in v0.1.0
func (t *TransactionOptions) SetWriteConcern(wc *writeconcern.WriteConcern) *TransactionOptions
SetWriteConcern sets the value for the WriteConcern field.
type UpdateOptions ¶ added in v0.1.0
type UpdateOptions struct { // A set of filters specifying to which array elements an update should apply. This option is only valid for MongoDB // versions >= 3.6. For previous server versions, the driver will return an error if this option is used. The // default value is nil, which means the update will apply to all array elements. ArrayFilters *ArrayFilters // If true, writes executed as part of the operation will opt out of document-level validation on the server. This // option is valid for MongoDB versions >= 3.2 and is ignored for previous server versions. The default value is // false. See https://docs.mongodb.com/manual/core/schema-validation/ for more information about document // validation. BypassDocumentValidation *bool // Specifies a collation to use for string comparisons during the operation. This option is only valid for MongoDB // versions >= 3.4. For previous server versions, the driver will return an error if this option is used. The // default value is nil, which means the default collation of the collection will be used. Collation *Collation // The index to use for the operation. This should either be the index name as a string or the index specification // as a document. The default value is nil, which means that no hint will be sent. This option is only supported by // servers >= 4.2. Older servers >= 3.4 will report an error for using this option. For servers < 3.4, the driver // will return an error if this option is used. Hint interface{} // If true, a new document will be inserted if the filter does not match any documents in the collection. The // default value is false. Upsert *bool }
UpdateOptions represents options that can be used to configure UpdateOne and UpdateMany operations.
func MergeUpdateOptions ¶ added in v0.1.0
func MergeUpdateOptions(opts ...*UpdateOptions) *UpdateOptions
MergeUpdateOptions combines the given UpdateOptions instances into a single UpdateOptions in a last-one-wins fashion.
func Update ¶ added in v0.1.0
func Update() *UpdateOptions
Update creates a new UpdateOptions instance.
func (*UpdateOptions) SetArrayFilters ¶ added in v0.1.0
func (uo *UpdateOptions) SetArrayFilters(af ArrayFilters) *UpdateOptions
SetArrayFilters sets the value for the ArrayFilters field.
func (*UpdateOptions) SetBypassDocumentValidation ¶ added in v0.1.0
func (uo *UpdateOptions) SetBypassDocumentValidation(b bool) *UpdateOptions
SetBypassDocumentValidation sets the value for the BypassDocumentValidation field.
func (*UpdateOptions) SetCollation ¶ added in v0.1.0
func (uo *UpdateOptions) SetCollation(c *Collation) *UpdateOptions
SetCollation sets the value for the Collation field.
func (*UpdateOptions) SetHint ¶ added in v1.3.1
func (uo *UpdateOptions) SetHint(h interface{}) *UpdateOptions
SetHint sets the value for the Hint field.
func (*UpdateOptions) SetUpsert ¶ added in v0.1.0
func (uo *UpdateOptions) SetUpsert(b bool) *UpdateOptions
SetUpsert sets the value for the Upsert field.
type UploadOptions ¶ added in v0.1.0
type UploadOptions struct { // The number of bytes in each chunk in the bucket. The default value is DefaultChunkSize (255 KiB). ChunkSizeBytes *int32 // Additional application data that will be stored in the "metadata" field of the document in the files collection. // The default value is nil, which means that the document in the files collection will not contain a "metadata" // field. Metadata interface{} // The BSON registry to use for converting filters to BSON documents. The default value is bson.DefaultRegistry. Registry *bsoncodec.Registry }
UploadOptions represents options that can be used to configure a GridFS upload operation.
func GridFSUpload ¶ added in v0.1.0
func GridFSUpload() *UploadOptions
GridFSUpload creates a new UploadOptions instance.
func MergeUploadOptions ¶ added in v0.1.0
func MergeUploadOptions(opts ...*UploadOptions) *UploadOptions
MergeUploadOptions combines the given UploadOptions instances into a single UploadOptions in a last-one-wins fashion.
func (*UploadOptions) SetChunkSizeBytes ¶ added in v0.1.0
func (u *UploadOptions) SetChunkSizeBytes(i int32) *UploadOptions
SetChunkSizeBytes sets the value for the ChunkSize field.
func (*UploadOptions) SetMetadata ¶ added in v0.1.0
func (u *UploadOptions) SetMetadata(doc interface{}) *UploadOptions
SetMetadata sets the value for the Metadata field.
Source Files ¶
- aggregateoptions.go
- autoencryptionoptions.go
- bulkwriteoptions.go
- changestreamoptions.go
- clientencryptionoptions.go
- clientoptions.go
- clientoptions_1_10.go
- collectionoptions.go
- countoptions.go
- datakeyoptions.go
- dboptions.go
- deleteoptions.go
- distinctoptions.go
- encryptoptions.go
- estimatedcountoptions.go
- findoptions.go
- gridfsoptions.go
- indexoptions.go
- insertoptions.go
- listcollectionsoptions.go
- listdatabasesoptions.go
- mongooptions.go
- replaceoptions.go
- runcmdoptions.go
- sessionoptions.go
- transactionoptions.go
- updateoptions.go