Compare commits
3 Commits
d3f03f2cae
...
c91c784338
| Author | SHA1 | Date | |
|---|---|---|---|
| c91c784338 | |||
| c34c3dfa51 | |||
| 4fd63574c2 |
6
backend/internal/storage/cache/cache.go
vendored
6
backend/internal/storage/cache/cache.go
vendored
@ -10,10 +10,10 @@ import (
|
||||
|
||||
const (
|
||||
UserExpTime = time.Minute
|
||||
RolesExpTime = time.Minute
|
||||
GroupsExpTime = time.Minute
|
||||
RoleExpTime = time.Minute
|
||||
GroupExpTime = time.Minute
|
||||
UserGroupsExpTime = time.Minute
|
||||
ReceptsExpTime = time.Minute
|
||||
ReceiptExpTime = time.Minute
|
||||
ReceiptImageExpTime = time.Minute
|
||||
)
|
||||
|
||||
|
||||
@ -46,7 +46,7 @@ func (s *GroupStore) Set(ctx context.Context, group *storage.Group) error {
|
||||
return err
|
||||
}
|
||||
|
||||
return s.rdb.Set(ctx, cacheKey, json, RolesExpTime).Err()
|
||||
return s.rdb.Set(ctx, cacheKey, json, RoleExpTime).Err()
|
||||
}
|
||||
|
||||
func (s *GroupStore) Delete(ctx context.Context, id int64) {
|
||||
55
backend/internal/storage/cache/redis-image.go
vendored
Normal file
55
backend/internal/storage/cache/redis-image.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 ReceiptImageStore struct {
|
||||
rdb *redis.Client
|
||||
}
|
||||
|
||||
func (s *ReceiptImageStore) generateCacheKey(id int64) string {
|
||||
return fmt.Sprintf("receiptimage-%d", id)
|
||||
}
|
||||
|
||||
func (s *ReceiptImageStore) Get(ctx context.Context, id int64) (*storage.Image, 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 receiptimage storage.Image
|
||||
if data != "" {
|
||||
err := json.Unmarshal([]byte(data), &receiptimage)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
}
|
||||
|
||||
return &receiptimage, nil
|
||||
}
|
||||
|
||||
func (s *ReceiptImageStore) Set(ctx context.Context, receiptimage *storage.Image) error {
|
||||
cacheKey := s.generateCacheKey(receiptimage.ID)
|
||||
|
||||
json, err := json.Marshal(receiptimage)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
return s.rdb.Set(ctx, cacheKey, json, ReceiptImageExpTime).Err()
|
||||
}
|
||||
|
||||
func (s *ReceiptImageStore) Delete(ctx context.Context, id int64) {
|
||||
cacheKey := s.generateCacheKey(id)
|
||||
s.rdb.Del(ctx, cacheKey)
|
||||
}
|
||||
55
backend/internal/storage/cache/redis-receipt.go
vendored
Normal file
55
backend/internal/storage/cache/redis-receipt.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 ReceiptStore struct {
|
||||
rdb *redis.Client
|
||||
}
|
||||
|
||||
func (s *ReceiptStore) generateCacheKey(id int64) string {
|
||||
return fmt.Sprintf("receipt-%d", id)
|
||||
}
|
||||
|
||||
func (s *ReceiptStore) Get(ctx context.Context, id int64) (*storage.Receipt, 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 receipt storage.Receipt
|
||||
if data != "" {
|
||||
err := json.Unmarshal([]byte(data), &receipt)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
}
|
||||
|
||||
return &receipt, nil
|
||||
}
|
||||
|
||||
func (s *ReceiptStore) Set(ctx context.Context, receipt *storage.Receipt) error {
|
||||
cacheKey := s.generateCacheKey(receipt.ID)
|
||||
|
||||
json, err := json.Marshal(receipt)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
return s.rdb.Set(ctx, cacheKey, json, ReceiptExpTime).Err()
|
||||
}
|
||||
|
||||
func (s *ReceiptStore) Delete(ctx context.Context, id int64) {
|
||||
cacheKey := s.generateCacheKey(id)
|
||||
s.rdb.Del(ctx, cacheKey)
|
||||
}
|
||||
@ -45,7 +45,7 @@ func (s *RoleStore) Set(ctx context.Context, role *storage.Role) error {
|
||||
return err
|
||||
}
|
||||
|
||||
return s.rdb.Set(ctx, cacheKey, json, RolesExpTime).Err()
|
||||
return s.rdb.Set(ctx, cacheKey, json, RoleExpTime).Err()
|
||||
}
|
||||
|
||||
func (s *RoleStore) Delete(ctx context.Context, name string) {
|
||||
@ -46,7 +46,7 @@ func (s *UserGroupsStore) Set(ctx context.Context, groups *storage.UserGroups) e
|
||||
return err
|
||||
}
|
||||
|
||||
return s.rdb.Set(ctx, cacheKey, json, RolesExpTime).Err()
|
||||
return s.rdb.Set(ctx, cacheKey, json, RoleExpTime).Err()
|
||||
}
|
||||
|
||||
func (s *UserGroupsStore) Delete(ctx context.Context, userid int64) {
|
||||
Loading…
Reference in New Issue
Block a user