summaryrefslogtreecommitdiffstats
path: root/model/service_terms.go
diff options
context:
space:
mode:
authorHarshil Sharma <harshil.sharma@joshtechnologygroup.com>2018-09-26 20:49:22 +0000
committerJesse Hallam <jesse.hallam@gmail.com>2018-09-26 16:49:22 -0400
commitaf275fe9242303581192258ef4f6457fa45a58e4 (patch)
treedf05afdb0894d577574cbee5d056ffddeec3a93e /model/service_terms.go
parent4e59a27293394b6d5529efd13ad711daebbc0eb3 (diff)
downloadchat-af275fe9242303581192258ef4f6457fa45a58e4.tar.gz
chat-af275fe9242303581192258ef4f6457fa45a58e4.tar.bz2
chat-af275fe9242303581192258ef4f6457fa45a58e4.zip
#MM-12130 changes for custom service terms (#9450)
* #MM-12130 changes for custom service terms * Fixed styling * Added getServiceTerms API * removed unnecessary panic * removed custom service terms text from flat config * reverted user sql store as those changes are no longer needed * added tests * Updated a config key to be more standard * Added copyright info * Loading service terms only if the feature is enabled * Loading service terms only if the feature is enabled * removed unused index * added createservice termns API * made a param to bool instead of string * added createservice termns API * review fixes * fixed styling * Minor refactoring * removed saveConfig and loadConfig magic * added empty service terms text check to createServiceTerms API * refactoed some urls to be terms_of_service instead of service_terms * removed check for support settings * changed URLs in tests * removed unused code * fixed a bug * added service termd id in conif * fixed a test * review fixes * minor fixes * Fixed TestCreateServiceTerms
Diffstat (limited to 'model/service_terms.go')
-rw-r--r--model/service_terms.go70
1 files changed, 70 insertions, 0 deletions
diff --git a/model/service_terms.go b/model/service_terms.go
new file mode 100644
index 000000000..64ecabf31
--- /dev/null
+++ b/model/service_terms.go
@@ -0,0 +1,70 @@
+// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
+// See License.txt for license information.
+
+package model
+
+import (
+ "encoding/json"
+ "fmt"
+ "io"
+ "net/http"
+ "unicode/utf8"
+)
+
+// we only ever need the latest version of service terms
+const SERVICE_TERMS_CACHE_SIZE = 1
+
+type ServiceTerms struct {
+ Id string `json:"id"`
+ CreateAt int64 `json:"create_at"`
+ UserId string `json:"user_id"`
+ Text string `json:"text"`
+}
+
+func (t *ServiceTerms) IsValid() *AppError {
+ if len(t.Id) != 26 {
+ return InvalidServiceTermsError("id", "")
+ }
+
+ if t.CreateAt == 0 {
+ return InvalidServiceTermsError("create_at", t.Id)
+ }
+
+ if len(t.UserId) != 26 {
+ return InvalidServiceTermsError("user_id", t.Id)
+ }
+
+ if utf8.RuneCountInString(t.Text) > POST_MESSAGE_MAX_RUNES_V2 {
+ return InvalidServiceTermsError("text", t.Id)
+ }
+
+ return nil
+}
+
+func (t *ServiceTerms) ToJson() string {
+ b, _ := json.Marshal(t)
+ return string(b)
+}
+
+func ServiceTermsFromJson(data io.Reader) *ServiceTerms {
+ var serviceTerms *ServiceTerms
+ json.NewDecoder(data).Decode(&serviceTerms)
+ return serviceTerms
+}
+
+func InvalidServiceTermsError(fieldName string, serviceTermsId string) *AppError {
+ id := fmt.Sprintf("model.term.is_valid.%s.app_error", fieldName)
+ details := ""
+ if serviceTermsId != "" {
+ details = "service_terms_id=" + serviceTermsId
+ }
+ return NewAppError("ServiceTerms.IsValid", id, nil, details, http.StatusBadRequest)
+}
+
+func (t *ServiceTerms) PreSave() {
+ if t.Id == "" {
+ t.Id = NewId()
+ }
+
+ t.CreateAt = GetMillis()
+}