diff options
author | Joram Wilander <jwawilander@gmail.com> | 2017-03-13 09:23:16 -0400 |
---|---|---|
committer | Christopher Speller <crspeller@gmail.com> | 2017-03-13 09:23:16 -0400 |
commit | e9c6cc269b5c9fe82e5f38d63344a07365bccd6b (patch) | |
tree | 711fefd3511dbd5a7f1a20225f00b766eb4808f7 /app/command_logout.go | |
parent | 8b0eedbbcd47ba09142c72a71969840aa6e121d2 (diff) | |
download | chat-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.go | 48 |
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 +} |