monorepo/cloud/maplefile-backend/pkg/distributedmutex/provider.go

23 lines
660 B
Go

package distributedmutex
import (
"fmt"
"github.com/redis/go-redis/v9"
"go.uber.org/zap"
"codeberg.org/mapleopentech/monorepo/cloud/maplefile-backend/config"
)
// ProvideDistributedMutexAdapter provides a distributed mutex adapter for Wire DI
func ProvideDistributedMutexAdapter(cfg *config.Config, logger *zap.Logger) Adapter {
// Create Redis client for distributed locking
// Note: This is separate from the cache redis client
redisClient := redis.NewClient(&redis.Options{
Addr: fmt.Sprintf("%s:%d", cfg.Cache.Host, cfg.Cache.Port),
Password: cfg.Cache.Password,
DB: cfg.Cache.DB,
})
return NewAdapter(logger, redisClient)
}