summaryrefslogtreecommitdiffstats
path: root/api4/webhook.go
diff options
context:
space:
mode:
authorCarlos Tadeu Panato Junior <ctadeu@gmail.com>2018-02-16 17:29:12 +0100
committerChristopher Speller <crspeller@gmail.com>2018-02-16 08:29:12 -0800
commit8c3a7b75de5be45a64dc06c4e998817e7b52d6bc (patch)
tree0fc63555836970e00eeedd7df648f58fb1a6199f /api4/webhook.go
parent6d8f122a5160f6d9e4c51579f2429dfaa62c7271 (diff)
downloadchat-8c3a7b75de5be45a64dc06c4e998817e7b52d6bc.tar.gz
chat-8c3a7b75de5be45a64dc06c4e998817e7b52d6bc.tar.bz2
chat-8c3a7b75de5be45a64dc06c4e998817e7b52d6bc.zip
[PLT-539] Update incoming webhooks to accept multipart/form-data content (#7873)
Diffstat (limited to 'api4/webhook.go')
-rw-r--r--api4/webhook.go56
1 files changed, 38 insertions, 18 deletions
diff --git a/api4/webhook.go b/api4/webhook.go
index 90e32a891..e19f14704 100644
--- a/api4/webhook.go
+++ b/api4/webhook.go
@@ -8,7 +8,10 @@ import (
"net/http"
"strings"
+ l4g "github.com/alecthomas/log4go"
+
"github.com/gorilla/mux"
+ "github.com/gorilla/schema"
"github.com/mattermost/mattermost-server/model"
"github.com/mattermost/mattermost-server/utils"
)
@@ -447,34 +450,40 @@ func incomingWebhook(c *Context, w http.ResponseWriter, r *http.Request) {
r.ParseForm()
- var payload io.Reader
+ var err *model.AppError
+ incomingWebhookPayload := &model.IncomingWebhookRequest{}
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
- }
+ payload := strings.NewReader(r.FormValue("payload"))
- if c.App.Config().LogSettings.EnableWebhookDebugging {
- var err error
- payload, err = utils.InfoReader(
- payload,
- utils.T("api.webhook.incoming.debug"),
- )
+ incomingWebhookPayload, err = decodePayload(payload)
if err != nil {
- c.Err = model.NewAppError("incomingWebhook", "api.webhook.incoming.debug.error", nil, err.Error(), http.StatusInternalServerError)
+ c.Err = err
return
}
- }
+ } else if strings.HasPrefix(contentType, "multipart/form-data") {
+ r.ParseMultipartForm(0)
- parsedRequest, decodeError := model.IncomingWebhookRequestFromJson(payload)
+ decoder := schema.NewDecoder()
+ err := decoder.Decode(incomingWebhookPayload, r.PostForm)
- if decodeError != nil {
- c.Err = decodeError
- return
+ if err != nil {
+ c.Err = model.NewAppError("incomingWebhook", "api.webhook.incoming.error", nil, err.Error(), http.StatusBadRequest)
+ return
+ }
+ } else {
+ incomingWebhookPayload, err = decodePayload(r.Body)
+ if err != nil {
+ c.Err = err
+ return
+ }
+ }
+
+ if c.App.Config().LogSettings.EnableWebhookDebugging {
+ l4g.Debug(utils.T("api.webhook.incoming.debug"), incomingWebhookPayload.ToJson())
}
- err := c.App.HandleIncomingWebhook(id, parsedRequest)
+ err = c.App.HandleIncomingWebhook(id, incomingWebhookPayload)
if err != nil {
c.Err = err
return
@@ -499,3 +508,14 @@ func commandWebhook(c *Context, w http.ResponseWriter, r *http.Request) {
w.Header().Set("Content-Type", "text/plain")
w.Write([]byte("ok"))
}
+
+func decodePayload(payload io.Reader) (*model.IncomingWebhookRequest, *model.AppError) {
+ decodeError := &model.AppError{}
+ incomingWebhookPayload, decodeError := model.IncomingWebhookRequestFromJson(payload)
+
+ if decodeError != nil {
+ return nil, decodeError
+ }
+
+ return incomingWebhookPayload, nil
+}