mirror of
https://github.com/mainflux/mainflux.git
synced 2025-05-01 13:48:56 +08:00

* Move messaging to pkg Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Move errors to pkg Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Move Transformers to pkg Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Move SDK to pkg Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Remove Transformers from root Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Fix make proto Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Add copyrights header Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Fix CI Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Move Auth client to pkg Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Fix dependencies Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Update dependencies and vendors Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Fix CI Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com>
71 lines
2.0 KiB
Go
71 lines
2.0 KiB
Go
// Copyright (c) Mainflux
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package redis
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
|
|
"github.com/go-redis/redis"
|
|
"github.com/mainflux/mainflux/pkg/errors"
|
|
"github.com/mainflux/mainflux/things"
|
|
)
|
|
|
|
const chanPrefix = "channel"
|
|
|
|
// ErrRedisConnectChannel indicates error while adding connection in redis cache
|
|
var ErrRedisConnectChannel = errors.New("add connection to redis cache error")
|
|
|
|
// ErrRedisDisconnectChannel indicates error while removing connection from redis cache
|
|
var ErrRedisDisconnectChannel = errors.New("remove connection from redis cache error")
|
|
|
|
// ErrRedisRemoveChannel indicates error while removing channel from redis cache
|
|
var ErrRedisRemoveChannel = errors.New("remove channel from redis cache error")
|
|
|
|
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(_ context.Context, chanID, thingID string) error {
|
|
cid, tid := kv(chanID, thingID)
|
|
if err := cc.client.SAdd(cid, tid).Err(); err != nil {
|
|
return errors.Wrap(ErrRedisConnectChannel, err)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (cc channelCache) HasThing(_ context.Context, chanID, thingID string) bool {
|
|
cid, tid := kv(chanID, thingID)
|
|
return cc.client.SIsMember(cid, tid).Val()
|
|
}
|
|
|
|
func (cc channelCache) Disconnect(_ context.Context, chanID, thingID string) error {
|
|
cid, tid := kv(chanID, thingID)
|
|
if err := cc.client.SRem(cid, tid).Err(); err != nil {
|
|
return errors.Wrap(ErrRedisDisconnectChannel, err)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (cc channelCache) Remove(_ context.Context, chanID string) error {
|
|
cid, _ := kv(chanID, "0")
|
|
if err := cc.client.Del(cid).Err(); err != nil {
|
|
return errors.Wrap(ErrRedisRemoveChannel, err)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// Generates key-value pair
|
|
func kv(chanID, thingID string) (string, string) {
|
|
cid := fmt.Sprintf("%s:%s", chanPrefix, chanID)
|
|
return cid, thingID
|
|
}
|