mirror of
https://github.com/mainflux/mainflux.git
synced 2025-04-29 13:49:28 +08:00

* Update metadata type in things service Update things service so that metadata has map type. Update repo implementation by adding sqlx lib. Signed-off-by: Aleksandar Novakovic <aleksandar.novakovic@mainflux.com> * Add sqlx lib to bootstrap service Add sqlx lib to bootstrap service and update metadata field type. Signed-off-by: Aleksandar Novakovic <aleksandar.novakovic@mainflux.com> * Update metadata in redis streams consumer Signed-off-by: Aleksandar Novakovic <aleksandar.novakovic@mainflux.com> * Update tests for bootstrap service Signed-off-by: Aleksandar Novakovic <aleksandar.novakovic@mainflux.com> * Fix mongo reader logging and driver version Signed-off-by: Aleksandar Novakovic <aleksandar.novakovic@mainflux.com> * Fix mongo reader and writer Fix mongo reader and writer by updating driver version. Signed-off-by: Aleksandar Novakovic <aleksandar.novakovic@mainflux.com> * Update SDK with new metadata format Signed-off-by: Aleksandar Novakovic <aleksandar.novakovic@mainflux.com> * Update LoRa adapter with new metadata format Signed-off-by: Aleksandar Novakovic <aleksandar.novakovic@mainflux.com> * Update users service in order to use sqlx Signed-off-by: Aleksandar Novakovic <aleksandar.novakovic@mainflux.com> * Replace anonymous struct with map Signed-off-by: Aleksandar Novakovic <aleksandar.novakovic@mainflux.com> * Update docs for LoRa adapter Signed-off-by: Aleksandar Novakovic <aleksandar.novakovic@mainflux.com> * Fix LoRa application metadata format Signed-off-by: Aleksandar Novakovic <aleksandar.novakovic@mainflux.com> * Fix metadata format in LoRa docs Signed-off-by: Aleksandar Novakovic <aleksandar.novakovic@mainflux.com> * Add metadata2 var to SDK things test Signed-off-by: Aleksandar Novakovic <aleksandar.novakovic@mainflux.com>
98 lines
3.6 KiB
Go
98 lines
3.6 KiB
Go
// Copyright (C) MongoDB, Inc. 2017-present.
|
||
//
|
||
// Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||
// not use this file except in compliance with the License. You may obtain
|
||
// a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
|
||
|
||
package options
|
||
|
||
import (
|
||
"go.mongodb.org/mongo-driver/bson/primitive"
|
||
"time"
|
||
)
|
||
|
||
// ChangeStreamOptions represents all possible options to a change stream
|
||
type ChangeStreamOptions struct {
|
||
BatchSize *int32 // The number of documents to return per batch
|
||
Collation *Collation // Specifies a collation
|
||
FullDocument *FullDocument // When set to ‘updateLookup’, the change notification for partial updates will include both a delta describing the changes to the document, as well as a copy of the entire document that was changed from some time after the change occurred.
|
||
MaxAwaitTime *time.Duration // The maximum amount of time for the server to wait on new documents to satisfy a change stream query
|
||
ResumeAfter interface{} // Specifies the logical starting point for the new change stream
|
||
StartAtOperationTime *primitive.Timestamp // Ensures that a change stream will only provide changes that occurred after a timestamp.
|
||
}
|
||
|
||
// ChangeStream returns a pointer to a new ChangeStreamOptions
|
||
func ChangeStream() *ChangeStreamOptions {
|
||
return &ChangeStreamOptions{}
|
||
}
|
||
|
||
// SetBatchSize specifies the number of documents to return per batch
|
||
func (cso *ChangeStreamOptions) SetBatchSize(i int32) *ChangeStreamOptions {
|
||
cso.BatchSize = &i
|
||
return cso
|
||
}
|
||
|
||
// SetCollation specifies a collation
|
||
func (cso *ChangeStreamOptions) SetCollation(c Collation) *ChangeStreamOptions {
|
||
cso.Collation = &c
|
||
return cso
|
||
}
|
||
|
||
// SetFullDocument specifies the fullDocument option.
|
||
// When set to ‘updateLookup’, the change notification for partial updates will
|
||
// include both a delta describing the changes to the document, as well as a
|
||
// copy of the entire document that was changed from some time after the change
|
||
// occurred.
|
||
func (cso *ChangeStreamOptions) SetFullDocument(fd FullDocument) *ChangeStreamOptions {
|
||
cso.FullDocument = &fd
|
||
return cso
|
||
}
|
||
|
||
// SetMaxAwaitTime specifies the maximum amount of time for the server to wait on new documents to satisfy a change stream query
|
||
func (cso *ChangeStreamOptions) SetMaxAwaitTime(d time.Duration) *ChangeStreamOptions {
|
||
cso.MaxAwaitTime = &d
|
||
return cso
|
||
}
|
||
|
||
// SetResumeAfter specifies the logical starting point for the new change stream
|
||
func (cso *ChangeStreamOptions) SetResumeAfter(rt interface{}) *ChangeStreamOptions {
|
||
cso.ResumeAfter = rt
|
||
return cso
|
||
}
|
||
|
||
// SetStartAtOperationTime ensures that a change stream will only provide changes that occurred after a specified timestamp.
|
||
func (cso *ChangeStreamOptions) SetStartAtOperationTime(t *primitive.Timestamp) *ChangeStreamOptions {
|
||
cso.StartAtOperationTime = t
|
||
return cso
|
||
}
|
||
|
||
// MergeChangeStreamOptions combines the argued ChangeStreamOptions into a single ChangeStreamOptions in a last-one-wins fashion
|
||
func MergeChangeStreamOptions(opts ...*ChangeStreamOptions) *ChangeStreamOptions {
|
||
csOpts := ChangeStream()
|
||
for _, cso := range opts {
|
||
if cso == nil {
|
||
continue
|
||
}
|
||
if cso.BatchSize != nil {
|
||
csOpts.BatchSize = cso.BatchSize
|
||
}
|
||
if cso.Collation != nil {
|
||
csOpts.Collation = cso.Collation
|
||
}
|
||
if cso.FullDocument != nil {
|
||
csOpts.FullDocument = cso.FullDocument
|
||
}
|
||
if cso.MaxAwaitTime != nil {
|
||
csOpts.MaxAwaitTime = cso.MaxAwaitTime
|
||
}
|
||
if cso.ResumeAfter != nil {
|
||
csOpts.ResumeAfter = cso.ResumeAfter
|
||
}
|
||
if cso.StartAtOperationTime != nil {
|
||
csOpts.StartAtOperationTime = cso.StartAtOperationTime
|
||
}
|
||
}
|
||
|
||
return csOpts
|
||
}
|