redis_storage.go 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. package distcache
  2. import (
  3. "time"
  4. redis "gopkg.in/redis.v2"
  5. )
  6. type redisStorage struct {
  7. c *redis.Client
  8. }
  9. func newRedisStorage(c *redis.Client) *redisStorage {
  10. opt := &redis.Options{
  11. Network: "tcp",
  12. Addr: "localhost:6379",
  13. }
  14. return &redisStorage{
  15. c: redis.NewClient(opt),
  16. }
  17. }
  18. // Set sets value to given key in session.
  19. func (s *redisStorage) Put(key string, val interface{}, expires time.Duration) error {
  20. item := &cachedItem{Val: val}
  21. value, err := encodeGob(item)
  22. if err != nil {
  23. return err
  24. }
  25. var status *redis.StatusCmd
  26. if expires == 0 {
  27. status = s.c.Set(key, string(value))
  28. } else {
  29. status = s.c.SetEx(key, expires, string(value))
  30. }
  31. return status.Err()
  32. }
  33. // Get gets value by given key in session.
  34. func (s *redisStorage) Get(key string) (interface{}, error) {
  35. v := s.c.Get(key)
  36. item := &cachedItem{}
  37. err := decodeGob([]byte(v.Val()), item)
  38. if err == nil {
  39. return item.Val, nil
  40. }
  41. if err.Error() == "EOF" {
  42. return nil, ErrCacheItemNotFound
  43. }
  44. if err != nil {
  45. return nil, err
  46. }
  47. return item.Val, nil
  48. }
  49. // Delete delete a key from session.
  50. func (s *redisStorage) Delete(key string) error {
  51. cmd := s.c.Del(key)
  52. return cmd.Err()
  53. }