2019-11-29 06:59:40 -05:00
|
|
|
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
|
|
|
// See LICENSE.txt for license information.
|
2016-07-12 09:36:27 -04:00
|
|
|
|
2017-03-28 04:58:19 -04:00
|
|
|
package wsapi
|
2016-07-12 09:36:27 -04:00
|
|
|
|
|
|
|
|
import (
|
2017-09-06 18:12:54 -04:00
|
|
|
"net/http"
|
|
|
|
|
|
2023-06-11 01:24:35 -04:00
|
|
|
"github.com/mattermost/mattermost/server/public/model"
|
|
|
|
|
"github.com/mattermost/mattermost/server/public/shared/i18n"
|
|
|
|
|
"github.com/mattermost/mattermost/server/public/shared/mlog"
|
|
|
|
|
"github.com/mattermost/mattermost/server/v8/channels/app"
|
|
|
|
|
"github.com/mattermost/mattermost/server/v8/channels/app/platform"
|
2016-07-12 09:36:27 -04:00
|
|
|
)
|
|
|
|
|
|
2022-07-05 02:46:50 -04:00
|
|
|
func (api *API) APIWebSocketHandler(wh func(*model.WebSocketRequest) (map[string]any, *model.AppError)) webSocketHandler {
|
2017-09-27 12:52:34 -04:00
|
|
|
return webSocketHandler{api.App, wh}
|
2016-07-12 09:36:27 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
type webSocketHandler struct {
|
2017-09-27 12:52:34 -04:00
|
|
|
app *app.App
|
2022-07-05 02:46:50 -04:00
|
|
|
handlerFunc func(*model.WebSocketRequest) (map[string]any, *model.AppError)
|
2016-07-12 09:36:27 -04:00
|
|
|
}
|
|
|
|
|
|
2022-10-06 04:04:21 -04:00
|
|
|
func (wh webSocketHandler) ServeWebSocket(conn *platform.WebConn, r *model.WebSocketRequest) {
|
2025-04-10 16:24:23 -04:00
|
|
|
// Don't log ping requests to reduce log noise
|
|
|
|
|
if r.Action != "ping" {
|
|
|
|
|
mlog.Debug("Websocket request", mlog.String("action", r.Action))
|
|
|
|
|
}
|
2016-07-12 09:36:27 -04:00
|
|
|
|
2022-10-06 04:04:21 -04:00
|
|
|
hub := wh.app.Srv().Platform().GetHubForUserId(conn.UserId)
|
2020-04-23 03:46:18 -04:00
|
|
|
if hub == nil {
|
|
|
|
|
return
|
|
|
|
|
}
|
2017-09-27 12:52:34 -04:00
|
|
|
session, sessionErr := wh.app.GetSession(conn.GetSessionToken())
|
2021-01-27 13:58:24 -05:00
|
|
|
|
2017-01-13 13:53:37 -05:00
|
|
|
if sessionErr != nil {
|
2019-12-16 07:57:21 -05:00
|
|
|
mlog.Error(
|
|
|
|
|
"websocket session error",
|
|
|
|
|
mlog.String("action", r.Action),
|
2023-11-23 04:30:08 -05:00
|
|
|
mlog.Int("seq", r.Seq),
|
2019-12-16 07:57:21 -05:00
|
|
|
mlog.String("user_id", conn.UserId),
|
2021-02-26 02:12:49 -05:00
|
|
|
mlog.String("error_message", sessionErr.SystemMessage(i18n.T)),
|
2019-12-16 07:57:21 -05:00
|
|
|
mlog.Err(sessionErr),
|
|
|
|
|
)
|
2024-03-20 13:30:14 -04:00
|
|
|
sessionErr.WipeDetailed()
|
2017-01-13 13:53:37 -05:00
|
|
|
errResp := model.NewWebSocketError(r.Seq, sessionErr)
|
2020-04-23 03:46:18 -04:00
|
|
|
hub.SendMessage(conn, errResp)
|
2017-01-13 13:53:37 -05:00
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
r.Session = *session
|
2016-07-12 09:36:27 -04:00
|
|
|
r.T = conn.T
|
|
|
|
|
r.Locale = conn.Locale
|
|
|
|
|
|
2022-07-05 02:46:50 -04:00
|
|
|
var data map[string]any
|
2016-07-18 11:10:03 -04:00
|
|
|
var err *model.AppError
|
2016-07-12 09:36:27 -04:00
|
|
|
|
2016-07-18 11:10:03 -04:00
|
|
|
if data, err = wh.handlerFunc(r); err != nil {
|
2019-12-16 07:57:21 -05:00
|
|
|
mlog.Error(
|
|
|
|
|
"websocket request handling error",
|
|
|
|
|
mlog.String("action", r.Action),
|
2023-11-23 04:30:08 -05:00
|
|
|
mlog.Int("seq", r.Seq),
|
2019-12-16 07:57:21 -05:00
|
|
|
mlog.String("user_id", conn.UserId),
|
2021-02-26 02:12:49 -05:00
|
|
|
mlog.String("error_message", err.SystemMessage(i18n.T)),
|
2019-12-16 07:57:21 -05:00
|
|
|
mlog.Err(err),
|
|
|
|
|
)
|
2024-03-20 13:30:14 -04:00
|
|
|
err.WipeDetailed()
|
2016-10-19 14:49:25 -04:00
|
|
|
errResp := model.NewWebSocketError(r.Seq, err)
|
2020-04-23 03:46:18 -04:00
|
|
|
hub.SendMessage(conn, errResp)
|
2016-07-12 09:36:27 -04:00
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
2021-07-12 14:05:36 -04:00
|
|
|
resp := model.NewWebSocketResponse(model.StatusOk, r.Seq, data)
|
2020-04-23 03:46:18 -04:00
|
|
|
hub.SendMessage(conn, resp)
|
2016-07-12 09:36:27 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func NewInvalidWebSocketParamError(action string, name string) *model.AppError {
|
2022-07-05 02:46:50 -04:00
|
|
|
return model.NewAppError("websocket: "+action, "api.websocket_handler.invalid_param.app_error", map[string]any{"Name": name}, "", http.StatusBadRequest)
|
2016-07-12 09:36:27 -04:00
|
|
|
}
|
2019-11-27 20:41:09 -05:00
|
|
|
|
|
|
|
|
func NewServerBusyWebSocketError(action string) *model.AppError {
|
|
|
|
|
return model.NewAppError("websocket: "+action, "api.websocket_handler.server_busy.app_error", nil, "", http.StatusServiceUnavailable)
|
|
|
|
|
}
|