package databag import ( "databag/internal/store" "gorm.io/gorm" "net/http" ) //SetAccountNotification sets whether notifications should be received func SetAccountNotification(w http.ResponseWriter, r *http.Request) { session, code, err := GetSession(r) if err != nil { ErrResponse(w, code, err) return } deviceToken := r.FormValue("deviceToken") webEndpoint := r.FormValue("webEndpoint") webPublicKey := r.FormValue("webPublicKey") webAuth := r.FormValue("webAuth"); pushType := r.FormValue("pushType"); var flag bool if err := ParseRequest(r, w, &flag); err != nil { ErrResponse(w, http.StatusBadRequest, err) return } err = store.DB.Transaction(func(tx *gorm.DB) error { if res := tx.Model(session).Update("push_enabled", flag).Error; res != nil { return res } if deviceToken != "" { if res := tx.Model(session).Update("push_token", deviceToken).Error; res != nil { return res } } if webEndpoint != "" { if res := tx.Model(session).Update("web_endpoint", webEndpoint).Error; res != nil { return res } } if webPublicKey != "" { if res := tx.Model(session).Update("web_public_key", webPublicKey).Error; res != nil { return res } } if webAuth != "" { if res := tx.Model(session).Update("web_auth", webAuth).Error; res != nil { return res } } if pushType != "" { if res := tx.Model(session).Update("push_type", pushType).Error; res != nil { return res } } session.Account.AccountRevision += 1; if res := tx.Model(session.Account).Update("account_revision", session.Account.AccountRevision).Error; res != nil { return res } return nil }) if err != nil { ErrResponse(w, http.StatusInternalServerError, err) return } SetStatus(&session.Account) WriteResponse(w, nil) }