mirror of
https://github.com/mainflux/mainflux.git
synced 2025-04-29 13:49:28 +08:00

* remove owner id Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * add users endpoint for retrieving users from group Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * remove groups from things and users Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * move groups into auth Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * separate endpoints for users and things Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * fix problems with retrieving members Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * add groups test Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * remove groups from users Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * remove groups from things Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * rename constant Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * add new errors Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * remove unnecessary constants Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * fix validation Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * create groups db mock Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * adding tests Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * revert changes to docker related files Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * remove groups endpoints from users openapi Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * remove groups endpoints from users openapi Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * move constant from postgres to groups Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * move constant from postgres to groups Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * move constant from postgres to groups Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * remove testing group Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * renam typ to groupType Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * add error for max level Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * remove print Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * remove groups.Member interface Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * fix query building and add test cases Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * uncomment tests Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * move groups package Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * remove group type, add bulk assign and unassign Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * update openapi, remove parentID from create request, reorder endpoints Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * update openapi Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * update openapi for users and things Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * fix groups test Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * fix linter errors Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * resolve comments Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * rename assignReq structure Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * refactor mocks, response, remove type from endpoint Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * some refactor, renaming, errors Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * simplify check Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * remove package alias Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * fix naming and comment Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * additional comments Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * add members grpc endpoint test Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * fix retrieving members for different types Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * fix retrieving members for different types Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * remove unecessary structure Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * fix api grpc Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * rename const Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * refactore retrieve parents and children with common function Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * small changes for errors Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * fix compile error Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * fix sorting in mock Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * remove regexp for groups Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * revert as change is made by mistake Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * revert as change is made by mistake Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * refactor groups and keys package Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * fix naming Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * fix naming Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * fix test for timestamp compare Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * fix error handling Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * remove errors not being used Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * var renaming Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * resolve comments Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * minor changes Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * fix test Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * add endpoints for groups into nginx Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * reorganize endpoints, remove some errors Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * reorganize endpoints, remove some errors Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * small fix Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * fix linter errors Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * minor changes Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * resolve comments Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * fix group save path problem Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * description constant Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * rename variables Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * fix validation Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * get back return Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * fix compile Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com>
241 lines
6.0 KiB
Go
241 lines
6.0 KiB
Go
// Copyright (c) Mainflux
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package mocks
|
|
|
|
import (
|
|
"context"
|
|
"strconv"
|
|
"sync"
|
|
|
|
"github.com/mainflux/mainflux"
|
|
"github.com/mainflux/mainflux/things"
|
|
)
|
|
|
|
var _ things.Service = (*mainfluxThings)(nil)
|
|
|
|
type mainfluxThings struct {
|
|
mu sync.Mutex
|
|
counter uint64
|
|
things map[string]things.Thing
|
|
channels map[string]things.Channel
|
|
auth mainflux.AuthServiceClient
|
|
connections map[string][]string
|
|
}
|
|
|
|
// NewThingsService returns Mainflux Things service mock.
|
|
// Only methods used by SDK are mocked.
|
|
func NewThingsService(things map[string]things.Thing, channels map[string]things.Channel, auth mainflux.AuthServiceClient) things.Service {
|
|
return &mainfluxThings{
|
|
things: things,
|
|
channels: channels,
|
|
auth: auth,
|
|
connections: make(map[string][]string),
|
|
}
|
|
}
|
|
|
|
func (svc *mainfluxThings) CreateThings(_ context.Context, owner string, ths ...things.Thing) ([]things.Thing, error) {
|
|
svc.mu.Lock()
|
|
defer svc.mu.Unlock()
|
|
|
|
userID, err := svc.auth.Identify(context.Background(), &mainflux.Token{Value: owner})
|
|
if err != nil {
|
|
return []things.Thing{}, things.ErrUnauthorizedAccess
|
|
}
|
|
for i := range ths {
|
|
svc.counter++
|
|
ths[i].Owner = userID.Email
|
|
ths[i].ID = strconv.FormatUint(svc.counter, 10)
|
|
ths[i].Key = ths[i].ID
|
|
svc.things[ths[i].ID] = ths[i]
|
|
}
|
|
|
|
return ths, nil
|
|
}
|
|
|
|
func (svc *mainfluxThings) ViewThing(_ context.Context, owner, id string) (things.Thing, error) {
|
|
svc.mu.Lock()
|
|
defer svc.mu.Unlock()
|
|
|
|
userID, err := svc.auth.Identify(context.Background(), &mainflux.Token{Value: owner})
|
|
if err != nil {
|
|
return things.Thing{}, things.ErrUnauthorizedAccess
|
|
}
|
|
|
|
if t, ok := svc.things[id]; ok && t.Owner == userID.Email {
|
|
return t, nil
|
|
|
|
}
|
|
|
|
return things.Thing{}, things.ErrNotFound
|
|
}
|
|
|
|
func (svc *mainfluxThings) Connect(_ context.Context, owner string, chIDs, thIDs []string) error {
|
|
svc.mu.Lock()
|
|
defer svc.mu.Unlock()
|
|
|
|
userID, err := svc.auth.Identify(context.Background(), &mainflux.Token{Value: owner})
|
|
if err != nil {
|
|
return things.ErrUnauthorizedAccess
|
|
}
|
|
for _, chID := range chIDs {
|
|
if svc.channels[chID].Owner != userID.Email {
|
|
return things.ErrUnauthorizedAccess
|
|
}
|
|
for _, thID := range thIDs {
|
|
svc.connections[chID] = append(svc.connections[chID], thID)
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (svc *mainfluxThings) Disconnect(_ context.Context, owner, chanID, thingID string) error {
|
|
svc.mu.Lock()
|
|
defer svc.mu.Unlock()
|
|
|
|
userID, err := svc.auth.Identify(context.Background(), &mainflux.Token{Value: owner})
|
|
if err != nil || svc.channels[chanID].Owner != userID.Email {
|
|
return things.ErrUnauthorizedAccess
|
|
}
|
|
|
|
ids := svc.connections[chanID]
|
|
i := 0
|
|
for _, t := range ids {
|
|
if t == thingID {
|
|
break
|
|
}
|
|
i++
|
|
}
|
|
|
|
if i == len(ids) {
|
|
return things.ErrNotFound
|
|
}
|
|
|
|
var tmp []string
|
|
if i != len(ids)-2 {
|
|
tmp = ids[i+1:]
|
|
}
|
|
ids = append(ids[:i], tmp...)
|
|
svc.connections[chanID] = ids
|
|
|
|
return nil
|
|
}
|
|
|
|
func (svc *mainfluxThings) RemoveThing(_ context.Context, owner, id string) error {
|
|
svc.mu.Lock()
|
|
defer svc.mu.Unlock()
|
|
|
|
userID, err := svc.auth.Identify(context.Background(), &mainflux.Token{Value: owner})
|
|
if err != nil {
|
|
return things.ErrUnauthorizedAccess
|
|
}
|
|
|
|
if t, ok := svc.things[id]; !ok || t.Owner != userID.Email {
|
|
return things.ErrNotFound
|
|
}
|
|
|
|
delete(svc.things, id)
|
|
conns := make(map[string][]string)
|
|
for k, v := range svc.connections {
|
|
i := findIndex(v, id)
|
|
if i != -1 {
|
|
var tmp []string
|
|
if i != len(v)-2 {
|
|
tmp = v[i+1:]
|
|
}
|
|
conns[k] = append(v[:i], tmp...)
|
|
}
|
|
}
|
|
|
|
svc.connections = conns
|
|
return nil
|
|
}
|
|
|
|
func (svc *mainfluxThings) ViewChannel(_ context.Context, owner, id string) (things.Channel, error) {
|
|
if c, ok := svc.channels[id]; ok {
|
|
return c, nil
|
|
}
|
|
return things.Channel{}, things.ErrNotFound
|
|
}
|
|
|
|
func (svc *mainfluxThings) UpdateThing(context.Context, string, things.Thing) error {
|
|
panic("not implemented")
|
|
}
|
|
|
|
func (svc *mainfluxThings) UpdateKey(context.Context, string, string, string) error {
|
|
panic("not implemented")
|
|
}
|
|
|
|
func (svc *mainfluxThings) ListThings(context.Context, string, things.PageMetadata) (things.Page, error) {
|
|
panic("not implemented")
|
|
}
|
|
|
|
func (svc *mainfluxThings) ListChannelsByThing(context.Context, string, string, things.PageMetadata) (things.ChannelsPage, error) {
|
|
panic("not implemented")
|
|
}
|
|
|
|
func (svc *mainfluxThings) ListThingsByChannel(context.Context, string, string, things.PageMetadata) (things.Page, error) {
|
|
panic("not implemented")
|
|
}
|
|
|
|
func (svc *mainfluxThings) CreateChannels(_ context.Context, owner string, chs ...things.Channel) ([]things.Channel, error) {
|
|
svc.mu.Lock()
|
|
defer svc.mu.Unlock()
|
|
|
|
userID, err := svc.auth.Identify(context.Background(), &mainflux.Token{Value: owner})
|
|
if err != nil {
|
|
return []things.Channel{}, things.ErrUnauthorizedAccess
|
|
}
|
|
for i := range chs {
|
|
svc.counter++
|
|
chs[i].Owner = userID.Email
|
|
chs[i].ID = strconv.FormatUint(svc.counter, 10)
|
|
svc.channels[chs[i].ID] = chs[i]
|
|
}
|
|
|
|
return chs, nil
|
|
}
|
|
|
|
func (svc *mainfluxThings) UpdateChannel(context.Context, string, things.Channel) error {
|
|
panic("not implemented")
|
|
}
|
|
|
|
func (svc *mainfluxThings) ListChannels(context.Context, string, things.PageMetadata) (things.ChannelsPage, error) {
|
|
panic("not implemented")
|
|
}
|
|
|
|
func (svc *mainfluxThings) RemoveChannel(context.Context, string, string) error {
|
|
panic("not implemented")
|
|
}
|
|
|
|
func (svc *mainfluxThings) CanAccessByKey(context.Context, string, string) (string, error) {
|
|
panic("not implemented")
|
|
}
|
|
|
|
func (svc *mainfluxThings) CanAccessByID(context.Context, string, string) error {
|
|
panic("not implemented")
|
|
}
|
|
|
|
func (svc *mainfluxThings) IsChannelOwner(context.Context, string, string) error {
|
|
panic("not implemented")
|
|
}
|
|
|
|
func (svc *mainfluxThings) Identify(context.Context, string) (string, error) {
|
|
panic("not implemented")
|
|
}
|
|
|
|
func findIndex(list []string, val string) int {
|
|
for i, v := range list {
|
|
if v == val {
|
|
return i
|
|
}
|
|
}
|
|
|
|
return -1
|
|
}
|
|
|
|
func (svc *mainfluxThings) ListMembers(ctx context.Context, token, groupID string, pm things.PageMetadata) (things.Page, error) {
|
|
panic("not implemented")
|
|
}
|