summaryrefslogtreecommitdiffstats
path: root/model/client4.go
diff options
context:
space:
mode:
authorMartin Kraft <martinkraft@gmail.com>2018-05-17 07:53:16 -0400
committerMartin Kraft <martinkraft@gmail.com>2018-05-17 07:53:16 -0400
commit6f31d90e2f31ae597b83b2f845d5db938af8e38c (patch)
tree81c59b83ffb033df92ff7fba5ffaf3ba5fe7a3cf /model/client4.go
parent319d61123a0418ea9caa9510b8ad1e9a302c7b93 (diff)
parent1f6c271b3bedd6656ae7155714423b1b39a669c1 (diff)
downloadchat-6f31d90e2f31ae597b83b2f845d5db938af8e38c.tar.gz
chat-6f31d90e2f31ae597b83b2f845d5db938af8e38c.tar.bz2
chat-6f31d90e2f31ae597b83b2f845d5db938af8e38c.zip
Merge remote-tracking branch 'origin/master' into advanced-permissions-phase-2
Diffstat (limited to 'model/client4.go')
-rw-r--r--model/client4.go72
1 files changed, 72 insertions, 0 deletions
diff --git a/model/client4.go b/model/client4.go
index 2bfdd049f..afd8a6bc4 100644
--- a/model/client4.go
+++ b/model/client4.go
@@ -13,6 +13,33 @@ import (
"net/url"
"strconv"
"strings"
+ "time"
+)
+
+const (
+ HEADER_REQUEST_ID = "X-Request-ID"
+ HEADER_VERSION_ID = "X-Version-ID"
+ HEADER_CLUSTER_ID = "X-Cluster-ID"
+ HEADER_ETAG_SERVER = "ETag"
+ HEADER_ETAG_CLIENT = "If-None-Match"
+ HEADER_FORWARDED = "X-Forwarded-For"
+ HEADER_REAL_IP = "X-Real-IP"
+ HEADER_FORWARDED_PROTO = "X-Forwarded-Proto"
+ HEADER_TOKEN = "token"
+ HEADER_BEARER = "BEARER"
+ HEADER_AUTH = "Authorization"
+ HEADER_REQUESTED_WITH = "X-Requested-With"
+ HEADER_REQUESTED_WITH_XML = "XMLHttpRequest"
+ STATUS = "status"
+ STATUS_OK = "OK"
+ STATUS_FAIL = "FAIL"
+ STATUS_REMOVE = "REMOVE"
+
+ CLIENT_DIR = "client"
+
+ API_URL_SUFFIX_V1 = "/api/v1"
+ API_URL_SUFFIX_V4 = "/api/v4"
+ API_URL_SUFFIX = API_URL_SUFFIX_V4
)
type Response struct {
@@ -32,6 +59,24 @@ type Client4 struct {
AuthType string
}
+func closeBody(r *http.Response) {
+ if r.Body != nil {
+ ioutil.ReadAll(r.Body)
+ r.Body.Close()
+ }
+}
+
+// Must is a convenience function used for testing.
+func (c *Client4) Must(result interface{}, resp *Response) interface{} {
+ if resp.Error != nil {
+
+ time.Sleep(time.Second)
+ panic(resp.Error)
+ }
+
+ return result
+}
+
func NewAPIv4Client(url string) *Client4 {
return &Client4{url, url + API_URL_SUFFIX, &http.Client{}, "", ""}
}
@@ -64,6 +109,11 @@ func BuildResponse(r *http.Response) *Response {
}
}
+func (c *Client4) MockSession(sessionToken string) {
+ c.AuthToken = sessionToken
+ c.AuthType = HEADER_BEARER
+}
+
func (c *Client4) SetOAuthToken(token string) {
c.AuthToken = token
c.AuthType = HEADER_TOKEN
@@ -2982,6 +3032,28 @@ func (c *Client4) DeauthorizeOAuthApp(appId string) (bool, *Response) {
}
}
+// GetOAuthAccessToken is a test helper function for the OAuth access token endpoint.
+func (c *Client4) GetOAuthAccessToken(data url.Values) (*AccessResponse, *Response) {
+ rq, _ := http.NewRequest(http.MethodPost, c.Url+"/oauth/access_token", strings.NewReader(data.Encode()))
+ rq.Header.Set("Content-Type", "application/x-www-form-urlencoded")
+ rq.Close = true
+
+ if len(c.AuthToken) > 0 {
+ rq.Header.Set(HEADER_AUTH, c.AuthType+" "+c.AuthToken)
+ }
+
+ if rp, err := c.HttpClient.Do(rq); err != nil || rp == nil {
+ return nil, &Response{StatusCode: http.StatusForbidden, Error: NewAppError(c.Url+"/oauth/access_token", "model.client.connecting.app_error", nil, err.Error(), 403)}
+ } else {
+ defer closeBody(rp)
+ if rp.StatusCode >= 300 {
+ return nil, BuildErrorResponse(rp, AppErrorFromJson(rp.Body))
+ } else {
+ return AccessResponseFromJson(rp.Body), BuildResponse(rp)
+ }
+ }
+}
+
// Elasticsearch Section
// TestElasticsearch will attempt to connect to the configured Elasticsearch server and return OK if configured