summaryrefslogtreecommitdiffstats
path: root/api4/webhook.go
diff options
context:
space:
mode:
authorChris <ccbrown112@gmail.com>2017-08-17 17:07:47 -0500
committerCorey Hulen <corey@hulen.com>2017-08-17 15:07:47 -0700
commit2c895ee66eed626721135acfcc48254c6e3f3b29 (patch)
treec5859428e32fe72454ac388aef717cb46a7f0d0d /api4/webhook.go
parent4d243e9256f86517fc55529372f729568582c03c (diff)
downloadchat-2c895ee66eed626721135acfcc48254c6e3f3b29.tar.gz
chat-2c895ee66eed626721135acfcc48254c6e3f3b29.tar.bz2
chat-2c895ee66eed626721135acfcc48254c6e3f3b29.zip
webhook merge fix (#7250)
Diffstat (limited to 'api4/webhook.go')
-rw-r--r--api4/webhook.go17
1 files changed, 17 insertions, 0 deletions
diff --git a/api4/webhook.go b/api4/webhook.go
index ef68fd9fe..e34cc4137 100644
--- a/api4/webhook.go
+++ b/api4/webhook.go
@@ -31,6 +31,7 @@ func InitWebhook() {
BaseRoutes.OutgoingHook.Handle("", ApiSessionRequired(deleteOutgoingHook)).Methods("DELETE")
BaseRoutes.OutgoingHook.Handle("/regen_token", ApiSessionRequired(regenOutgoingHookToken)).Methods("POST")
+ BaseRoutes.Root.Handle("/hooks/commands/{id:[A-Za-z0-9]+}", ApiHandler(commandWebhook)).Methods("POST")
BaseRoutes.Root.Handle("/hooks/{id:[A-Za-z0-9]+}", ApiHandler(incomingWebhook)).Methods("POST")
// Old endpoint for backwards compatibility
@@ -486,3 +487,19 @@ func incomingWebhook(c *Context, w http.ResponseWriter, r *http.Request) {
w.Header().Set("Content-Type", "text/plain")
w.Write([]byte("ok"))
}
+
+func commandWebhook(c *Context, w http.ResponseWriter, r *http.Request) {
+ params := mux.Vars(r)
+ id := params["id"]
+
+ response := model.CommandResponseFromHTTPBody(r.Header.Get("Content-Type"), r.Body)
+
+ err := app.HandleCommandWebhook(id, response)
+ if err != nil {
+ c.Err = err
+ return
+ }
+
+ w.Header().Set("Content-Type", "text/plain")
+ w.Write([]byte("ok"))
+}