databag/net/server/internal/api_setCloseMessage.go

79 lines
2.0 KiB
Go
Raw Normal View History

2022-02-11 22:29:28 +00:00
package databag
import (
2022-07-22 19:28:14 +00:00
"databag/internal/store"
"errors"
"gorm.io/gorm"
"net/http"
"time"
2022-02-11 22:29:28 +00:00
)
2022-07-29 21:57:25 +00:00
//SetCloseMessage delivers disconnection message to contact
2022-02-11 22:29:28 +00:00
func SetCloseMessage(w http.ResponseWriter, r *http.Request) {
2022-07-22 19:28:14 +00:00
var message DataMessage
if err := ParseRequest(r, w, &message); err != nil {
ErrResponse(w, http.StatusBadRequest, err)
return
}
2022-02-11 22:29:28 +00:00
2022-07-22 19:28:14 +00:00
var disconnect Disconnect
guid, messageType, ts, err := ReadDataMessage(&message, &disconnect)
if messageType != APPMsgDisconnect || err != nil {
ErrResponse(w, http.StatusBadRequest, err)
return
}
if ts+APPConnectExpire < time.Now().Unix() {
ErrResponse(w, http.StatusBadRequest, errors.New("message has expired"))
return
}
2022-02-11 22:29:28 +00:00
2022-07-22 19:28:14 +00:00
// load referenced account
var account store.Account
if err := store.DB.Where("guid = ?", disconnect.Contact).First(&account).Error; err != nil {
if errors.Is(err, gorm.ErrRecordNotFound) {
ErrResponse(w, http.StatusNotFound, err)
} else {
ErrResponse(w, http.StatusInternalServerError, err)
}
return
}
2022-02-11 22:29:28 +00:00
2022-07-22 19:28:14 +00:00
// see if card exists
var card store.Card
if err := store.DB.Preload("CardSlot").Where("account_id = ? AND guid = ?", account.GUID, guid).First(&card).Error; err != nil {
if !errors.Is(err, gorm.ErrRecordNotFound) {
ErrResponse(w, http.StatusInternalServerError, err)
} else {
WriteResponse(w, nil)
}
return
}
2022-02-11 22:29:28 +00:00
2022-07-22 19:28:14 +00:00
slot := card.CardSlot
err = store.DB.Transaction(func(tx *gorm.DB) error {
if card.Status != APPCardPending {
if res := tx.Model(&card).Update("status", APPCardConfirmed).Error; res != nil {
return res
}
}
if res := tx.Model(&card).Update("detail_revision", account.CardRevision+1).Error; res != nil {
return res
}
if res := tx.Model(&slot).Update("revision", account.CardRevision+1).Error; res != nil {
return res
}
if res := tx.Model(&account).Update("card_revision", account.CardRevision+1).Error; res != nil {
return res
}
return nil
})
if err != nil {
ErrResponse(w, http.StatusInternalServerError, err)
return
}
2022-02-11 22:29:28 +00:00
2022-07-22 19:28:14 +00:00
SetStatus(&account)
WriteResponse(w, nil)
2022-02-11 22:29:28 +00:00
}