mcd/internal/gotify/gotify.go

52 lines
1.2 KiB
Go

package gotify
import (
"fmt"
"log"
"net/http"
"net/url"
"strings"
"github.com/spf13/viper"
)
func sendNotification(msg string, title string) error {
if viper.GetBool("gotify.enabled") == false {
return nil
}
gUrl, err := url.Parse(viper.GetString("gotify.url"))
if err != nil {
log.Println("error parsing gotify url")
return err
}
gUrl.Path, err = url.JoinPath(gUrl.Path, "message")
if err != nil {
log.Println("error /message to gotify url")
return err
}
gUrl.RawQuery = fmt.Sprintf("token=%s", viper.GetString("gotify.token"))
resp, err := http.PostForm(gUrl.String(), url.Values{
"message": {msg},
"title": {title},
})
if err != nil {
log.Println("Error sending gotify message: ", err)
return err
} else {
log.Printf("Gotify: %s title: %s msg=%s\n", resp.Status, title, msg)
return nil
}
}
func PlayerJoin(text string) {
if strings.Contains(text, "joined the game") && viper.GetBool("gotify.join") {
sendNotification(text, fmt.Sprintf("%s: Player joined", viper.GetString("gotify.name")))
}
}
func PlayerLeave(text string) {
if strings.Contains(text, "left the game") && viper.GetBool("gotify.leave") {
sendNotification(text, fmt.Sprintf("%s: Player left", viper.GetString("gotify.name")))
}
}