From 60cf74352f13874a7d07c609c03b1c763af19cea Mon Sep 17 00:00:00 2001 From: George Goldberg Date: Thu, 3 May 2018 14:00:26 +0100 Subject: MM-10140: API Implementation for Schemes related Endpoints (#8615) * Implement basic scheme CRUD endpoints. * Get All Schemes (Paged) Endpoint and store plumbing. * Add get teams/channels for schemes. * Fix unit tests. * Review fixes. * More review fixes. --- model/scheme.go | 39 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 39 insertions(+) (limited to 'model/scheme.go') diff --git a/model/scheme.go b/model/scheme.go index c3ae7f15d..f949d9122 100644 --- a/model/scheme.go +++ b/model/scheme.go @@ -29,6 +29,11 @@ type Scheme struct { DefaultChannelUserRole string `json:"default_channel_user_role"` } +type SchemePatch struct { + Name *string `json:"name"` + Description *string `json:"description"` +} + type SchemeIDPatch struct { SchemeID *string `json:"scheme_id"` } @@ -44,6 +49,20 @@ func SchemeFromJson(data io.Reader) *Scheme { return scheme } +func SchemesToJson(schemes []*Scheme) string { + b, _ := json.Marshal(schemes) + return string(b) +} + +func SchemesFromJson(data io.Reader) []*Scheme { + var schemes []*Scheme + if err := json.NewDecoder(data).Decode(&schemes); err == nil { + return schemes + } else { + return nil + } +} + func (scheme *Scheme) IsValid() bool { if len(scheme.Id) != 26 { return false @@ -98,6 +117,26 @@ func (scheme *Scheme) IsValidForCreate() bool { return true } +func (scheme *Scheme) Patch(patch *SchemePatch) { + if patch.Name != nil { + scheme.Name = *patch.Name + } + if patch.Description != nil { + scheme.Description = *patch.Description + } +} + +func (patch *SchemePatch) ToJson() string { + b, _ := json.Marshal(patch) + return string(b) +} + +func SchemePatchFromJson(data io.Reader) *SchemePatch { + var patch *SchemePatch + json.NewDecoder(data).Decode(&patch) + return patch +} + func SchemeIDFromJson(data io.Reader) *string { var p *SchemeIDPatch json.NewDecoder(data).Decode(&p) -- cgit v1.2.3-1-g7c22