summaryrefslogtreecommitdiffstats
path: root/model
diff options
context:
space:
mode:
authorSaturnino Abril <saturnino.abril@gmail.com>2017-02-28 22:11:56 +0900
committerJoram Wilander <jwawilander@gmail.com>2017-02-28 08:11:55 -0500
commit66c5f7a31c5d0f26d394b94747c17ee55e5d5ce4 (patch)
tree5ccb3fc95f07d996cc0830431a64a341fee6eb3a /model
parentda902ef8bacb0751c7bd681abdc58039812d6430 (diff)
downloadchat-66c5f7a31c5d0f26d394b94747c17ee55e5d5ce4.tar.gz
chat-66c5f7a31c5d0f26d394b94747c17ee55e5d5ce4.tar.bz2
chat-66c5f7a31c5d0f26d394b94747c17ee55e5d5ce4.zip
Implementation of APIv4: POST users/{user_id}/image (#5537)
* APIv4: POST users/{user_id}/image * removed 'return' and rebased to master
Diffstat (limited to 'model')
-rw-r--r--model/client4.go34
1 files changed, 34 insertions, 0 deletions
diff --git a/model/client4.go b/model/client4.go
index e6c9192b9..0ccb94009 100644
--- a/model/client4.go
+++ b/model/client4.go
@@ -505,6 +505,40 @@ func (c *Client4) VerifyUserEmail(userId, hashId string) (bool, *Response) {
}
}
+// SetProfileImage sets profile image of the user
+func (c *Client4) SetProfileImage(userId string, data []byte) (bool, *Response) {
+ body := &bytes.Buffer{}
+ writer := multipart.NewWriter(body)
+
+ if part, err := writer.CreateFormFile("image", "profile.png"); err != nil {
+ return false, &Response{Error: NewAppError("SetProfileImage", "model.client.set_profile_user.no_file.app_error", nil, err.Error(), http.StatusBadRequest)}
+ } else if _, err = io.Copy(part, bytes.NewBuffer(data)); err != nil {
+ return false, &Response{Error: NewAppError("SetProfileImage", "model.client.set_profile_user.no_file.app_error", nil, err.Error(), http.StatusBadRequest)}
+ }
+
+ if err := writer.Close(); err != nil {
+ return false, &Response{Error: NewAppError("SetProfileImage", "model.client.set_profile_user.writer.app_error", nil, err.Error(), http.StatusBadRequest)}
+ }
+
+ rq, _ := http.NewRequest("POST", c.ApiUrl+c.GetUserRoute(userId)+"/image", bytes.NewReader(body.Bytes()))
+ rq.Header.Set("Content-Type", writer.FormDataContentType())
+ 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 {
+ // set to http.StatusForbidden(403)
+ return false, &Response{StatusCode: http.StatusForbidden, Error: NewAppError(c.GetUserRoute(userId)+"/image", "model.client.connecting.app_error", nil, err.Error(), 403)}
+ } else if rp.StatusCode >= 300 {
+ return false, &Response{StatusCode: rp.StatusCode, Error: AppErrorFromJson(rp.Body)}
+ } else {
+ defer closeBody(rp)
+ return CheckStatusOK(rp), BuildResponse(rp)
+ }
+}
+
// Team Section
// CreateTeam creates a team in the system based on the provided team struct.