diff options
author | kali kaneko (leap communications) <kali@leap.se> | 2021-11-15 21:35:53 +0100 |
---|---|---|
committer | kali kaneko (leap communications) <kali@leap.se> | 2021-11-23 21:51:26 +0100 |
commit | f219243eb77546afbaaa7bc25d347952e1e2bbae (patch) | |
tree | 96fb54f6019fd44d17d934f11bf7c5deb50331b1 /branding/motd-cli/main.go | |
parent | d4313f27aafa7ecce211bbcd12a6e5cf9ebe3609 (diff) |
[feat] naive motd json format implementation
Diffstat (limited to 'branding/motd-cli/main.go')
-rw-r--r-- | branding/motd-cli/main.go | 120 |
1 files changed, 120 insertions, 0 deletions
diff --git a/branding/motd-cli/main.go b/branding/motd-cli/main.go new file mode 100644 index 0000000..6cfd29e --- /dev/null +++ b/branding/motd-cli/main.go @@ -0,0 +1,120 @@ +package main + +import ( + "encoding/json" + "flag" + "fmt" + "io/ioutil" + "os" +) + +const defaultFile = "motd-example.json" + +const OK = "✓" +const WRONG = "☓" + +/* TODO move structs to pkg/config/motd module, import from there */ + +type Messages struct { + Messages []Message `json:"motd"` +} + +func (m *Messages) Length() int { + return len(m.Messages) +} + +type Message struct { + Begin string `json:"begin"` + End string `json:"end"` + Type string `json:"type"` + Platform string `json:"platform"` + Text []LocalizedText `json:"text"` +} + +func (m *Message) IsValid() bool { + valid := (m.IsValidBegin() && m.IsValidEnd() && + m.IsValidType() && m.IsValidPlatform() && m.HasLocalizedText()) + return valid +} + +func (m *Message) IsValidBegin() bool { + return true +} + +func (m *Message) IsValidEnd() bool { + return true +} + +func (m *Message) IsValidType() bool { + switch m.Type { + case "once", "daily": + return true + default: + return false + } +} + +func (m *Message) IsValidPlatform() bool { + switch m.Platform { + case "windows", "linux", "osx", "all": + return true + default: + return false + } +} + +func (m *Message) HasLocalizedText() bool { + return true +} + +type LocalizedText struct { + Lang string `json:"lang"` + Str string `json:"str"` +} + +func main() { + // TODO pass url flag too, to fetch and validate remote file + file := flag.String("file", "", "file to validate") + flag.Parse() + f := *file + if f == "" { + f = defaultFile + } + + fmt.Println("file:", f) + m := parseFile(f) + fmt.Printf("count: %v\n", m.Length()) + fmt.Println() + for i, msg := range m.Messages { + fmt.Printf("Message %d %v\n-----------\n", i+1, mark(msg.IsValid())) + fmt.Printf("Type: %s %v\n", msg.Type, mark(msg.IsValidType())) + fmt.Printf("Platform: %s %v\n", msg.Platform, mark(msg.IsValidPlatform())) + fmt.Printf("Languages: %d %v\n", len(msg.Text), mark(msg.HasLocalizedText())) + if !msg.IsValid() { + os.Exit(1) + } + } +} + +func parseFile(f string) Messages { + jsonFile, err := os.Open(f) + if err != nil { + panic(err) + } + defer jsonFile.Close() + byteVal, err := ioutil.ReadAll(jsonFile) + if err != nil { + panic(err) + } + var m Messages + json.Unmarshal(byteVal, &m) + return m +} + +func mark(val bool) string { + if val { + return OK + } else { + return WRONG + } +} |