my-log/formatters/json.go

78 lines
1.4 KiB
Go
Raw Permalink Normal View History

2024-03-10 11:33:51 -05:00
package formatters
import (
2024-03-10 12:14:21 -05:00
"bytes"
2024-03-10 11:33:51 -05:00
"encoding/json"
"time"
"codeberg.org/danjones000/my-log/config"
"codeberg.org/danjones000/my-log/models"
)
func newJson(ff config.Formatters) (Formatter, error) {
2024-03-10 12:14:21 -05:00
return &Json{ff.Json().PrettyPrint}, nil
2024-03-10 11:33:51 -05:00
}
type Json struct {
2024-03-10 12:14:21 -05:00
prettPrint bool
2024-03-10 11:33:51 -05:00
}
func (js *Json) Name() string {
return "json"
}
2024-03-10 12:14:21 -05:00
func (js *Json) marshal(v any) (o []byte, err error) {
o, err = json.Marshal(v)
if err != nil {
return
}
if js.prettPrint {
buff := &bytes.Buffer{}
err = json.Indent(buff, o, "", "\t")
if err == nil {
o = buff.Bytes()
}
}
return
}
2024-03-10 11:33:51 -05:00
func (js *Json) Meta(m models.Meta) ([]byte, error) {
o := map[string]any{m.Key: m.Value}
2024-03-10 12:14:21 -05:00
return js.marshal(o)
2024-03-10 11:33:51 -05:00
}
func (js *Json) entryMap(e models.Entry) map[string]any {
o := map[string]any{
"title": e.Title,
"date": e.Date.Format(time.RFC3339),
}
for _, m := range e.Fields {
o[m.Key] = m.Value
}
return o
}
func (js *Json) Entry(e models.Entry) ([]byte, error) {
2024-03-10 12:14:21 -05:00
return js.marshal(js.entryMap(e))
2024-03-10 11:33:51 -05:00
}
func (js *Json) Log(l models.Log) ([]byte, error) {
return js.Logs([]models.Log{l})
}
func (js *Json) Logs(logs []models.Log) (out []byte, err error) {
if len(logs) == 0 {
return
}
o := map[string][]map[string]any{}
for _, l := range logs {
es := []map[string]any{}
for _, e := range l.Entries {
es = append(es, js.entryMap(e))
}
o[l.Name] = es
}
2024-03-10 12:14:21 -05:00
return js.marshal(o)
2024-03-10 11:33:51 -05:00
}