Compare commits
2 Commits
2b2fa217d6
...
d3f03f2cae
| Author | SHA1 | Date | |
|---|---|---|---|
| d3f03f2cae | |||
| d8b2bd7226 |
6
backend/internal/storage/cache/cache.go
vendored
6
backend/internal/storage/cache/cache.go
vendored
@ -29,9 +29,9 @@ type Storage struct {
|
||||
Delete(ctx context.Context, name string)
|
||||
}
|
||||
Groups interface {
|
||||
Get(ctx context.Context, name string) (*storage.Role, error)
|
||||
Set(ctx context.Context, role *storage.Role) error
|
||||
Delete(ctx context.Context, name string)
|
||||
Get(ctx context.Context, id int64) (*storage.Group, error)
|
||||
Set(ctx context.Context, group *storage.Group) error
|
||||
Delete(ctx context.Context, id int64)
|
||||
}
|
||||
UserGroups interface {
|
||||
Get(ctx context.Context, userid int64) (*storage.UserGroups, error)
|
||||
|
||||
55
backend/internal/storage/cache/redis_groups.go
vendored
Normal file
55
backend/internal/storage/cache/redis_groups.go
vendored
Normal file
@ -0,0 +1,55 @@
|
||||
package cache
|
||||
|
||||
import (
|
||||
"context"
|
||||
"encoding/json"
|
||||
"fmt"
|
||||
|
||||
"git.ewellenr.ca/receipt_indexer/backend/internal/storage"
|
||||
"github.com/redis/go-redis/v9"
|
||||
)
|
||||
|
||||
type GroupStore struct {
|
||||
rdb *redis.Client
|
||||
}
|
||||
|
||||
func (s *GroupStore) generateCacheKey(id int64) string {
|
||||
return fmt.Sprintf("group-%d", id)
|
||||
}
|
||||
|
||||
func (s *GroupStore) Get(ctx context.Context, id int64) (*storage.Group, error) {
|
||||
cacheKey := s.generateCacheKey(id)
|
||||
|
||||
data, err := s.rdb.Get(ctx, cacheKey).Result()
|
||||
if err == redis.Nil {
|
||||
return nil, nil
|
||||
} else if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
var group storage.Group
|
||||
if data != "" {
|
||||
err := json.Unmarshal([]byte(data), &group)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
}
|
||||
|
||||
return &group, nil
|
||||
}
|
||||
|
||||
func (s *GroupStore) Set(ctx context.Context, group *storage.Group) error {
|
||||
cacheKey := s.generateCacheKey(group.ID)
|
||||
|
||||
json, err := json.Marshal(group)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
return s.rdb.Set(ctx, cacheKey, json, RolesExpTime).Err()
|
||||
}
|
||||
|
||||
func (s *GroupStore) Delete(ctx context.Context, id int64) {
|
||||
cacheKey := s.generateCacheKey(id)
|
||||
s.rdb.Del(ctx, cacheKey)
|
||||
}
|
||||
21
backend/internal/storage/cache/redis_roles.go
vendored
21
backend/internal/storage/cache/redis_roles.go
vendored
@ -8,13 +8,18 @@ import (
|
||||
"github.com/redis/go-redis/v9"
|
||||
)
|
||||
|
||||
type RolesStore struct {
|
||||
type RoleStore struct {
|
||||
rdb *redis.Client
|
||||
}
|
||||
|
||||
func (s *RolesStore) Get(ctx context.Context, name string) (*storage.Role, error) {
|
||||
func (s *RoleStore) generateCacheKey(name string) string {
|
||||
return name
|
||||
}
|
||||
|
||||
data, err := s.rdb.Get(ctx, name).Result()
|
||||
func (s *RoleStore) Get(ctx context.Context, name string) (*storage.Role, error) {
|
||||
cacheKey := s.generateCacheKey(name)
|
||||
|
||||
data, err := s.rdb.Get(ctx, cacheKey).Result()
|
||||
if err == redis.Nil {
|
||||
return nil, nil
|
||||
} else if err != nil {
|
||||
@ -32,16 +37,18 @@ func (s *RolesStore) Get(ctx context.Context, name string) (*storage.Role, error
|
||||
return &role, nil
|
||||
}
|
||||
|
||||
func (s *RolesStore) Set(ctx context.Context, role *storage.Role) error {
|
||||
func (s *RoleStore) Set(ctx context.Context, role *storage.Role) error {
|
||||
cacheKey := s.generateCacheKey(role.Name)
|
||||
|
||||
json, err := json.Marshal(role)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
return s.rdb.Set(ctx, role.Name, json, RolesExpTime).Err()
|
||||
return s.rdb.Set(ctx, cacheKey, json, RolesExpTime).Err()
|
||||
}
|
||||
|
||||
func (s *RolesStore) Delete(ctx context.Context, name string) {
|
||||
s.rdb.Del(ctx, name)
|
||||
func (s *RoleStore) Delete(ctx context.Context, name string) {
|
||||
cacheKey := s.generateCacheKey(name)
|
||||
s.rdb.Del(ctx, cacheKey)
|
||||
}
|
||||
|
||||
10
backend/internal/storage/cache/redis_user.go
vendored
10
backend/internal/storage/cache/redis_user.go
vendored
@ -13,8 +13,12 @@ type UserStore struct {
|
||||
rdb *redis.Client
|
||||
}
|
||||
|
||||
func (s *UserStore) generateCacheKey(id int64) string {
|
||||
return fmt.Sprintf("user-%d", id)
|
||||
}
|
||||
|
||||
func (s *UserStore) Get(ctx context.Context, userID int64) (*storage.User, error) {
|
||||
cacheKey := fmt.Sprintf("user-%d", userID)
|
||||
cacheKey := s.generateCacheKey(userID)
|
||||
|
||||
data, err := s.rdb.Get(ctx, cacheKey).Result()
|
||||
if err == redis.Nil {
|
||||
@ -35,7 +39,7 @@ func (s *UserStore) Get(ctx context.Context, userID int64) (*storage.User, error
|
||||
}
|
||||
|
||||
func (s *UserStore) Set(ctx context.Context, user *storage.User) error {
|
||||
cacheKey := fmt.Sprintf("user-%d", user.ID)
|
||||
cacheKey := s.generateCacheKey(user.ID)
|
||||
|
||||
json, err := json.Marshal(user)
|
||||
if err != nil {
|
||||
@ -46,6 +50,6 @@ func (s *UserStore) Set(ctx context.Context, user *storage.User) error {
|
||||
}
|
||||
|
||||
func (s *UserStore) Delete(ctx context.Context, userID int64) {
|
||||
cacheKey := fmt.Sprintf("user-%d", userID)
|
||||
cacheKey := s.generateCacheKey(userID)
|
||||
s.rdb.Del(ctx, cacheKey)
|
||||
}
|
||||
|
||||
@ -13,8 +13,12 @@ type UserGroupsStore struct {
|
||||
rdb *redis.Client
|
||||
}
|
||||
|
||||
func (s *UserGroupsStore) generateCacheKey(id int64) string {
|
||||
return fmt.Sprintf("user-%d", id)
|
||||
}
|
||||
|
||||
func (s *UserGroupsStore) Get(ctx context.Context, userid int64) (*storage.UserGroups, error) {
|
||||
cacheKey := fmt.Sprintf("user-%d", userid)
|
||||
cacheKey := s.generateCacheKey(userid)
|
||||
|
||||
data, err := s.rdb.Get(ctx, cacheKey).Result()
|
||||
if err == redis.Nil {
|
||||
@ -35,7 +39,7 @@ func (s *UserGroupsStore) Get(ctx context.Context, userid int64) (*storage.UserG
|
||||
}
|
||||
|
||||
func (s *UserGroupsStore) Set(ctx context.Context, groups *storage.UserGroups) error {
|
||||
cacheKey := fmt.Sprintf("user-%d", groups.UserID)
|
||||
cacheKey := s.generateCacheKey(groups.UserID)
|
||||
|
||||
json, err := json.Marshal(groups)
|
||||
if err != nil {
|
||||
@ -46,6 +50,6 @@ func (s *UserGroupsStore) Set(ctx context.Context, groups *storage.UserGroups) e
|
||||
}
|
||||
|
||||
func (s *UserGroupsStore) Delete(ctx context.Context, userid int64) {
|
||||
cacheKey := fmt.Sprintf("user-%d", userid)
|
||||
cacheKey := s.generateCacheKey(userid)
|
||||
s.rdb.Del(ctx, cacheKey)
|
||||
}
|
||||
|
||||
Loading…
Reference in New Issue
Block a user