eventRT/database/mongo_init.go

57 lines
1.4 KiB
Go
Raw Normal View History

2026-01-29 16:54:00 +08:00
// Package database define database operation functions
package database
import (
"context"
"sync"
"time"
2026-01-30 17:43:16 +08:00
"eventRT/config" //
"eventRT/logger"
2026-01-29 16:54:00 +08:00
"go.mongodb.org/mongo-driver/mongo"
"go.mongodb.org/mongo-driver/mongo/options"
)
var (
mongoOnce sync.Once
2026-01-30 17:43:16 +08:00
_globalMongoClient *mongo.Client
2026-01-29 16:54:00 +08:00
)
2026-01-30 17:43:16 +08:00
// GetMongoClient returns the global MongoDB client
func GetMongoClient() *mongo.Client {
return _globalMongoClient
}
2026-01-29 16:54:00 +08:00
// InitMongoInstance return instance of MongoDB client
2026-01-30 17:43:16 +08:00
func InitMongoInstance(ctx context.Context, eCfg config.EventRTConfig) *mongo.Client {
2026-01-29 16:54:00 +08:00
mongoOnce.Do(func() {
2026-01-30 17:43:16 +08:00
_globalMongoClient = initMongoClient(ctx, eCfg.MongoDBURI, eCfg.Timeout)
2026-01-29 16:54:00 +08:00
})
return _globalMongoClient
}
2026-01-30 17:43:16 +08:00
// initMongoClient return successfully initialized MongoDB client
func initMongoClient(ctx context.Context, mongoDBURI string, timeout int) *mongo.Client {
clientOptions := options.Client().ApplyURI(mongoDBURI)
client, err := mongo.Connect(ctx, clientOptions)
if err != nil {
logger.Error(ctx, "failed to connect to MongoDB", "error", err)
panic(err)
}
pingTimeout := time.Duration(timeout) * time.Second
if pingTimeout == 0 {
pingTimeout = 10 * time.Second
}
pingCtx, cancel := context.WithTimeout(ctx, pingTimeout)
defer cancel()
if err := client.Ping(pingCtx, nil); err != nil {
logger.Error(ctx, "failed to ping operation with MongoDB", "error", err)
panic(err)
}
return client
}