4a17f30da8
* First pass at browser, discord, twilio notifications * Commit updated Javascript packages * Remove twilio notification support * Email notifications/smtp support * Fix Firefox notification support, remove chrome checks * WIP more email work * Add support for twitter notifications * Add stream title to discord and twitter notifications * Update notification registration modal * Fix hide/show email section * Commit updated API documentation * Commit updated Javascript packages * Fix post-rebase missing var * Remove unused var * Handle unsubscribe errors for browser push * Standardize email config prop names * Allow overriding go live email template * Some notifications cleanup * Commit updated Javascript packages * Remove email/smtp/mailjet support * Remove more references to email notifications Co-authored-by: Owncast <owncast@owncast.online>
86 lines
2.4 KiB
Go
86 lines
2.4 KiB
Go
package admin
|
|
|
|
import (
|
|
"encoding/json"
|
|
"net/http"
|
|
|
|
"github.com/owncast/owncast/controllers"
|
|
"github.com/owncast/owncast/core/data"
|
|
"github.com/owncast/owncast/models"
|
|
)
|
|
|
|
// SetDiscordNotificationConfiguration will set the discord notification configuration.
|
|
func SetDiscordNotificationConfiguration(w http.ResponseWriter, r *http.Request) {
|
|
if !requirePOST(w, r) {
|
|
return
|
|
}
|
|
|
|
type request struct {
|
|
Value models.DiscordConfiguration `json:"value"`
|
|
}
|
|
|
|
decoder := json.NewDecoder(r.Body)
|
|
var config request
|
|
if err := decoder.Decode(&config); err != nil {
|
|
controllers.WriteSimpleResponse(w, false, "unable to update discord config with provided values")
|
|
return
|
|
}
|
|
|
|
if err := data.SetDiscordConfig(config.Value); err != nil {
|
|
controllers.WriteSimpleResponse(w, false, "unable to update discord config with provided values")
|
|
return
|
|
}
|
|
|
|
controllers.WriteSimpleResponse(w, true, "updated discord config with provided values")
|
|
}
|
|
|
|
// SetBrowserNotificationConfiguration will set the browser notification configuration.
|
|
func SetBrowserNotificationConfiguration(w http.ResponseWriter, r *http.Request) {
|
|
if !requirePOST(w, r) {
|
|
return
|
|
}
|
|
|
|
type request struct {
|
|
Value models.BrowserNotificationConfiguration `json:"value"`
|
|
}
|
|
|
|
decoder := json.NewDecoder(r.Body)
|
|
var config request
|
|
if err := decoder.Decode(&config); err != nil {
|
|
controllers.WriteSimpleResponse(w, false, "unable to update browser push config with provided values")
|
|
return
|
|
}
|
|
|
|
if err := data.SetBrowserPushConfig(config.Value); err != nil {
|
|
controllers.WriteSimpleResponse(w, false, "unable to update browser push config with provided values")
|
|
return
|
|
}
|
|
|
|
controllers.WriteSimpleResponse(w, true, "updated browser push config with provided values")
|
|
}
|
|
|
|
// SetTwitterConfiguration will set the browser notification configuration.
|
|
func SetTwitterConfiguration(w http.ResponseWriter, r *http.Request) {
|
|
if !requirePOST(w, r) {
|
|
return
|
|
}
|
|
|
|
type request struct {
|
|
Value models.TwitterConfiguration `json:"value"`
|
|
}
|
|
|
|
decoder := json.NewDecoder(r.Body)
|
|
var config request
|
|
if err := decoder.Decode(&config); err != nil {
|
|
controllers.WriteSimpleResponse(w, false, "unable to update twitter config with provided values")
|
|
return
|
|
}
|
|
|
|
if err := data.SetTwitterConfiguration(config.Value); err != nil {
|
|
controllers.WriteSimpleResponse(w, false, "unable to update twitter config with provided values")
|
|
return
|
|
}
|
|
|
|
controllers.WriteSimpleResponse(w, true, "updated twitter config with provided values")
|
|
}
|