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) }