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:
parent
a6fbafc079
commit
9f452aeb01
@ -43,7 +43,7 @@ func (h *MembersHandler) membersCreate(w http.ResponseWriter, r *http.Request) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// TODO: Join structs?
|
// TODO: Join structs?
|
||||||
session := h.sessions.Create(data.ID, types.MemberProfile{
|
session, err := h.sessions.Create(data.ID, types.MemberProfile{
|
||||||
Secret: data.Secret,
|
Secret: data.Secret,
|
||||||
Name: data.Name,
|
Name: data.Name,
|
||||||
IsAdmin: data.IsAdmin,
|
IsAdmin: data.IsAdmin,
|
||||||
@ -54,6 +54,11 @@ func (h *MembersHandler) membersCreate(w http.ResponseWriter, r *http.Request) {
|
|||||||
CanAccessClipboard: data.CanAccessClipboard,
|
CanAccessClipboard: data.CanAccessClipboard,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
utils.HttpInternalServerError(w, err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
utils.HttpSuccess(w, MemberCreatePayload{
|
utils.HttpSuccess(w, MemberCreatePayload{
|
||||||
ID: session.ID(),
|
ID: session.ID(),
|
||||||
})
|
})
|
||||||
|
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"
|
||||||
"github.com/rs/zerolog/log"
|
"github.com/rs/zerolog/log"
|
||||||
|
|
||||||
|
"demodesk/neko/internal/session/database"
|
||||||
"demodesk/neko/internal/types"
|
"demodesk/neko/internal/types"
|
||||||
"demodesk/neko/internal/config"
|
"demodesk/neko/internal/config"
|
||||||
"demodesk/neko/internal/utils"
|
"demodesk/neko/internal/utils"
|
||||||
@ -19,20 +20,23 @@ func New(config *config.Session) *SessionManagerCtx {
|
|||||||
host: nil,
|
host: nil,
|
||||||
hostMu: sync.Mutex{},
|
hostMu: sync.Mutex{},
|
||||||
config: config,
|
config: config,
|
||||||
|
database: database.New(),
|
||||||
members: make(map[string]*SessionCtx),
|
members: make(map[string]*SessionCtx),
|
||||||
membersMu: sync.Mutex{},
|
membersMu: sync.Mutex{},
|
||||||
emmiter: events.New(),
|
emmiter: events.New(),
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO: Import from Database at startup.
|
||||||
|
|
||||||
// create default admin account at startup
|
// create default admin account at startup
|
||||||
_ = manager.Create("admin", types.MemberProfile{
|
_, _ = manager.Create("admin", types.MemberProfile{
|
||||||
Secret: config.AdminPassword,
|
Secret: config.AdminPassword,
|
||||||
Name: "Administrator",
|
Name: "Administrator",
|
||||||
IsAdmin: true,
|
IsAdmin: true,
|
||||||
})
|
})
|
||||||
|
|
||||||
// create default user account at startup
|
// create default user account at startup
|
||||||
_ = manager.Create("user", types.MemberProfile{
|
_, _ = manager.Create("user", types.MemberProfile{
|
||||||
Secret: config.Password,
|
Secret: config.Password,
|
||||||
Name: "User",
|
Name: "User",
|
||||||
IsAdmin: false,
|
IsAdmin: false,
|
||||||
@ -46,12 +50,13 @@ type SessionManagerCtx struct {
|
|||||||
host types.Session
|
host types.Session
|
||||||
hostMu sync.Mutex
|
hostMu sync.Mutex
|
||||||
config *config.Session
|
config *config.Session
|
||||||
|
database *database.MembersDatabaseCtx
|
||||||
members map[string]*SessionCtx
|
members map[string]*SessionCtx
|
||||||
membersMu sync.Mutex
|
membersMu sync.Mutex
|
||||||
emmiter events.EventEmmiter
|
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{
|
session := &SessionCtx{
|
||||||
id: id,
|
id: id,
|
||||||
manager: manager,
|
manager: manager,
|
||||||
@ -60,21 +65,41 @@ func (manager *SessionManagerCtx) Create(id string, profile types.MemberProfile)
|
|||||||
}
|
}
|
||||||
|
|
||||||
manager.membersMu.Lock()
|
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.members[id] = session
|
||||||
manager.membersMu.Unlock()
|
manager.membersMu.Unlock()
|
||||||
|
|
||||||
manager.emmiter.Emit("created", session)
|
manager.emmiter.Emit("created", session)
|
||||||
return session
|
return session, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (manager *SessionManagerCtx) Update(id string, profile types.MemberProfile) error {
|
func (manager *SessionManagerCtx) Update(id string, profile types.MemberProfile) error {
|
||||||
manager.membersMu.Lock()
|
manager.membersMu.Lock()
|
||||||
|
|
||||||
session, ok := manager.members[id]
|
session, ok := manager.members[id]
|
||||||
if !ok {
|
if !ok {
|
||||||
manager.membersMu.Unlock()
|
manager.membersMu.Unlock()
|
||||||
return fmt.Errorf("Member not found.")
|
return fmt.Errorf("Member not found.")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
err := manager.database.Update(id, profile)
|
||||||
|
if err != nil {
|
||||||
|
manager.membersMu.Unlock()
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
session.profile = profile
|
session.profile = profile
|
||||||
manager.membersMu.Unlock()
|
manager.membersMu.Unlock()
|
||||||
|
|
||||||
@ -82,14 +107,6 @@ func (manager *SessionManagerCtx) Update(id string, profile types.MemberProfile)
|
|||||||
return nil
|
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 {
|
func (manager *SessionManagerCtx) Delete(id string) error {
|
||||||
manager.membersMu.Lock()
|
manager.membersMu.Lock()
|
||||||
session, ok := manager.members[id]
|
session, ok := manager.members[id]
|
||||||
@ -98,10 +115,15 @@ func (manager *SessionManagerCtx) Delete(id string) error {
|
|||||||
return fmt.Errorf("Member not found.")
|
return fmt.Errorf("Member not found.")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
err := manager.database.Delete(id)
|
||||||
|
if err != nil {
|
||||||
|
manager.membersMu.Unlock()
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
delete(manager.members, id)
|
delete(manager.members, id)
|
||||||
manager.membersMu.Unlock()
|
manager.membersMu.Unlock()
|
||||||
|
|
||||||
var err error
|
|
||||||
if session.IsConnected() {
|
if session.IsConnected() {
|
||||||
err = session.Disconnect("member deleted")
|
err = session.Disconnect("member deleted")
|
||||||
}
|
}
|
||||||
@ -110,6 +132,14 @@ func (manager *SessionManagerCtx) Delete(id string) error {
|
|||||||
return err
|
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
|
// host
|
||||||
// ---
|
// ---
|
||||||
|
@ -41,7 +41,7 @@ type Session interface {
|
|||||||
}
|
}
|
||||||
|
|
||||||
type SessionManager interface {
|
type SessionManager interface {
|
||||||
Create(id string, profile MemberProfile) Session
|
Create(id string, profile MemberProfile) (Session, error)
|
||||||
Update(id string, profile MemberProfile) error
|
Update(id string, profile MemberProfile) error
|
||||||
Get(id string) (Session, bool)
|
Get(id string) (Session, bool)
|
||||||
Delete(id string) error
|
Delete(id string) error
|
||||||
|
Loading…
Reference in New Issue
Block a user