summaryrefslogtreecommitdiffstats
path: root/model/client4.go
diff options
context:
space:
mode:
Diffstat (limited to 'model/client4.go')
-rw-r--r--model/client4.go43
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)
+ }
+}