diff options
Diffstat (limited to 'model/client4.go')
-rw-r--r-- | model/client4.go | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/model/client4.go b/model/client4.go index d9034385b..117f6c570 100644 --- a/model/client4.go +++ b/model/client4.go @@ -401,6 +401,14 @@ func (c *Client4) GetRedirectLocationRoute() string { return fmt.Sprintf("/redirect_location") } +func (c *Client4) GetRegisterServiceTermsRoute(userId string) string { + return c.GetUserRoute(userId) + "/terms_of_service" +} + +func (c *Client4) GetServiceTermsRoute() string { + return "/terms_of_service" +} + func (c *Client4) DoApiGet(url string, etag string) (*http.Response, *AppError) { return c.DoApiRequest(http.MethodGet, c.ApiUrl+url, "", etag) } @@ -3794,3 +3802,38 @@ func (c *Client4) GetRedirectLocation(urlParam, etag string) (string, *Response) return MapFromJson(r.Body)["location"], BuildResponse(r) } } + +func (c *Client4) RegisterServiceTermsAction(userId, serviceTermsId string, accepted bool) (*bool, *Response) { + url := c.GetRegisterServiceTermsRoute(userId) + data := map[string]interface{}{"serviceTermsId": serviceTermsId, "accepted": accepted} + + if r, err := c.DoApiPost(url, StringInterfaceToJson(data)); err != nil { + return nil, BuildErrorResponse(r, err) + } else { + defer closeBody(r) + return NewBool(CheckStatusOK(r)), BuildResponse(r) + } +} + +func (c *Client4) GetServiceTerms(etag string) (*ServiceTerms, *Response) { + url := c.GetServiceTermsRoute() + + if r, err := c.DoApiGet(url, etag); err != nil { + return nil, BuildErrorResponse(r, err) + } else { + defer closeBody(r) + return ServiceTermsFromJson(r.Body), BuildResponse(r) + } +} + +func (c *Client4) CreateServiceTerms(text, userId string) (*ServiceTerms, *Response) { + url := c.GetServiceTermsRoute() + + data := map[string]string{"text": text} + if r, err := c.DoApiPost(url, MapToJson(data)); err != nil { + return nil, BuildErrorResponse(r, err) + } else { + defer closeBody(r) + return ServiceTermsFromJson(r.Body), BuildResponse(r) + } +} |