// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved. // See LICENSE.txt for license information. package wsapi import ( "net/http" "github.com/mattermost/mattermost-server/v5/app" "github.com/mattermost/mattermost-server/v5/mlog" "github.com/mattermost/mattermost-server/v5/model" "github.com/mattermost/mattermost-server/v5/utils" ) func (api *API) ApiWebSocketHandler(wh func(*model.WebSocketRequest) (map[string]interface{}, *model.AppError)) webSocketHandler { return webSocketHandler{api.App, wh} } type webSocketHandler struct { app *app.App handlerFunc func(*model.WebSocketRequest) (map[string]interface{}, *model.AppError) } func (wh webSocketHandler) ServeWebSocket(conn *app.WebConn, r *model.WebSocketRequest) { mlog.Debug("Websocket request", mlog.String("action", r.Action)) session, sessionErr := wh.app.GetSession(conn.GetSessionToken()) if sessionErr != nil { mlog.Error( "websocket session error", mlog.String("action", r.Action), mlog.Int64("seq", r.Seq), mlog.String("user_id", conn.UserId), mlog.String("error_message", sessionErr.SystemMessage(utils.T)), mlog.Err(sessionErr), ) sessionErr.DetailedError = "" errResp := model.NewWebSocketError(r.Seq, sessionErr) conn.Send <- errResp return } r.Session = *session r.T = conn.T r.Locale = conn.Locale var data map[string]interface{} var err *model.AppError if data, err = wh.handlerFunc(r); err != nil { mlog.Error( "websocket request handling error", mlog.String("action", r.Action), mlog.Int64("seq", r.Seq), mlog.String("user_id", conn.UserId), mlog.String("error_message", err.SystemMessage(utils.T)), mlog.Err(err), ) err.DetailedError = "" errResp := model.NewWebSocketError(r.Seq, err) conn.Send <- errResp return } resp := model.NewWebSocketResponse(model.STATUS_OK, r.Seq, data) conn.Send <- resp } func NewInvalidWebSocketParamError(action string, name string) *model.AppError { return model.NewAppError("websocket: "+action, "api.websocket_handler.invalid_param.app_error", map[string]interface{}{"Name": name}, "", http.StatusBadRequest) } func NewServerBusyWebSocketError(action string) *model.AppError { return model.NewAppError("websocket: "+action, "api.websocket_handler.server_busy.app_error", nil, "", http.StatusServiceUnavailable) }