codeword/internal/initialize/mongo.go

42 lines
921 B
Go
Raw Normal View History

2023-12-29 12:41:26 +00:00
package initialize
import (
"context"
2024-11-22 11:22:08 +00:00
"gitea.pena/PenaSide/codeword/internal/repository"
2024-11-29 07:27:15 +00:00
mdb "gitea.pena/PenaSide/common/mongo"
2023-12-29 12:41:26 +00:00
"go.mongodb.org/mongo-driver/mongo"
2024-01-15 13:32:46 +00:00
"go.uber.org/zap"
2023-12-29 12:41:26 +00:00
"time"
)
2024-01-11 12:07:17 +00:00
func MongoDB(ctx context.Context, cfg Config) (*mongo.Database, error) {
2024-01-15 13:32:46 +00:00
newCtx, cancel := context.WithTimeout(ctx, 10*time.Second)
2024-01-15 08:43:55 +00:00
defer cancel()
2023-12-29 12:41:26 +00:00
mongoDeps := &mdb.ConnectDeps{
2024-11-29 07:27:15 +00:00
Configuration: &cfg.DataBase,
2023-12-29 12:41:26 +00:00
Timeout: 10 * time.Second,
}
2024-01-15 13:32:46 +00:00
db, err := mdb.Connect(newCtx, mongoDeps)
2023-12-29 12:41:26 +00:00
if err != nil {
return nil, err
}
2024-01-15 13:32:46 +00:00
err = db.Client().Ping(newCtx, nil)
2023-12-29 12:41:26 +00:00
if err != nil {
return nil, err
}
return db, nil
}
2024-01-15 13:32:46 +00:00
func InitDatabaseIndexes(ctx context.Context, mdb *mongo.Database, logger *zap.Logger) error {
if err := repository.InitPromoCodeIndexes(ctx, mdb.Collection("promoCodes")); err != nil {
logger.Error("Failed to initialize promoCodes indexes", zap.Error(err))
return err
}
return nil
}