databag/net/server/internal/api_setPushEvent.go

56 lines
1.4 KiB
Go
Raw Normal View History

package databag
import (
"databag/internal/store"
"net/http"
)
type push struct {
PushToken string
MessageTitle string
MessageBody string
}
//AddPushEvent notify account of event to push notify
func SetPushEvent(w http.ResponseWriter, r *http.Request) {
card, code, err := ParamContactToken(r, false)
if err != nil {
ErrResponse(w, code, err)
return
}
var event string
if err := ParseRequest(r, w, &event); err != nil {
ErrResponse(w, http.StatusBadRequest, err)
return
}
2022-11-15 05:08:20 +00:00
SendPushEvent(card.Account, event)
2022-11-14 07:27:15 +00:00
WriteResponse(w, nil)
}
//SendPushEvent delivers notification to clients
2022-11-15 05:08:20 +00:00
func SendPushEvent(account store.Account, event string) {
2022-11-14 07:27:15 +00:00
2022-11-15 05:08:20 +00:00
// check if server supports push
if getBoolConfigValue(CNFPushSupported, true) != true {
return
}
2022-11-15 05:08:20 +00:00
// get all sessions supporting push for specified event
rows, err := store.DB.Table("sessions").Select("sessions.push_token, push_events.message_title, push_events.message_body").Joins("left join push_events on push_events.session_id = sessions.id").Where("sessions.account_id = ? AND sessions.push_enabled = ? AND push_events.event = ?", account.GUID, true, event).Rows();
if err != nil {
ErrMsg(err);
return
}
for rows.Next() {
PrintMsg("IN ROW");
var pushToken string
var messageTitle string
var messageBody string
rows.Scan(&pushToken, &messageTitle, &messageBody)
}
}