Compare commits

...

3 Commits

Author SHA1 Message Date
c91c784338 Redis image (struct not actual image) caching implementation
Signed-off-by: Ethan Wellenreiter <ewellenreiter@gmail.com>
2025-05-07 00:22:08 -04:00
c34c3dfa51 Fixing naming scheme for redis caching files 2025-05-07 00:18:37 -04:00
4fd63574c2 Implementing redis caching for receipts
Signed-off-by: Ethan Wellenreiter <ewellenreiter@gmail.com>
2025-05-07 00:16:54 -04:00
7 changed files with 116 additions and 6 deletions

View File

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

View File

@ -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) {

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

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

View File

@ -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) {

View File

@ -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) {