// Vikunja is a to-do list application to facilitate your life. // Copyright 2018-2020 Vikunja and contributors. All rights reserved. // // This program is free software: you can redistribute it and/or modify // it under the terms of the GNU Affero General Public Licensee as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU Affero General Public Licensee for more details. // // You should have received a copy of the GNU Affero General Public Licensee // along with this program. If not, see . package redis import ( "context" "encoding/json" "github.com/go-errors/errors" e "code.vikunja.io/api/pkg/modules/keyvalue/error" "code.vikunja.io/api/pkg/red" "github.com/go-redis/redis/v8" ) // Storage is a redis implementation of a keyvalue storage type Storage struct { client *redis.Client } // NewStorage creates a new redis key value storage func NewStorage() *Storage { red.InitRedis() return &Storage{ client: red.GetRedis(), } } // Put puts a value into redis func (s *Storage) Put(key string, value interface{}) (err error) { v, err := json.Marshal(value) if err != nil { return err } return s.client.Set(context.Background(), key, v, 0).Err() } // Get retrieves a saved value from redis func (s *Storage) Get(key string) (value interface{}, err error) { b, err := s.client.Get(context.Background(), key).Bytes() if err != nil { if errors.Is(err, redis.Nil) { return nil, &e.ErrValueNotFoundForKey{Key: key} } return nil, err } err = json.Unmarshal(b, value) return } // Del removed a value from redis func (s *Storage) Del(key string) (err error) { return s.client.Del(context.Background(), key).Err() } // IncrBy increases the value saved at key by the amount provided through update func (s *Storage) IncrBy(key string, update int64) (err error) { return s.client.IncrBy(context.Background(), key, update).Err() } // DecrBy decreases the value saved at key by the amount provided through update func (s *Storage) DecrBy(key string, update int64) (err error) { return s.client.DecrBy(context.Background(), key, update).Err() }