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

* remove owner id Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * move authz into authn and merge into new service Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * add groups Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * add groups Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * add groups endpoints Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * add group type Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * adding mocks, some renaming, refactor Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * update proto Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * adding mocks, some renaming, refactor Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * fix linter err,and comments Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * undo renaming, add interface for authn and authz Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * renam some variables Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * renaming Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * remove extra slashes from comment Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com> * resolving small remarks Signed-off-by: Mirko Teodorovic <mirko.teodorovic@gmail.com>
56 lines
1.2 KiB
Go
56 lines
1.2 KiB
Go
// Copyright (c) Mainflux
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package mocks
|
|
|
|
import (
|
|
"context"
|
|
"sync"
|
|
|
|
"github.com/mainflux/mainflux/auth"
|
|
)
|
|
|
|
var _ auth.KeyRepository = (*keyRepositoryMock)(nil)
|
|
|
|
type keyRepositoryMock struct {
|
|
mu sync.Mutex
|
|
keys map[string]auth.Key
|
|
}
|
|
|
|
// NewKeyRepository creates in-memory user repository
|
|
func NewKeyRepository() auth.KeyRepository {
|
|
return &keyRepositoryMock{
|
|
keys: make(map[string]auth.Key),
|
|
}
|
|
}
|
|
|
|
func (krm *keyRepositoryMock) Save(ctx context.Context, key auth.Key) (string, error) {
|
|
krm.mu.Lock()
|
|
defer krm.mu.Unlock()
|
|
|
|
if _, ok := krm.keys[key.ID]; ok {
|
|
return "", auth.ErrConflict
|
|
}
|
|
|
|
krm.keys[key.ID] = key
|
|
return key.ID, nil
|
|
}
|
|
func (krm *keyRepositoryMock) Retrieve(ctx context.Context, issuerID, id string) (auth.Key, error) {
|
|
krm.mu.Lock()
|
|
defer krm.mu.Unlock()
|
|
|
|
if key, ok := krm.keys[id]; ok && key.IssuerID == issuerID {
|
|
return key, nil
|
|
}
|
|
|
|
return auth.Key{}, auth.ErrNotFound
|
|
}
|
|
func (krm *keyRepositoryMock) Remove(ctx context.Context, issuerID, id string) error {
|
|
krm.mu.Lock()
|
|
defer krm.mu.Unlock()
|
|
if key, ok := krm.keys[id]; ok && key.IssuerID == issuerID {
|
|
delete(krm.keys, id)
|
|
}
|
|
return nil
|
|
}
|