summaryrefslogtreecommitdiffstats
path: root/vendor/github.com/mattermost/mattermost-server/v5/model/compliance.go
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/github.com/mattermost/mattermost-server/v5/model/compliance.go')
-rw-r--r--vendor/github.com/mattermost/mattermost-server/v5/model/compliance.go119
1 files changed, 119 insertions, 0 deletions
diff --git a/vendor/github.com/mattermost/mattermost-server/v5/model/compliance.go b/vendor/github.com/mattermost/mattermost-server/v5/model/compliance.go
new file mode 100644
index 00000000..a86087c1
--- /dev/null
+++ b/vendor/github.com/mattermost/mattermost-server/v5/model/compliance.go
@@ -0,0 +1,119 @@
+// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
+// See LICENSE.txt for license information.
+
+package model
+
+import (
+ "encoding/json"
+ "io"
+ "net/http"
+ "strings"
+)
+
+const (
+ COMPLIANCE_STATUS_CREATED = "created"
+ COMPLIANCE_STATUS_RUNNING = "running"
+ COMPLIANCE_STATUS_FINISHED = "finished"
+ COMPLIANCE_STATUS_FAILED = "failed"
+ COMPLIANCE_STATUS_REMOVED = "removed"
+
+ COMPLIANCE_TYPE_DAILY = "daily"
+ COMPLIANCE_TYPE_ADHOC = "adhoc"
+)
+
+type Compliance struct {
+ Id string `json:"id"`
+ CreateAt int64 `json:"create_at"`
+ UserId string `json:"user_id"`
+ Status string `json:"status"`
+ Count int `json:"count"`
+ Desc string `json:"desc"`
+ Type string `json:"type"`
+ StartAt int64 `json:"start_at"`
+ EndAt int64 `json:"end_at"`
+ Keywords string `json:"keywords"`
+ Emails string `json:"emails"`
+}
+
+type Compliances []Compliance
+
+func (c *Compliance) ToJson() string {
+ b, _ := json.Marshal(c)
+ return string(b)
+}
+
+func (c *Compliance) PreSave() {
+ if c.Id == "" {
+ c.Id = NewId()
+ }
+
+ if c.Status == "" {
+ c.Status = COMPLIANCE_STATUS_CREATED
+ }
+
+ c.Count = 0
+ c.Emails = NormalizeEmail(c.Emails)
+ c.Keywords = strings.ToLower(c.Keywords)
+
+ c.CreateAt = GetMillis()
+}
+
+func (c *Compliance) JobName() string {
+ jobName := c.Type
+ if c.Type == COMPLIANCE_TYPE_DAILY {
+ jobName += "-" + c.Desc
+ }
+
+ jobName += "-" + c.Id
+
+ return jobName
+}
+
+func (c *Compliance) IsValid() *AppError {
+
+ if !IsValidId(c.Id) {
+ return NewAppError("Compliance.IsValid", "model.compliance.is_valid.id.app_error", nil, "", http.StatusBadRequest)
+ }
+
+ if c.CreateAt == 0 {
+ return NewAppError("Compliance.IsValid", "model.compliance.is_valid.create_at.app_error", nil, "", http.StatusBadRequest)
+ }
+
+ if len(c.Desc) > 512 || len(c.Desc) == 0 {
+ return NewAppError("Compliance.IsValid", "model.compliance.is_valid.desc.app_error", nil, "", http.StatusBadRequest)
+ }
+
+ if c.StartAt == 0 {
+ return NewAppError("Compliance.IsValid", "model.compliance.is_valid.start_at.app_error", nil, "", http.StatusBadRequest)
+ }
+
+ if c.EndAt == 0 {
+ return NewAppError("Compliance.IsValid", "model.compliance.is_valid.end_at.app_error", nil, "", http.StatusBadRequest)
+ }
+
+ if c.EndAt <= c.StartAt {
+ return NewAppError("Compliance.IsValid", "model.compliance.is_valid.start_end_at.app_error", nil, "", http.StatusBadRequest)
+ }
+
+ return nil
+}
+
+func ComplianceFromJson(data io.Reader) *Compliance {
+ var c *Compliance
+ json.NewDecoder(data).Decode(&c)
+ return c
+}
+
+func (c Compliances) ToJson() string {
+ if b, err := json.Marshal(c); err != nil {
+ return "[]"
+ } else {
+ return string(b)
+ }
+}
+
+func CompliancesFromJson(data io.Reader) Compliances {
+ var o Compliances
+ json.NewDecoder(data).Decode(&o)
+ return o
+}