neko/internal/member/object/provider.go

173 lines
3.7 KiB
Go
Raw Normal View History

2021-03-15 00:57:19 +13:00
package object
import (
"fmt"
"sync"
"demodesk/neko/internal/types"
)
2021-03-15 04:58:18 +13:00
func New(config Config) types.MemberProvider {
return &MemberProviderCtx{
2021-03-15 01:07:03 +13:00
config: config,
2021-03-15 02:44:03 +13:00
entries: make(map[string]*MemberEntry),
2021-03-15 00:57:19 +13:00
mu: sync.Mutex{},
}
}
2021-03-15 04:58:18 +13:00
type MemberProviderCtx struct {
2021-03-15 01:07:03 +13:00
config Config
2021-03-15 02:44:03 +13:00
entries map[string]*MemberEntry
2021-03-15 00:57:19 +13:00
mu sync.Mutex
}
2021-03-15 04:58:18 +13:00
func (provider *MemberProviderCtx) Connect() error {
var err error
2021-03-15 04:58:18 +13:00
if provider.config.AdminPassword != "" {
// create default admin account at startup
2021-03-15 04:58:18 +13:00
_, err = provider.Insert("admin", provider.config.AdminPassword, types.MemberProfile{
Name: "Administrator",
IsAdmin: true,
CanLogin: true,
CanConnect: true,
CanWatch: true,
CanHost: true,
CanAccessClipboard: true,
})
}
2021-03-15 04:58:18 +13:00
if provider.config.UserPassword != "" {
// create default user account at startup
2021-03-15 04:58:18 +13:00
_, err = provider.Insert("user", provider.config.UserPassword, types.MemberProfile{
Name: "User",
IsAdmin: false,
CanLogin: true,
CanConnect: true,
CanWatch: true,
CanHost: true,
CanAccessClipboard: true,
})
}
return err
2021-03-15 00:57:19 +13:00
}
2021-03-15 04:58:18 +13:00
func (provider *MemberProviderCtx) Disconnect() error {
2021-03-15 00:57:19 +13:00
return nil
}
2021-03-15 04:58:18 +13:00
func (provider *MemberProviderCtx) Authenticate(username string, password string) (string, types.MemberProfile, error) {
provider.mu.Lock()
defer provider.mu.Unlock()
2021-03-15 00:57:19 +13:00
// id will be also username
id := username
2021-03-15 04:58:18 +13:00
entry, ok := provider.entries[id]
2021-03-15 00:57:19 +13:00
if !ok {
return "", types.MemberProfile{}, fmt.Errorf("Member ID does not exist.")
}
// TODO: Use hash function.
if entry.Password != password {
return "", types.MemberProfile{}, fmt.Errorf("Invalid password.")
}
return id, entry.Profile, nil
}
2021-03-15 04:58:18 +13:00
func (provider *MemberProviderCtx) Insert(username string, password string, profile types.MemberProfile) (string, error) {
provider.mu.Lock()
defer provider.mu.Unlock()
2021-03-15 00:57:19 +13:00
// id will be also username
id := username
2021-03-15 04:58:18 +13:00
_, ok := provider.entries[id]
2021-03-15 00:57:19 +13:00
if ok {
return "", fmt.Errorf("Member ID already exists.")
}
2021-03-15 04:58:18 +13:00
provider.entries[id] = &MemberEntry{
2021-03-15 02:44:03 +13:00
// TODO: Use hash function.
Password: password,
Profile: profile,
}
2021-03-15 00:57:19 +13:00
return id, nil
}
2021-03-15 04:58:18 +13:00
func (provider *MemberProviderCtx) UpdateProfile(id string, profile types.MemberProfile) error {
provider.mu.Lock()
defer provider.mu.Unlock()
2021-03-15 00:57:19 +13:00
2021-03-15 04:58:18 +13:00
entry, ok := provider.entries[id]
2021-03-15 00:57:19 +13:00
if !ok {
return fmt.Errorf("Member ID does not exist.")
}
entry.Profile = profile
return nil
}
2021-03-15 04:58:18 +13:00
func (provider *MemberProviderCtx) UpdatePassword(id string, password string) error {
provider.mu.Lock()
defer provider.mu.Unlock()
2021-03-15 00:57:19 +13:00
2021-03-15 04:58:18 +13:00
entry, ok := provider.entries[id]
2021-03-15 00:57:19 +13:00
if !ok {
return fmt.Errorf("Member ID does not exist.")
}
// TODO: Use hash function.
entry.Password = password
return nil
}
2021-03-15 04:58:18 +13:00
func (provider *MemberProviderCtx) Select(id string) (types.MemberProfile, error) {
provider.mu.Lock()
defer provider.mu.Unlock()
2021-03-15 00:57:19 +13:00
2021-03-15 04:58:18 +13:00
entry, ok := provider.entries[id]
2021-03-15 02:44:03 +13:00
if !ok {
return types.MemberProfile{}, fmt.Errorf("Member ID does not exist.")
2021-03-15 00:57:19 +13:00
}
return entry.Profile, nil
}
2021-03-15 04:58:18 +13:00
func (provider *MemberProviderCtx) SelectAll(limit int, offset int) (map[string]types.MemberProfile, error) {
provider.mu.Lock()
defer provider.mu.Unlock()
2021-03-15 00:57:19 +13:00
2021-03-15 02:44:03 +13:00
profiles := make(map[string]types.MemberProfile)
2021-03-15 00:57:19 +13:00
i := 0
2021-03-15 04:58:18 +13:00
for id, entry := range provider.entries {
2021-03-15 02:44:03 +13:00
if i >= offset && (limit == 0 || i < offset+limit) {
profiles[id] = entry.Profile
2021-03-15 00:57:19 +13:00
}
i = i + 1
}
return profiles, nil
}
2021-03-15 04:58:18 +13:00
func (provider *MemberProviderCtx) Delete(id string) error {
provider.mu.Lock()
defer provider.mu.Unlock()
2021-03-15 00:57:19 +13:00
2021-03-15 04:58:18 +13:00
_, ok := provider.entries[id]
2021-03-15 00:57:19 +13:00
if !ok {
return fmt.Errorf("Member ID does not exist.")
}
2021-03-15 04:58:18 +13:00
delete(provider.entries, id)
2021-03-15 00:57:19 +13:00
return nil
}