From ac2940ccfe464f14b6c9243ae16c30a259190708 Mon Sep 17 00:00:00 2001 From: Bastien Riviere Date: Sun, 3 Sep 2023 16:38:03 +0200 Subject: [PATCH] feat: add support for notification action --- bridge/bridge.go | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) diff --git a/bridge/bridge.go b/bridge/bridge.go index dbd7d9f..29b7b2d 100644 --- a/bridge/bridge.go +++ b/bridge/bridge.go @@ -23,11 +23,37 @@ type NotificationError struct { Error string `json:"error"` } +type NotificationAction struct { + Action string + Label string + Params []string +} + +func NewViewAction(label, url string, params ...string) NotificationAction { + return NotificationAction{ + Action: "view", + Label: label, + Params: append([]string{url}, params...), + } +} + +func (n NotificationAction) Format() string { + var sb strings.Builder + sb.WriteString(n.Action + ", " + n.Label) + + if len(n.Params) > 0 { + sb.WriteString(", " + strings.Join(n.Params, ", ")) + } + + return sb.String() +} + type Notification struct { Title string Body string Priority int Tags []string + Actions []NotificationAction IsMarkdown bool topic string @@ -70,6 +96,15 @@ func (n Notification) Send(base string) error { req.Header.Set("Authorization", n.auth.bearer()) } + if len(n.Actions) > 0 { + actions := make([]string, len(n.Actions)) + for i, act := range n.Actions { + actions[i] = act.Format() + } + + req.Header.Set("Actions", strings.Join(actions, "; ")) + } + resp, err := http.DefaultClient.Do(req) if err != nil { return err