From 0033e3e37b12cb5d951d21492500d66a6abc472b Mon Sep 17 00:00:00 2001 From: Joram Wilander Date: Tue, 15 Aug 2017 16:25:36 -0400 Subject: PLT-7408 Move webhook handling into api4 package to fix EnableAPIv3 config setting (#7219) * Move webhook handling into api4 package to fix EnableAPIv3 config setting * Fix unit test --- api/webhook.go | 52 ---------------------------------------------------- api4/webhook.go | 51 +++++++++++++++++++++++++++++++++++++++++++++++++++ web/web_test.go | 2 ++ 3 files changed, 53 insertions(+), 52 deletions(-) diff --git a/api/webhook.go b/api/webhook.go index c17b5bc56..204df6b31 100644 --- a/api/webhook.go +++ b/api/webhook.go @@ -4,12 +4,9 @@ package api import ( - "io" "net/http" - "strings" l4g "github.com/alecthomas/log4go" - "github.com/gorilla/mux" "github.com/mattermost/platform/app" "github.com/mattermost/platform/model" "github.com/mattermost/platform/utils" @@ -28,12 +25,6 @@ func InitWebhook() { BaseRoutes.Hooks.Handle("/outgoing/regen_token", ApiUserRequired(regenOutgoingHookToken)).Methods("POST") BaseRoutes.Hooks.Handle("/outgoing/delete", ApiUserRequired(deleteOutgoingHook)).Methods("POST") BaseRoutes.Hooks.Handle("/outgoing/list", ApiUserRequired(getOutgoingHooks)).Methods("GET") - - BaseRoutes.Hooks.Handle("/{id:[A-Za-z0-9]+}", ApiAppHandler(incomingWebhook)).Methods("POST") - - // Old route. Remove eventually. - mr := app.Srv.Router - mr.Handle("/hooks/{id:[A-Za-z0-9]+}", ApiAppHandler(incomingWebhook)).Methods("POST") } func createIncomingHook(c *Context, w http.ResponseWriter, r *http.Request) { @@ -340,46 +331,3 @@ func regenOutgoingHookToken(c *Context, w http.ResponseWriter, r *http.Request) w.Write([]byte(rhook.ToJson())) } } - -func incomingWebhook(c *Context, w http.ResponseWriter, r *http.Request) { - params := mux.Vars(r) - id := params["id"] - - r.ParseForm() - - var payload io.Reader - contentType := r.Header.Get("Content-Type") - if strings.Split(contentType, "; ")[0] == "application/x-www-form-urlencoded" { - payload = strings.NewReader(r.FormValue("payload")) - } else { - payload = r.Body - } - - if utils.Cfg.LogSettings.EnableWebhookDebugging { - var err error - payload, err = utils.DebugReader( - payload, - utils.T("api.webhook.incoming.debug"), - ) - if err != nil { - c.Err = model.NewLocAppError( - "incomingWebhook", - "api.webhook.incoming.debug.error", - nil, - err.Error(), - ) - return - } - } - - parsedRequest := model.IncomingWebhookRequestFromJson(payload) - - err := app.HandleIncomingWebhook(id, parsedRequest) - if err != nil { - c.Err = err - return - } - - w.Header().Set("Content-Type", "text/plain") - w.Write([]byte("ok")) -} diff --git a/api4/webhook.go b/api4/webhook.go index 668636932..ef68fd9fe 100644 --- a/api4/webhook.go +++ b/api4/webhook.go @@ -4,9 +4,12 @@ package api4 import ( + "io" "net/http" + "strings" l4g "github.com/alecthomas/log4go" + "github.com/gorilla/mux" "github.com/mattermost/platform/app" "github.com/mattermost/platform/model" "github.com/mattermost/platform/utils" @@ -27,6 +30,11 @@ func InitWebhook() { BaseRoutes.OutgoingHook.Handle("", ApiSessionRequired(updateOutgoingHook)).Methods("PUT") BaseRoutes.OutgoingHook.Handle("", ApiSessionRequired(deleteOutgoingHook)).Methods("DELETE") BaseRoutes.OutgoingHook.Handle("/regen_token", ApiSessionRequired(regenOutgoingHookToken)).Methods("POST") + + BaseRoutes.Root.Handle("/hooks/{id:[A-Za-z0-9]+}", ApiHandler(incomingWebhook)).Methods("POST") + + // Old endpoint for backwards compatibility + BaseRoutes.Root.Handle("/api/v3/teams/{team_id:[A-Za-z0-9]+}/hooks/{id:[A-Za-z0-9]+}", ApiHandler(incomingWebhook)).Methods("POST") } func createIncomingHook(c *Context, w http.ResponseWriter, r *http.Request) { @@ -435,3 +443,46 @@ func deleteOutgoingHook(c *Context, w http.ResponseWriter, r *http.Request) { c.LogAudit("success") ReturnStatusOK(w) } + +func incomingWebhook(c *Context, w http.ResponseWriter, r *http.Request) { + params := mux.Vars(r) + id := params["id"] + + r.ParseForm() + + var payload io.Reader + contentType := r.Header.Get("Content-Type") + if strings.Split(contentType, "; ")[0] == "application/x-www-form-urlencoded" { + payload = strings.NewReader(r.FormValue("payload")) + } else { + payload = r.Body + } + + if utils.Cfg.LogSettings.EnableWebhookDebugging { + var err error + payload, err = utils.DebugReader( + payload, + utils.T("api.webhook.incoming.debug"), + ) + if err != nil { + c.Err = model.NewLocAppError( + "incomingWebhook", + "api.webhook.incoming.debug.error", + nil, + err.Error(), + ) + return + } + } + + parsedRequest := model.IncomingWebhookRequestFromJson(payload) + + err := app.HandleIncomingWebhook(id, parsedRequest) + if err != nil { + c.Err = err + return + } + + w.Header().Set("Content-Type", "text/plain") + w.Write([]byte("ok")) +} diff --git a/web/web_test.go b/web/web_test.go index c932b25d2..7881b8eed 100644 --- a/web/web_test.go +++ b/web/web_test.go @@ -8,6 +8,7 @@ import ( "time" "github.com/mattermost/platform/api" + "github.com/mattermost/platform/api4" "github.com/mattermost/platform/app" "github.com/mattermost/platform/model" "github.com/mattermost/platform/store" @@ -26,6 +27,7 @@ func Setup() { app.InitStores() api.InitRouter() app.StartServer() + api4.InitApi(false) api.InitApi() InitWeb() URL = "http://localhost" + utils.Cfg.ServiceSettings.ListenAddress -- cgit v1.2.3-1-g7c22