member profile & state to types.

This commit is contained in:
Miroslav Šedivý 2020-12-08 15:14:20 +01:00
parent 58c8104ce6
commit 209971cb8a
5 changed files with 68 additions and 92 deletions

View File

@ -9,28 +9,19 @@ import (
type MemberCreatePayload struct { type MemberCreatePayload struct {
ID string `json:"id"` ID string `json:"id"`
} *types.MemberProfile
type MemberDataPayload struct {
ID string `json:"id"`
Secret string `json:"secret,omitempty"`
Name string `json:"name"`
IsAdmin bool `json:"is_admin"`
CanLogin bool `json:"can_login"`
CanConnect bool `json:"can_connect"`
CanWatch bool `json:"can_watch"`
CanHost bool `json:"can_host"`
CanAccessClipboard bool `json:"can_access_clipboard"`
} }
func (h *MembersHandler) membersCreate(w http.ResponseWriter, r *http.Request) { func (h *MembersHandler) membersCreate(w http.ResponseWriter, r *http.Request) {
data := &MemberDataPayload{ data := &MemberCreatePayload{
IsAdmin: false, MemberProfile: &types.MemberProfile{
CanLogin: true, IsAdmin: false,
CanConnect: true, CanLogin: true,
CanWatch: true, CanConnect: true,
CanHost: true, CanWatch: true,
CanAccessClipboard: true, CanHost: true,
CanAccessClipboard: true,
},
} }
if !utils.HttpJsonRequest(w, r, data) { if !utils.HttpJsonRequest(w, r, data) {
@ -60,18 +51,7 @@ func (h *MembersHandler) membersCreate(w http.ResponseWriter, r *http.Request) {
} }
} }
// TODO: Join structs? session, err := h.sessions.Create(data.ID, *data.MemberProfile)
session, err := h.sessions.Create(data.ID, types.MemberProfile{
Secret: data.Secret,
Name: data.Name,
IsAdmin: data.IsAdmin,
CanLogin: data.CanLogin,
CanConnect: data.CanConnect,
CanWatch: data.CanWatch,
CanHost: data.CanHost,
CanAccessClipboard: data.CanAccessClipboard,
})
if err != nil { if err != nil {
utils.HttpInternalServerError(w, err) utils.HttpInternalServerError(w, err)
return return
@ -85,8 +65,8 @@ func (h *MembersHandler) membersCreate(w http.ResponseWriter, r *http.Request) {
func (h *MembersHandler) membersRead(w http.ResponseWriter, r *http.Request) { func (h *MembersHandler) membersRead(w http.ResponseWriter, r *http.Request) {
member := GetMember(r) member := GetMember(r)
// TODO: Join structs? // TODO: Get whole profile from session.
utils.HttpSuccess(w, MemberDataPayload{ utils.HttpSuccess(w, types.MemberProfile{
Name: member.Name(), Name: member.Name(),
IsAdmin: member.IsAdmin(), IsAdmin: member.IsAdmin(),
CanLogin: member.CanLogin(), CanLogin: member.CanLogin(),
@ -100,7 +80,8 @@ func (h *MembersHandler) membersRead(w http.ResponseWriter, r *http.Request) {
func (h *MembersHandler) membersUpdate(w http.ResponseWriter, r *http.Request) { func (h *MembersHandler) membersUpdate(w http.ResponseWriter, r *http.Request) {
member := GetMember(r) member := GetMember(r)
data := &MemberDataPayload{ // TODO: Get whole profile from session.
profile := types.MemberProfile{
Name: member.Name(), Name: member.Name(),
IsAdmin: member.IsAdmin(), IsAdmin: member.IsAdmin(),
CanLogin: member.CanLogin(), CanLogin: member.CanLogin(),
@ -110,23 +91,11 @@ func (h *MembersHandler) membersUpdate(w http.ResponseWriter, r *http.Request) {
CanAccessClipboard: member.CanAccessClipboard(), CanAccessClipboard: member.CanAccessClipboard(),
} }
if !utils.HttpJsonRequest(w, r, data) { if !utils.HttpJsonRequest(w, r, &profile) {
return return
} }
// TODO: Join structs? if err := h.sessions.Update(member.ID(), profile); err != nil {
err := h.sessions.Update(member.ID(), types.MemberProfile{
Secret: data.Secret,
Name: data.Name,
IsAdmin: data.IsAdmin,
CanLogin: data.CanLogin,
CanConnect: data.CanConnect,
CanWatch: data.CanWatch,
CanHost: data.CanHost,
CanAccessClipboard: data.CanAccessClipboard,
})
if err != nil {
utils.HttpInternalServerError(w, err) utils.HttpInternalServerError(w, err)
return return
} }

View File

@ -1,5 +1,9 @@
package message package message
import (
"demodesk/neko/internal/types"
)
type Message struct { type Message struct {
Event string `json:"event"` Event string `json:"event"`
Payload interface{} `json:"payload"` // TODO: New. Payload interface{} `json:"payload"` // TODO: New.
@ -55,29 +59,22 @@ type MemberID struct {
} }
type MemberProfile struct { type MemberProfile struct {
Event string `json:"event,omitempty"` Event string `json:"event,omitempty"`
ID string `json:"id,omitempty"` ID string `json:"id"`
Name string `json:"name"` *types.MemberProfile
IsAdmin bool `json:"is_admin"`
CanLogin bool `json:"can_login"`
CanConnect bool `json:"can_connect"`
CanWatch bool `json:"can_watch"`
CanHost bool `json:"can_host"`
CanAccessClipboard bool `json:"can_access_clipboard"`
} }
type MemberState struct { type MemberState struct {
Event string `json:"event,omitempty"` Event string `json:"event,omitempty"`
ID string `json:"id,omitempty"` ID string `json:"id"`
IsConnected bool `json:"is_connected"` *types.MemberState
IsWatching bool `json:"is_watching"`
} }
type MemberData struct { type MemberData struct {
Event string `json:"event,omitempty"` Event string `json:"event,omitempty"`
ID string `json:"id"` ID string `json:"id"`
Profile MemberProfile `json:"profile"` Profile types.MemberProfile `json:"profile"`
State MemberState `json:"state"` State types.MemberState `json:"state"`
} }
///////////////////////////// /////////////////////////////

View File

@ -3,15 +3,19 @@ package types
import "net/http" import "net/http"
type MemberProfile struct { type MemberProfile struct {
Secret string Secret string `json:"secret,omitempty"`
Name string Name string `json:"name"`
IsAdmin bool `json:"is_admin"`
CanLogin bool `json:"can_login"`
CanConnect bool `json:"can_connect"`
CanWatch bool `json:"can_watch"`
CanHost bool `json:"can_host"`
CanAccessClipboard bool `json:"can_access_clipboard"`
}
IsAdmin bool type MemberState struct {
CanLogin bool IsConnected bool `json:"is_connected"`
CanConnect bool IsWatching bool `json:"is_watching"`
CanWatch bool
CanHost bool
CanAccessClipboard bool
} }
type MembersDatabase interface { type MembersDatabase interface {

View File

@ -7,12 +7,12 @@ import (
) )
func (h *MessageHandlerCtx) SessionCreated(session types.Session) error { func (h *MessageHandlerCtx) SessionCreated(session types.Session) error {
// TODO: Join structs?
h.sessions.Broadcast( h.sessions.Broadcast(
message.MemberData{ message.MemberData{
Event: event.MEMBER_CREATED, Event: event.MEMBER_CREATED,
ID: session.ID(), ID: session.ID(),
Profile: message.MemberProfile{ // TODO: Get whole profile from session.
Profile: types.MemberProfile{
Name: session.Name(), Name: session.Name(),
IsAdmin: session.IsAdmin(), IsAdmin: session.IsAdmin(),
CanLogin: session.CanLogin(), CanLogin: session.CanLogin(),
@ -21,7 +21,8 @@ func (h *MessageHandlerCtx) SessionCreated(session types.Session) error {
CanHost: session.CanHost(), CanHost: session.CanHost(),
CanAccessClipboard: session.CanAccessClipboard(), CanAccessClipboard: session.CanAccessClipboard(),
}, },
State: message.MemberState{ // TODO: Get whole state from session.
State: types.MemberState{
IsConnected: session.IsConnected(), IsConnected: session.IsConnected(),
IsWatching: session.IsWatching(), IsWatching: session.IsWatching(),
}, },
@ -81,31 +82,35 @@ func (h *MessageHandlerCtx) SessionDisconnected(session types.Session) error {
} }
func (h *MessageHandlerCtx) SessionProfileChanged(session types.Session) error { func (h *MessageHandlerCtx) SessionProfileChanged(session types.Session) error {
// TODO: Join structs?
h.sessions.Broadcast( h.sessions.Broadcast(
message.MemberProfile{ message.MemberProfile{
Event: event.MEMBER_PROFILE, Event: event.MEMBER_PROFILE,
ID: session.ID(), ID: session.ID(),
Name: session.Name(), // TODO: Get whole profile from session.
IsAdmin: session.IsAdmin(), MemberProfile: &types.MemberProfile{
CanLogin: session.CanLogin(), Name: session.Name(),
CanConnect: session.CanConnect(), IsAdmin: session.IsAdmin(),
CanWatch: session.CanWatch(), CanLogin: session.CanLogin(),
CanHost: session.CanHost(), CanConnect: session.CanConnect(),
CanAccessClipboard: session.CanAccessClipboard(), CanWatch: session.CanWatch(),
CanHost: session.CanHost(),
CanAccessClipboard: session.CanAccessClipboard(),
},
}, nil) }, nil)
return nil return nil
} }
func (h *MessageHandlerCtx) SessionStateChanged(session types.Session) error { func (h *MessageHandlerCtx) SessionStateChanged(session types.Session) error {
// TODO: Join structs?
h.sessions.Broadcast( h.sessions.Broadcast(
message.MemberState{ message.MemberState{
Event: event.MEMBER_STATE, Event: event.MEMBER_STATE,
ID: session.ID(), ID: session.ID(),
IsConnected: session.IsConnected(), // TODO: Get whole state from session.
IsWatching: session.IsWatching(), MemberState: &types.MemberState{
IsConnected: session.IsConnected(),
IsWatching: session.IsWatching(),
},
}, nil) }, nil)
return nil return nil

View File

@ -25,10 +25,10 @@ func (h *MessageHandlerCtx) systemInit(session types.Session) error {
members := map[string]message.MemberData{} members := map[string]message.MemberData{}
for _, session := range h.sessions.Members() { for _, session := range h.sessions.Members() {
// TODO: Join structs?
members[session.ID()] = message.MemberData{ members[session.ID()] = message.MemberData{
ID: session.ID(), ID: session.ID(),
Profile: message.MemberProfile{ // TODO: Get whole profile from session.
Profile: types.MemberProfile{
Name: session.Name(), Name: session.Name(),
IsAdmin: session.IsAdmin(), IsAdmin: session.IsAdmin(),
CanLogin: session.CanLogin(), CanLogin: session.CanLogin(),
@ -37,7 +37,8 @@ func (h *MessageHandlerCtx) systemInit(session types.Session) error {
CanHost: session.CanHost(), CanHost: session.CanHost(),
CanAccessClipboard: session.CanAccessClipboard(), CanAccessClipboard: session.CanAccessClipboard(),
}, },
State: message.MemberState{ // TODO: Get whole state from session.
State: types.MemberState{
IsConnected: session.IsConnected(), IsConnected: session.IsConnected(),
IsWatching: session.IsWatching(), IsWatching: session.IsWatching(),
}, },