1
0
mirror of https://github.com/mainflux/mainflux.git synced 2025-04-29 13:49:28 +08:00
Aleksandar Novaković 0c77d84176 MF-382 - Improve performance by adding Redis cache for message auth (#383)
* Add redis caching for thing and channel connections

Signed-off-by: Aleksandar Novakovic <aleksandar.novakovic@mainflux.com>

* Fix authorization caching flow

Signed-off-by: Aleksandar Novakovic <aleksandar.novakovic@mainflux.com>

* Update things documentation

Signed-off-by: Aleksandar Novakovic <aleksandar.novakovic@mainflux.com>
2018-09-04 22:19:43 +02:00

57 lines
1.2 KiB
Go

//
// Copyright (c) 2018
// Mainflux
//
// SPDX-License-Identifier: Apache-2.0
//
package redis
import (
"fmt"
"strconv"
"github.com/go-redis/redis"
"github.com/mainflux/mainflux/things"
)
const chanPrefix = "channel"
var _ things.ChannelCache = (*channelCache)(nil)
type channelCache struct {
client *redis.Client
}
// NewChannelCache returns redis channel cache implementation.
func NewChannelCache(client *redis.Client) things.ChannelCache {
return channelCache{client: client}
}
func (cc channelCache) Connect(chanID, thingID uint64) error {
cid, tid := kv(chanID, thingID)
return cc.client.SAdd(cid, tid).Err()
}
func (cc channelCache) HasThing(chanID, thingID uint64) bool {
cid, tid := kv(chanID, thingID)
return cc.client.SIsMember(cid, tid).Val()
}
func (cc channelCache) Disconnect(chanID, thingID uint64) error {
cid, tid := kv(chanID, thingID)
return cc.client.SRem(cid, tid).Err()
}
func (cc channelCache) Remove(chanID uint64) error {
cid, _ := kv(chanID, 0)
return cc.client.Del(cid).Err()
}
// Generates key-value pair
func kv(chanID, thingID uint64) (string, string) {
cid := fmt.Sprintf("%s:%d", chanPrefix, chanID)
tid := strconv.FormatUint(thingID, 10)
return cid, tid
}