zitadel/internal/cache
Tim Möhlmann 250f2344c8
feat(cache): redis cache (#8822)
# 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
2024-11-04 10:44:51 +00:00
..
connector feat(cache): redis cache (#8822) 2024-11-04 10:44:51 +00:00
cache.go feat(cache): redis cache (#8822) 2024-11-04 10:44:51 +00:00
connector_enumer.go feat(cache): redis cache (#8822) 2024-11-04 10:44:51 +00:00
error.go feat(storage): generic cache interface (#8628) 2024-09-25 21:40:21 +02:00
pruner_test.go feat(cache): redis cache (#8822) 2024-11-04 10:44:51 +00:00
pruner.go feat(cache): redis cache (#8822) 2024-11-04 10:44:51 +00:00
purpose_enumer.go feat(cache): redis cache (#8822) 2024-11-04 10:44:51 +00:00