summaryrefslogtreecommitdiffstats
path: root/app/command_logout.go
diff options
context:
space:
mode:
authorJoram Wilander <jwawilander@gmail.com>2017-03-13 09:23:16 -0400
committerChristopher Speller <crspeller@gmail.com>2017-03-13 09:23:16 -0400
commite9c6cc269b5c9fe82e5f38d63344a07365bccd6b (patch)
tree711fefd3511dbd5a7f1a20225f00b766eb4808f7 /app/command_logout.go
parent8b0eedbbcd47ba09142c72a71969840aa6e121d2 (diff)
downloadchat-e9c6cc269b5c9fe82e5f38d63344a07365bccd6b.tar.gz
chat-e9c6cc269b5c9fe82e5f38d63344a07365bccd6b.tar.bz2
chat-e9c6cc269b5c9fe82e5f38d63344a07365bccd6b.zip
Move command logic into app layer (#5617)
Diffstat (limited to 'app/command_logout.go')
-rw-r--r--app/command_logout.go48
1 files changed, 48 insertions, 0 deletions
diff --git a/app/command_logout.go b/app/command_logout.go
new file mode 100644
index 000000000..1a353056e
--- /dev/null
+++ b/app/command_logout.go
@@ -0,0 +1,48 @@
+// Copyright (c) 2016 Mattermost, Inc. All Rights Reserved.
+// See License.txt for license information.
+
+package app
+
+import (
+ "github.com/mattermost/platform/model"
+ goi18n "github.com/nicksnyder/go-i18n/i18n"
+)
+
+type LogoutProvider struct {
+}
+
+const (
+ CMD_LOGOUT = "logout"
+)
+
+func init() {
+ RegisterCommandProvider(&LogoutProvider{})
+}
+
+func (me *LogoutProvider) GetTrigger() string {
+ return CMD_LOGOUT
+}
+
+func (me *LogoutProvider) GetCommand(T goi18n.TranslateFunc) *model.Command {
+ return &model.Command{
+ Trigger: CMD_LOGOUT,
+ AutoComplete: true,
+ AutoCompleteDesc: T("api.command_logout.desc"),
+ AutoCompleteHint: "",
+ DisplayName: T("api.command_logout.name"),
+ }
+}
+
+func (me *LogoutProvider) DoCommand(args *model.CommandArgs, message string) *model.CommandResponse {
+ FAIL := &model.CommandResponse{ResponseType: model.COMMAND_RESPONSE_TYPE_EPHEMERAL, Text: args.T("api.command_logout.fail_message")}
+ SUCCESS := &model.CommandResponse{GotoLocation: "/login"}
+
+ // We can't actually remove the user's cookie from here so we just dump their session and let the browser figure it out
+ if args.Session.Id != "" {
+ if err := RevokeSessionById(args.Session.Id); err != nil {
+ return FAIL
+ }
+ return SUCCESS
+ }
+ return FAIL
+}