2020-10-10 18:53:59 +02:00
|
|
|
// Copyright 2020 Vikunja and contriubtors. All rights reserved.
|
|
|
|
//
|
|
|
|
// This file is part of Vikunja.
|
|
|
|
//
|
|
|
|
// Vikunja is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU General Public License as published by
|
|
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
|
|
// (at your option) any later version.
|
|
|
|
//
|
|
|
|
// Vikunja 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 General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
|
|
// along with Vikunja. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
package redis
|
|
|
|
|
|
|
|
import (
|
2020-10-11 22:10:03 +02:00
|
|
|
"encoding/json"
|
|
|
|
|
|
|
|
"github.com/go-errors/errors"
|
|
|
|
|
2020-10-10 18:53:59 +02:00
|
|
|
e "code.vikunja.io/api/pkg/modules/keyvalue/error"
|
|
|
|
"code.vikunja.io/api/pkg/red"
|
|
|
|
"github.com/go-redis/redis/v7"
|
|
|
|
)
|
|
|
|
|
|
|
|
// 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(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(key).Bytes()
|
|
|
|
if err != nil {
|
2020-10-11 22:10:03 +02:00
|
|
|
if errors.Is(err, redis.Nil) {
|
2020-10-10 18:53:59 +02:00
|
|
|
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(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(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(key, update).Err()
|
|
|
|
}
|