From 01aff5c6b8e6e87cd8988e5f91ed8ffb1f2b3efc Mon Sep 17 00:00:00 2001 From: chen Date: Wed, 10 Jan 2024 10:45:38 +0800 Subject: [PATCH] make sure dingtalk notify always produce valid json --- notify/dingtalk/dingtalk.go | 35 +++++++++++++++++++++++++---------- 1 file changed, 25 insertions(+), 10 deletions(-) diff --git a/notify/dingtalk/dingtalk.go b/notify/dingtalk/dingtalk.go index bbd775de..e0e056aa 100644 --- a/notify/dingtalk/dingtalk.go +++ b/notify/dingtalk/dingtalk.go @@ -43,6 +43,18 @@ type NotifyConfig struct { SignSecret string `yaml:"secret,omitempty" json:"secret,omitempty" jsonschema:"format=string,title=Secret,description=The Dingtalk Robot Secret"` } +// DingTalk is the dingtalk notification struct +type DingTalk struct { + MsgType string `json:"msgtype"` + Markdown Markdown `json:"markdown"` +} + +// Markdown is the markdown struct of dingtalk notification +type Markdown struct { + Title string `json:"title"` + Text string `json:"text"` +} + // Config configures the dingtalk notification func (c *NotifyConfig) Config(gConf global.NotifySettings) error { c.NotifyKind = "dingtalk" @@ -56,18 +68,21 @@ func (c *NotifyConfig) Config(gConf global.NotifySettings) error { // SendDingtalkNotification will post to an 'Robot Webhook' url in Dingtalk Apps. It accepts // some text and the Dingtalk robot will send it in group. func (c *NotifyConfig) SendDingtalkNotification(title, msg string) error { - title = "**" + title + "**" - // It will be better to escape the msg. - msgContent := fmt.Sprintf(` - { - "msgtype": "markdown", - "markdown": { - "title": "%s", - "text": "%s" - } + dingtalk := DingTalk{ + MsgType: "markdown", + Markdown: Markdown{ + Title: title, + Text: msg, + }, + } + msgContent, err := json.Marshal(dingtalk) + if err != nil { + log.Errorf("[%s / %s ] - %v, err - %s", c.Kind(), c.Name(), dingtalk, err) + return fmt.Errorf("[%s / %s] - Error from json marshal [%s] - [%s]", + c.Kind(), c.Name(), dingtalk, err) } - `, report.JSONEscape(title), report.JSONEscape(msg)) + req, err := http.NewRequest(http.MethodPost, c.addSign(c.WebhookURL, c.SignSecret), bytes.NewBuffer([]byte(msgContent))) if err != nil { return err