summaryrefslogtreecommitdiffstats
path: root/app/webhook.go
diff options
context:
space:
mode:
authorChris <ccbrown112@gmail.com>2017-08-16 07:17:57 -0500
committerJoram Wilander <jwawilander@gmail.com>2017-08-16 08:17:57 -0400
commitb122381e87577ddfc12b792a3de9121ea830d50e (patch)
tree1487a6a97aa0a928db230b207463e721e56858c9 /app/webhook.go
parent5cd45c939406e5af84b0d9a6967683b77100303c (diff)
downloadchat-b122381e87577ddfc12b792a3de9121ea830d50e.tar.gz
chat-b122381e87577ddfc12b792a3de9121ea830d50e.tar.bz2
chat-b122381e87577ddfc12b792a3de9121ea830d50e.zip
PLT-1649: add response_url support for custom slash commands (#6739)
* add response_url support for custom slash commands * pr suggestions * pr update / suggestion * test fix
Diffstat (limited to 'app/webhook.go')
-rw-r--r--app/webhook.go51
1 files changed, 51 insertions, 0 deletions
diff --git a/app/webhook.go b/app/webhook.go
index 4606c207f..f84086d94 100644
--- a/app/webhook.go
+++ b/app/webhook.go
@@ -533,3 +533,54 @@ func HandleIncomingWebhook(hookId string, req *model.IncomingWebhookRequest) *mo
return nil
}
+
+func CreateCommandWebhook(commandId string, args *model.CommandArgs) (*model.CommandWebhook, *model.AppError) {
+ hook := &model.CommandWebhook{
+ CommandId: commandId,
+ UserId: args.UserId,
+ ChannelId: args.ChannelId,
+ RootId: args.RootId,
+ ParentId: args.ParentId,
+ }
+
+ if result := <-Srv.Store.CommandWebhook().Save(hook); result.Err != nil {
+ return nil, result.Err
+ } else {
+ return result.Data.(*model.CommandWebhook), nil
+ }
+}
+
+func HandleCommandWebhook(hookId string, response *model.CommandResponse) *model.AppError {
+ if response == nil {
+ return model.NewAppError("HandleCommandWebhook", "web.command_webhook.parse.app_error", nil, "", http.StatusBadRequest)
+ }
+
+ var hook *model.CommandWebhook
+ if result := <-Srv.Store.CommandWebhook().Get(hookId); result.Err != nil {
+ return model.NewAppError("HandleCommandWebhook", "web.command_webhook.invalid.app_error", nil, "err="+result.Err.Message, result.Err.StatusCode)
+ } else {
+ hook = result.Data.(*model.CommandWebhook)
+ }
+
+ var cmd *model.Command
+ if result := <-Srv.Store.Command().Get(hook.CommandId); result.Err != nil {
+ return model.NewAppError("HandleCommandWebhook", "web.command_webhook.command.app_error", nil, "err="+result.Err.Message, http.StatusBadRequest)
+ } else {
+ cmd = result.Data.(*model.Command)
+ }
+
+ args := &model.CommandArgs{
+ UserId: hook.UserId,
+ ChannelId: hook.ChannelId,
+ TeamId: cmd.TeamId,
+ RootId: hook.RootId,
+ ParentId: hook.ParentId,
+ }
+
+ if result := <-Srv.Store.CommandWebhook().TryUse(hook.Id, 5); result.Err != nil {
+ return model.NewAppError("HandleCommandWebhook", "web.command_webhook.invalid.app_error", nil, "err="+result.Err.Message, result.Err.StatusCode)
+ }
+
+ _, err := HandleCommandResponse(cmd, args, response, false)
+ return err
+}