mirror of
https://github.com/m1k1o/neko.git
synced 2024-07-24 14:40:50 +12:00
add database to Sessions.
This commit is contained in:
67
internal/session/database/manager.go
Normal file
67
internal/session/database/manager.go
Normal file
@ -0,0 +1,67 @@
|
||||
package database
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"sync"
|
||||
|
||||
"demodesk/neko/internal/types"
|
||||
)
|
||||
|
||||
func New() *MembersDatabaseCtx {
|
||||
return &MembersDatabaseCtx{
|
||||
profiles: make(map[string]types.MemberProfile),
|
||||
mu: sync.Mutex{},
|
||||
}
|
||||
}
|
||||
|
||||
type MembersDatabaseCtx struct {
|
||||
profiles map[string]types.MemberProfile
|
||||
mu sync.Mutex
|
||||
}
|
||||
|
||||
func (manager *MembersDatabaseCtx) Insert(id string, profile types.MemberProfile) error {
|
||||
manager.mu.Lock()
|
||||
defer manager.mu.Unlock()
|
||||
|
||||
_, ok := manager.profiles[id]
|
||||
if ok {
|
||||
return fmt.Errorf("Member ID already exists.")
|
||||
}
|
||||
|
||||
manager.profiles[id] = profile
|
||||
return nil
|
||||
}
|
||||
|
||||
func (manager *MembersDatabaseCtx) Update(id string, profile types.MemberProfile) error {
|
||||
manager.mu.Lock()
|
||||
defer manager.mu.Unlock()
|
||||
|
||||
_, ok := manager.profiles[id]
|
||||
if !ok {
|
||||
return fmt.Errorf("Member ID does not exist.")
|
||||
}
|
||||
|
||||
manager.profiles[id] = profile
|
||||
return nil
|
||||
}
|
||||
|
||||
func (manager *MembersDatabaseCtx) Delete(id string) error {
|
||||
manager.mu.Lock()
|
||||
defer manager.mu.Unlock()
|
||||
|
||||
_, ok := manager.profiles[id]
|
||||
if !ok {
|
||||
return fmt.Errorf("Member ID does not exist.")
|
||||
}
|
||||
|
||||
delete(manager.profiles, id)
|
||||
return nil
|
||||
}
|
||||
|
||||
func (manager *MembersDatabaseCtx) Select(id string) (types.MemberProfile, bool) {
|
||||
manager.mu.Lock()
|
||||
defer manager.mu.Unlock()
|
||||
|
||||
profile, ok := manager.profiles[id]
|
||||
return profile, ok
|
||||
}
|
@ -8,6 +8,7 @@ import (
|
||||
"github.com/rs/zerolog"
|
||||
"github.com/rs/zerolog/log"
|
||||
|
||||
"demodesk/neko/internal/session/database"
|
||||
"demodesk/neko/internal/types"
|
||||
"demodesk/neko/internal/config"
|
||||
"demodesk/neko/internal/utils"
|
||||
@ -19,20 +20,23 @@ func New(config *config.Session) *SessionManagerCtx {
|
||||
host: nil,
|
||||
hostMu: sync.Mutex{},
|
||||
config: config,
|
||||
database: database.New(),
|
||||
members: make(map[string]*SessionCtx),
|
||||
membersMu: sync.Mutex{},
|
||||
emmiter: events.New(),
|
||||
}
|
||||
|
||||
// TODO: Import from Database at startup.
|
||||
|
||||
// create default admin account at startup
|
||||
_ = manager.Create("admin", types.MemberProfile{
|
||||
_, _ = manager.Create("admin", types.MemberProfile{
|
||||
Secret: config.AdminPassword,
|
||||
Name: "Administrator",
|
||||
IsAdmin: true,
|
||||
})
|
||||
|
||||
// create default user account at startup
|
||||
_ = manager.Create("user", types.MemberProfile{
|
||||
_, _ = manager.Create("user", types.MemberProfile{
|
||||
Secret: config.Password,
|
||||
Name: "User",
|
||||
IsAdmin: false,
|
||||
@ -46,35 +50,56 @@ type SessionManagerCtx struct {
|
||||
host types.Session
|
||||
hostMu sync.Mutex
|
||||
config *config.Session
|
||||
database *database.MembersDatabaseCtx
|
||||
members map[string]*SessionCtx
|
||||
membersMu sync.Mutex
|
||||
emmiter events.EventEmmiter
|
||||
}
|
||||
|
||||
func (manager *SessionManagerCtx) Create(id string, profile types.MemberProfile) types.Session {
|
||||
func (manager *SessionManagerCtx) Create(id string, profile types.MemberProfile) (types.Session, error) {
|
||||
session := &SessionCtx{
|
||||
id: id,
|
||||
manager: manager,
|
||||
logger: manager.logger.With().Str("id", id).Logger(),
|
||||
profile: profile,
|
||||
id: id,
|
||||
manager: manager,
|
||||
logger: manager.logger.With().Str("id", id).Logger(),
|
||||
profile: profile,
|
||||
}
|
||||
|
||||
manager.membersMu.Lock()
|
||||
|
||||
_, ok := manager.members[id]
|
||||
if ok {
|
||||
manager.membersMu.Unlock()
|
||||
return nil, fmt.Errorf("Member ID already exists.")
|
||||
}
|
||||
|
||||
err := manager.database.Insert(id, profile)
|
||||
if err != nil {
|
||||
manager.membersMu.Unlock()
|
||||
return nil, err
|
||||
}
|
||||
|
||||
manager.members[id] = session
|
||||
manager.membersMu.Unlock()
|
||||
|
||||
manager.emmiter.Emit("created", session)
|
||||
return session
|
||||
return session, nil
|
||||
}
|
||||
|
||||
func (manager *SessionManagerCtx) Update(id string, profile types.MemberProfile) error {
|
||||
manager.membersMu.Lock()
|
||||
|
||||
session, ok := manager.members[id]
|
||||
if !ok {
|
||||
manager.membersMu.Unlock()
|
||||
return fmt.Errorf("Member not found.")
|
||||
}
|
||||
|
||||
err := manager.database.Update(id, profile)
|
||||
if err != nil {
|
||||
manager.membersMu.Unlock()
|
||||
return err
|
||||
}
|
||||
|
||||
session.profile = profile
|
||||
manager.membersMu.Unlock()
|
||||
|
||||
@ -82,14 +107,6 @@ func (manager *SessionManagerCtx) Update(id string, profile types.MemberProfile)
|
||||
return nil
|
||||
}
|
||||
|
||||
func (manager *SessionManagerCtx) Get(id string) (types.Session, bool) {
|
||||
manager.membersMu.Lock()
|
||||
session, ok := manager.members[id]
|
||||
manager.membersMu.Unlock()
|
||||
|
||||
return session, ok
|
||||
}
|
||||
|
||||
func (manager *SessionManagerCtx) Delete(id string) error {
|
||||
manager.membersMu.Lock()
|
||||
session, ok := manager.members[id]
|
||||
@ -98,10 +115,15 @@ func (manager *SessionManagerCtx) Delete(id string) error {
|
||||
return fmt.Errorf("Member not found.")
|
||||
}
|
||||
|
||||
err := manager.database.Delete(id)
|
||||
if err != nil {
|
||||
manager.membersMu.Unlock()
|
||||
return err
|
||||
}
|
||||
|
||||
delete(manager.members, id)
|
||||
manager.membersMu.Unlock()
|
||||
|
||||
var err error
|
||||
if session.IsConnected() {
|
||||
err = session.Disconnect("member deleted")
|
||||
}
|
||||
@ -110,6 +132,14 @@ func (manager *SessionManagerCtx) Delete(id string) error {
|
||||
return err
|
||||
}
|
||||
|
||||
func (manager *SessionManagerCtx) Get(id string) (types.Session, bool) {
|
||||
manager.membersMu.Lock()
|
||||
defer manager.membersMu.Unlock()
|
||||
|
||||
session, ok := manager.members[id]
|
||||
return session, ok
|
||||
}
|
||||
|
||||
// ---
|
||||
// host
|
||||
// ---
|
||||
|
Reference in New Issue
Block a user