mirror of
https://github.com/zitadel/zitadel.git
synced 2025-10-24 06:01:53 +00:00

# Which Problems Are Solved Add a cache implementation using Redis single mode. This does not add support for Redis Cluster or sentinel. # How the Problems Are Solved Added the `internal/cache/redis` package. All operations occur atomically, including setting of secondary indexes, using LUA scripts where needed. The [`miniredis`](https://github.com/alicebob/miniredis) package is used to run unit tests. # Additional Changes - Move connector code to `internal/cache/connector/...` and remove duplicate code from `query` and `command` packages. - Fix a missed invalidation on the restrictions projection # Additional Context Closes #8130
29 lines
457 B
Go
29 lines
457 B
Go
package pg
|
|
|
|
import (
|
|
"github.com/zitadel/zitadel/internal/cache"
|
|
"github.com/zitadel/zitadel/internal/database"
|
|
)
|
|
|
|
type Config struct {
|
|
Enabled bool
|
|
AutoPrune cache.AutoPruneConfig
|
|
}
|
|
|
|
type Connector struct {
|
|
PGXPool
|
|
Dialect string
|
|
Config Config
|
|
}
|
|
|
|
func NewConnector(config Config, client *database.DB) *Connector {
|
|
if !config.Enabled {
|
|
return nil
|
|
}
|
|
return &Connector{
|
|
PGXPool: client.Pool,
|
|
Dialect: client.Type(),
|
|
Config: config,
|
|
}
|
|
}
|