You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
75 lines
1.7 KiB
Go
75 lines
1.7 KiB
Go
package mon
|
|
|
|
import (
|
|
"reflect"
|
|
"time"
|
|
|
|
"github.com/zeromicro/go-zero/core/syncx"
|
|
"go.mongodb.org/mongo-driver/bson"
|
|
"go.mongodb.org/mongo-driver/bson/bsoncodec"
|
|
mopt "go.mongodb.org/mongo-driver/mongo/options"
|
|
)
|
|
|
|
const defaultTimeout = time.Second * 3
|
|
|
|
var (
|
|
slowThreshold = syncx.ForAtomicDuration(defaultSlowThreshold)
|
|
logMon = syncx.ForAtomicBool(true)
|
|
logSlowMon = syncx.ForAtomicBool(true)
|
|
)
|
|
|
|
type (
|
|
// Option defines the method to customize a mongo model.
|
|
Option func(opts *options)
|
|
|
|
// TypeCodec is a struct that stores specific type Encoder/Decoder.
|
|
TypeCodec struct {
|
|
ValueType reflect.Type
|
|
Encoder bsoncodec.ValueEncoder
|
|
Decoder bsoncodec.ValueDecoder
|
|
}
|
|
|
|
options = mopt.ClientOptions
|
|
)
|
|
|
|
// DisableLog disables logging of mongo commands, includes info and slow logs.
|
|
func DisableLog() {
|
|
logMon.Set(false)
|
|
logSlowMon.Set(false)
|
|
}
|
|
|
|
// DisableInfoLog disables info logging of mongo commands, but keeps slow logs.
|
|
func DisableInfoLog() {
|
|
logMon.Set(false)
|
|
}
|
|
|
|
// SetSlowThreshold sets the slow threshold.
|
|
func SetSlowThreshold(threshold time.Duration) {
|
|
slowThreshold.Set(threshold)
|
|
}
|
|
|
|
// WithTimeout set the mon client operation timeout.
|
|
func WithTimeout(timeout time.Duration) Option {
|
|
return func(opts *options) {
|
|
opts.SetTimeout(timeout)
|
|
}
|
|
}
|
|
|
|
// WithTypeCodec registers TypeCodecs to convert custom types.
|
|
func WithTypeCodec(typeCodecs ...TypeCodec) Option {
|
|
return func(opts *options) {
|
|
registry := bson.NewRegistry()
|
|
for _, v := range typeCodecs {
|
|
registry.RegisterTypeEncoder(v.ValueType, v.Encoder)
|
|
registry.RegisterTypeDecoder(v.ValueType, v.Decoder)
|
|
}
|
|
opts.SetRegistry(registry)
|
|
}
|
|
}
|
|
|
|
func defaultTimeoutOption() Option {
|
|
return func(opts *options) {
|
|
opts.SetTimeout(defaultTimeout)
|
|
}
|
|
}
|