diff options
author | Wim <wim@42.be> | 2016-07-22 23:14:13 +0200 |
---|---|---|
committer | Wim <wim@42.be> | 2016-07-22 23:15:59 +0200 |
commit | 911c597377b1f28533d1adee3f3bcff1c776927c (patch) | |
tree | a365b345cb2f4c93340306ec6c251c6ee9263406 /vendor/github.com/mattermost/platform/model/emoji.go | |
parent | 28244ffd9a6bad6228fbe53d73040ec29780b8a7 (diff) | |
download | matterbridge-msglm-911c597377b1f28533d1adee3f3bcff1c776927c.tar.gz matterbridge-msglm-911c597377b1f28533d1adee3f3bcff1c776927c.tar.bz2 matterbridge-msglm-911c597377b1f28533d1adee3f3bcff1c776927c.zip |
Sync with mattermost 3.2.0
Diffstat (limited to 'vendor/github.com/mattermost/platform/model/emoji.go')
-rw-r--r-- | vendor/github.com/mattermost/platform/model/emoji.go | 95 |
1 files changed, 95 insertions, 0 deletions
diff --git a/vendor/github.com/mattermost/platform/model/emoji.go b/vendor/github.com/mattermost/platform/model/emoji.go new file mode 100644 index 00000000..a66053aa --- /dev/null +++ b/vendor/github.com/mattermost/platform/model/emoji.go @@ -0,0 +1,95 @@ +// Copyright (c) 2016 Mattermost, Inc. All Rights Reserved. +// See License.txt for license information. + +package model + +import ( + "encoding/json" + "io" +) + +type Emoji struct { + Id string `json:"id"` + CreateAt int64 `json:"create_at"` + UpdateAt int64 `json:"update_at"` + DeleteAt int64 `json:"delete_at"` + CreatorId string `json:"creator_id"` + Name string `json:"name"` +} + +func (emoji *Emoji) IsValid() *AppError { + if len(emoji.Id) != 26 { + return NewLocAppError("Emoji.IsValid", "model.emoji.id.app_error", nil, "") + } + + if emoji.CreateAt == 0 { + return NewLocAppError("Emoji.IsValid", "model.emoji.create_at.app_error", nil, "id="+emoji.Id) + } + + if emoji.UpdateAt == 0 { + return NewLocAppError("Emoji.IsValid", "model.emoji.update_at.app_error", nil, "id="+emoji.Id) + } + + if len(emoji.CreatorId) != 26 { + return NewLocAppError("Emoji.IsValid", "model.emoji.user_id.app_error", nil, "") + } + + if len(emoji.Name) == 0 || len(emoji.Name) > 64 { + return NewLocAppError("Emoji.IsValid", "model.emoji.name.app_error", nil, "") + } + + return nil +} + +func (emoji *Emoji) PreSave() { + if emoji.Id == "" { + emoji.Id = NewId() + } + + emoji.CreateAt = GetMillis() + emoji.UpdateAt = emoji.CreateAt +} + +func (emoji *Emoji) PreUpdate() { + emoji.UpdateAt = GetMillis() +} + +func (emoji *Emoji) ToJson() string { + b, err := json.Marshal(emoji) + if err != nil { + return "" + } else { + return string(b) + } +} + +func EmojiFromJson(data io.Reader) *Emoji { + decoder := json.NewDecoder(data) + var emoji Emoji + err := decoder.Decode(&emoji) + if err == nil { + return &emoji + } else { + return nil + } +} + +func EmojiListToJson(emojiList []*Emoji) string { + b, err := json.Marshal(emojiList) + if err != nil { + return "" + } else { + return string(b) + } +} + +func EmojiListFromJson(data io.Reader) []*Emoji { + decoder := json.NewDecoder(data) + var emojiList []*Emoji + err := decoder.Decode(&emojiList) + if err == nil { + return emojiList + } else { + return nil + } +} |