mirror of
https://github.com/mainflux/mainflux.git
synced 2025-05-04 22:17:59 +08:00

* Switch CoAP lib Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Revert removed adapter code Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * WIP CoAP refactor Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Add auth key Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Fix observers map Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Fix reading message body Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Fix subtopic parsing Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Fix error handling Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Fix multi-protocol communication Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Separate client from observer Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Remove unused config Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Remove TCP option Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Inline error check Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Add logging client errors Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Replace RWMutex since we're not using RLock Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Inline error handling Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Inline error handling Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com>
65 lines
1.3 KiB
Go
65 lines
1.3 KiB
Go
package tcp
|
|
|
|
import (
|
|
"fmt"
|
|
"sync"
|
|
|
|
"github.com/plgd-dev/go-coap/v2/message"
|
|
)
|
|
|
|
// HandlerContainer for regirstration handlers by key
|
|
type HandlerContainer struct {
|
|
datas map[interface{}]HandlerFunc
|
|
mutex sync.Mutex
|
|
}
|
|
|
|
// NewHandlerContainer factory
|
|
func NewHandlerContainer() *HandlerContainer {
|
|
return &HandlerContainer{
|
|
datas: make(map[interface{}]HandlerFunc),
|
|
}
|
|
}
|
|
|
|
// Insert handler for key.
|
|
func (s *HandlerContainer) Insert(key interface{}, handler HandlerFunc) error {
|
|
if v, ok := key.(message.Token); ok {
|
|
key = v.String()
|
|
}
|
|
s.mutex.Lock()
|
|
defer s.mutex.Unlock()
|
|
if s.datas[key] != nil {
|
|
return fmt.Errorf("key already exist")
|
|
}
|
|
s.datas[key] = handler
|
|
return nil
|
|
}
|
|
|
|
// Get returns handler for key
|
|
func (s *HandlerContainer) Get(key interface{}) (HandlerFunc, error) {
|
|
if v, ok := key.(message.Token); ok {
|
|
key = v.String()
|
|
}
|
|
s.mutex.Lock()
|
|
defer s.mutex.Unlock()
|
|
v := s.datas[key]
|
|
if v == nil {
|
|
return nil, fmt.Errorf("key not exist")
|
|
}
|
|
return v, nil
|
|
}
|
|
|
|
// Pop pops handler for key
|
|
func (s *HandlerContainer) Pop(key interface{}) (HandlerFunc, error) {
|
|
if v, ok := key.(message.Token); ok {
|
|
key = v.String()
|
|
}
|
|
s.mutex.Lock()
|
|
defer s.mutex.Unlock()
|
|
v := s.datas[key]
|
|
if v == nil {
|
|
return nil, fmt.Errorf("key not exist")
|
|
}
|
|
delete(s.datas, key)
|
|
return v, nil
|
|
}
|