package dispatcher import ( "encoding/json" "fmt" "html" "log" "strings" "github.com/gomarkdown/markdown" "github.com/pushbits/server/internal/model" ) type ExampleEvent struct { Body string `json:"body"` Msgtype string `json:"msgtype"` RelatesTo RelatesTo `json:"m.relates_to,omitempty"` } type RelatesTo struct { InReplyTo map[string]string `json:"m.in_reply_to"` } // SendNotification sends a notification to the specified user. func (d *Dispatcher) SendNotification(a *model.Application, n *model.Notification) error { log.Printf("Sending notification to room %s.", a.MatrixID) plainMessage := strings.TrimSpace(n.Message) plainTitle := strings.TrimSpace(n.Title) message := d.getFormattedMessage(n) title := d.getFormattedTitle(n) text := fmt.Sprintf("%s\n\n%s", plainTitle, plainMessage) formattedText := fmt.Sprintf("%s %s", title, message) _, err := d.client.SendFormattedText(a.MatrixID, text, formattedText) return err } func (d *Dispatcher) SendDeleteNotification(a *model.Application, n *model.DeleteNotification) error { log.Printf("Sending delete notification to room %s", a.MatrixID) event := ExampleEvent{ Body: "Testmessage", Msgtype: "m.text", } irt := make(map[string]string) irt["event_id"] = "$uf5OLKPaefHTZhc2lxSIY7If7pLFcNHcMZLbMfS-7qw" rt := RelatesTo{ InReplyTo: irt, } event.RelatesTo = rt _, err := d.client.SendMessageEvent(a.MatrixID, "m.room.message", event) if err != nil { log.Println(err) } messages, _ := d.client.Messages(a.MatrixID, "", "", 'b', 10) js, _ := json.Marshal(messages) log.Println(string(js)) return nil } // HTML-formats the title func (d *Dispatcher) getFormattedTitle(n *model.Notification) string { trimmedTitle := strings.TrimSpace(n.Title) title := html.EscapeString(trimmedTitle) if d.formatting.ColoredTitle { title = d.coloredText(d.priorityToColor(n.Priority), title) } return "" + title + "

" } // Converts different syntaxes to a HTML-formatted message func (d *Dispatcher) getFormattedMessage(n *model.Notification) string { trimmedMessage := strings.TrimSpace(n.Message) message := strings.Replace(html.EscapeString(trimmedMessage), "\n", "
", -1) // default to text/plain if optionsDisplayRaw, ok := n.Extras["client::display"]; ok { optionsDisplay, ok := optionsDisplayRaw.(map[string]interface{}) if ok { if contentTypeRaw, ok := optionsDisplay["contentType"]; ok { contentType := fmt.Sprintf("%v", contentTypeRaw) log.Printf("Message content type: %s", contentType) switch contentType { case "html", "text/html": message = strings.Replace(trimmedMessage, "\n", "
", -1) case "markdown", "md", "text/md", "text/markdown": // allow HTML in Markdown message = string(markdown.ToHTML([]byte(trimmedMessage), nil, nil)) } } } } return message } // Maps priorities to hex colors func (d *Dispatcher) priorityToColor(prio int) string { switch { case prio < 0: return "#828282" case prio <= 3: // info - default color return "" case prio <= 10: // low - yellow return "#edd711" case prio <= 20: // mid - orange return "#ed6d11" case prio > 20: // high - red return "#ed1f11" } return "" } // Maps a priority to a color tag func (d *Dispatcher) coloredText(color string, text string) string { if color == "" { return text } return "" + text + "" }