summaryrefslogtreecommitdiffstats
path: root/model/access.go
diff options
context:
space:
mode:
authorCorey Hulen <corey@hulen.com>2015-07-23 09:21:14 -0800
committerCorey Hulen <corey@hulen.com>2015-07-23 09:21:14 -0800
commita9d48ff994cd2d03f8e1b2438e50fc6dd0d9bdc2 (patch)
treef1b1c37242136098941d3d96b32245bf2b6a528c /model/access.go
parentdc79707787b521ea5fc0d9088ccd9069780c8e0c (diff)
parentd42d0e3467c8eec38fdca429ba9ba5ac2af68db8 (diff)
downloadchat-a9d48ff994cd2d03f8e1b2438e50fc6dd0d9bdc2.tar.gz
chat-a9d48ff994cd2d03f8e1b2438e50fc6dd0d9bdc2.tar.bz2
chat-a9d48ff994cd2d03f8e1b2438e50fc6dd0d9bdc2.zip
Merge pull request #237 from mattermost/mm-1570
fixes mm-1570 adds support for using mattermost as an OAuth client
Diffstat (limited to 'model/access.go')
-rw-r--r--model/access.go41
1 files changed, 41 insertions, 0 deletions
diff --git a/model/access.go b/model/access.go
new file mode 100644
index 000000000..f9e36ce07
--- /dev/null
+++ b/model/access.go
@@ -0,0 +1,41 @@
+// Copyright (c) 2015 Spinpunch, Inc. All Rights Reserved.
+// See License.txt for license information.
+
+package model
+
+import (
+ "encoding/json"
+ "io"
+)
+
+const (
+ ACCESS_TOKEN_GRANT_TYPE = "authorization_code"
+ ACCESS_TOKEN_TYPE = "bearer"
+)
+
+type AccessResponse struct {
+ AccessToken string `json:"access_token"`
+ TokenType string `json:"token_type"`
+ ExpiresIn int32 `json:"expires_in"`
+ RefreshToken string `json:"refresh_token"`
+}
+
+func (ar *AccessResponse) ToJson() string {
+ b, err := json.Marshal(ar)
+ if err != nil {
+ return ""
+ } else {
+ return string(b)
+ }
+}
+
+func AccessResponseFromJson(data io.Reader) *AccessResponse {
+ decoder := json.NewDecoder(data)
+ var ar AccessResponse
+ err := decoder.Decode(&ar)
+ if err == nil {
+ return &ar
+ } else {
+ return nil
+ }
+}