fix(notifications): include icon in slack legacy url (#1303)

pull/1339/head
Brian Choromanski 2 years ago committed by GitHub
parent 08831f798c
commit 489356aa42
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -149,6 +149,8 @@ var _ = Describe("notifications", func() {
color := notifications.ColorInt color := notifications.ColorInt
data := notifications.GetTemplateData(command) data := notifications.GetTemplateData(command)
title := url.QueryEscape(data.Title) title := url.QueryEscape(data.Title)
username := "containrrrbot"
iconURL := "https://containrrr.dev/watchtower-sq180.png"
expected := fmt.Sprintf("discord://%s@%s?color=0x%x&colordebug=0x0&colorerror=0x0&colorinfo=0x0&colorwarn=0x0&title=%s&username=watchtower", token, channel, color, title) expected := fmt.Sprintf("discord://%s@%s?color=0x%x&colordebug=0x0&colorerror=0x0&colorinfo=0x0&colorwarn=0x0&title=%s&username=watchtower", token, channel, color, title)
buildArgs := func(url string) []string { buildArgs := func(url string) []string {
return []string{ return []string{
@ -167,6 +169,27 @@ var _ = Describe("notifications", func() {
hookURL := fmt.Sprintf("https://%s/api/webhooks/%s/%s/slack", "discordapp.com", channel, token) hookURL := fmt.Sprintf("https://%s/api/webhooks/%s/%s/slack", "discordapp.com", channel, token)
testURL(buildArgs(hookURL), expected, time.Duration(0)) testURL(buildArgs(hookURL), expected, time.Duration(0))
}) })
When("icon URL and username are specified", func() {
It("should return the expected URL", func() {
hookURL := fmt.Sprintf("https://%s/api/webhooks/%s/%s/slack", "discord.com", channel, token)
expectedOutput := fmt.Sprintf("discord://%s@%s?avatar=%s&color=0x%x&colordebug=0x0&colorerror=0x0&colorinfo=0x0&colorwarn=0x0&title=%s&username=%s", token, channel, url.QueryEscape(iconURL), color, title, username)
expectedDelay := time.Duration(7) * time.Second
args := []string{
"--notifications",
"slack",
"--notification-slack-hook-url",
hookURL,
"--notification-slack-identifier",
username,
"--notification-slack-icon-url",
iconURL,
"--notifications-delay",
fmt.Sprint(expectedDelay.Seconds()),
}
testURL(args, expectedOutput, expectedDelay)
})
})
}) })
When("converting a slack service config into a shoutrrr url", func() { When("converting a slack service config into a shoutrrr url", func() {
command := cmd.NewRootCommand() command := cmd.NewRootCommand()

@ -56,6 +56,11 @@ func (s *slackTypeNotifier) GetURL(c *cobra.Command, title string) (string, erro
SplitLines: true, SplitLines: true,
Username: s.Username, Username: s.Username,
} }
if s.IconURL != "" {
conf.Avatar = s.IconURL
}
return conf.GetURL().String(), nil return conf.GetURL().String(), nil
} }

Loading…
Cancel
Save