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"))) } }