mirror of
https://github.com/m1k1o/neko.git
synced 2024-07-24 14:40:50 +12:00
file transfer permission state management
This commit is contained in:
@ -35,12 +35,9 @@ const (
|
||||
)
|
||||
|
||||
const (
|
||||
FILETRANSFER_ENABLE = "filetransfer/enable"
|
||||
FILETRANSFER_DISABLE = "filetransfer/disable"
|
||||
FILETRANSFER_UNPRIVENABLE = "filetransfer/unprivenable"
|
||||
FILETRANSFER_UNPRIVDISABLE = "filetransfer/unprivdisable"
|
||||
FILETRANSFER_LIST = "filetransfer/list"
|
||||
FILETRANSFER_REFRESH = "filetransfer/refresh"
|
||||
FILETRANSFER_STATUS = "filetransfer/status"
|
||||
FILETRANSFER_LIST = "filetransfer/list"
|
||||
FILETRANSFER_REFRESH = "filetransfer/refresh"
|
||||
)
|
||||
|
||||
const (
|
||||
|
@ -108,7 +108,12 @@ type EmoteSend struct {
|
||||
|
||||
type FileTransferTarget struct {
|
||||
Event string `json:"event"`
|
||||
ID string `json:"id"`
|
||||
}
|
||||
|
||||
type FileTransferStatus struct {
|
||||
Event string `json:"event"`
|
||||
Admin bool `json:"admin"`
|
||||
Unpriv bool `json:"unpriv"`
|
||||
}
|
||||
|
||||
type FileList struct {
|
||||
|
@ -8,6 +8,36 @@ import (
|
||||
"m1k1o/neko/internal/utils"
|
||||
)
|
||||
|
||||
func (h *MessageHandler) setFileTransferStatus(session types.Session, payload *message.FileTransferStatus) error {
|
||||
if !session.Admin() {
|
||||
return errors.New(session.Member().Name + " tried to toggle file transfer but they're not admin")
|
||||
}
|
||||
h.state.SetFileTransferState(payload.Admin, payload.Unpriv)
|
||||
err := h.sessions.Broadcast(message.FileTransferStatus{
|
||||
Event: event.FILETRANSFER_STATUS,
|
||||
Admin: payload.Admin,
|
||||
Unpriv: payload.Admin && payload.Unpriv,
|
||||
}, nil)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
files, err := utils.ListFiles(h.state.FileTransferPath())
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
msg := message.FileList{
|
||||
Event: event.FILETRANSFER_LIST,
|
||||
Cwd: h.state.FileTransferPath(),
|
||||
Files: *files,
|
||||
}
|
||||
if payload.Unpriv {
|
||||
return h.sessions.Broadcast(msg, nil)
|
||||
} else {
|
||||
return h.sessions.AdminBroadcast(msg, nil)
|
||||
}
|
||||
}
|
||||
|
||||
func (h *MessageHandler) refresh(session types.Session) error {
|
||||
if !(h.state.FileTransferEnabled() && session.Admin() || h.state.UnprivFileTransferEnabled()) {
|
||||
return errors.New(session.Member().Name + " tried to refresh file list when they can't")
|
||||
|
@ -127,6 +127,12 @@ func (h *MessageHandler) Message(id string, raw []byte) error {
|
||||
}), "%s failed", header.Event)
|
||||
|
||||
// File Transfer Events
|
||||
case event.FILETRANSFER_STATUS:
|
||||
payload := &message.FileTransferStatus{}
|
||||
return errors.Wrapf(
|
||||
utils.Unmarshal(payload, raw, func() error {
|
||||
return h.setFileTransferStatus(session, payload)
|
||||
}), "%s failed", header.Event)
|
||||
case event.FILETRANSFER_REFRESH:
|
||||
return errors.Wrapf(h.refresh(session), "%s failed", header.Event)
|
||||
|
||||
|
@ -78,6 +78,11 @@ func (s *State) UnprivFileTransferEnabled() bool {
|
||||
return s.fileTransferUnprivEnabled
|
||||
}
|
||||
|
||||
func (s *State) SetFileTransferState(admin bool, unpriv bool) {
|
||||
s.fileTransferEnabled = admin
|
||||
s.fileTransferUnprivEnabled = unpriv
|
||||
}
|
||||
|
||||
func (s *State) FileTransferPath() string {
|
||||
return s.fileTransferPath
|
||||
}
|
||||
|
@ -135,7 +135,19 @@ func (ws *WebSocketHandler) Start() {
|
||||
}
|
||||
|
||||
// send file list if necessary
|
||||
if session.Admin() && ws.conf.FileTransfer || ws.conf.FileTransfer && ws.conf.UnprivFileTransfer {
|
||||
if session.Admin() && ws.state.FileTransferEnabled() ||
|
||||
ws.state.FileTransferEnabled() && ws.state.UnprivFileTransferEnabled() {
|
||||
err := session.Send(
|
||||
message.FileTransferStatus{
|
||||
Event: event.FILETRANSFER_STATUS,
|
||||
Admin: ws.state.FileTransferEnabled(),
|
||||
Unpriv: ws.state.UnprivFileTransferEnabled(),
|
||||
})
|
||||
if err != nil {
|
||||
ws.logger.Warn().Err(err).Msgf("file transfer status event has failed")
|
||||
return
|
||||
}
|
||||
|
||||
files, err := utils.ListFiles(ws.conf.FileTransferPath)
|
||||
if err == nil {
|
||||
if err := session.Send(
|
||||
@ -214,27 +226,25 @@ func (ws *WebSocketHandler) Start() {
|
||||
})
|
||||
|
||||
// watch for file changes
|
||||
if ws.conf.FileTransfer {
|
||||
watcher, err := fsnotify.NewWatcher()
|
||||
if err != nil {
|
||||
ws.logger.Err(err).Msg("unable to start file transfer dir watcher")
|
||||
return
|
||||
}
|
||||
watcher, err := fsnotify.NewWatcher()
|
||||
if err != nil {
|
||||
ws.logger.Err(err).Msg("unable to start file transfer dir watcher")
|
||||
return
|
||||
}
|
||||
|
||||
go func() {
|
||||
for {
|
||||
select {
|
||||
case <-watcher.Events:
|
||||
ws.sendFileTransferUpdate()
|
||||
case err := <-watcher.Errors:
|
||||
ws.logger.Err(err).Msg("error in file transfer dir watcher")
|
||||
}
|
||||
go func() {
|
||||
for {
|
||||
select {
|
||||
case <-watcher.Events:
|
||||
ws.sendFileTransferUpdate()
|
||||
case err := <-watcher.Errors:
|
||||
ws.logger.Err(err).Msg("error in file transfer dir watcher")
|
||||
}
|
||||
}()
|
||||
|
||||
if err := watcher.Add(ws.conf.FileTransferPath); err != nil {
|
||||
ws.logger.Err(err).Msg("unable to add file transfer path to watcher")
|
||||
}
|
||||
}()
|
||||
|
||||
if err := watcher.Add(ws.conf.FileTransferPath); err != nil {
|
||||
ws.logger.Err(err).Msg("unable to add file transfer path to watcher")
|
||||
}
|
||||
}
|
||||
|
||||
@ -364,11 +374,11 @@ func (ws *WebSocketHandler) IsAdmin(password string) (bool, error) {
|
||||
}
|
||||
|
||||
func (ws *WebSocketHandler) CanTransferFiles(password string) (bool, error) {
|
||||
if !ws.conf.FileTransfer {
|
||||
if !ws.state.FileTransferEnabled() {
|
||||
return false, nil
|
||||
}
|
||||
|
||||
if !ws.conf.UnprivFileTransfer {
|
||||
if !ws.state.UnprivFileTransferEnabled() {
|
||||
return ws.IsAdmin(password)
|
||||
}
|
||||
|
||||
@ -380,6 +390,10 @@ func (ws *WebSocketHandler) MakeFilePath(filename string) string {
|
||||
}
|
||||
|
||||
func (ws *WebSocketHandler) sendFileTransferUpdate() {
|
||||
if !ws.state.FileTransferEnabled() {
|
||||
return
|
||||
}
|
||||
|
||||
files, err := utils.ListFiles(ws.conf.FileTransferPath)
|
||||
if err != nil {
|
||||
ws.logger.Err(err).Msg("unable to ls file transfer path")
|
||||
@ -393,7 +407,7 @@ func (ws *WebSocketHandler) sendFileTransferUpdate() {
|
||||
}
|
||||
|
||||
var broadcastErr error
|
||||
if ws.conf.UnprivFileTransfer {
|
||||
if ws.state.UnprivFileTransferEnabled() {
|
||||
broadcastErr = ws.sessions.Broadcast(message, nil)
|
||||
} else {
|
||||
broadcastErr = ws.sessions.AdminBroadcast(message, nil)
|
||||
|
Reference in New Issue
Block a user