databag/net/server/internal/api_removeAgentToken.go

87 lines
2.1 KiB
Go
Raw Normal View History

package databag
import (
"databag/internal/store"
"gorm.io/gorm"
"net/http"
"errors"
)
//RemoveAgentToken
func RemoveAgentToken(w http.ResponseWriter, r *http.Request) {
// logout of all devices
logoutMode := r.FormValue("all") == "true"
if logoutMode {
// find account
account, code, err := ParamAgentToken(r, true)
if err != nil {
PrintMsg(r)
ErrResponse(w, code, err)
return
}
var sessions []store.Session
if err = store.DB.Where("account_id = ?", account.GUID).Find(&sessions).Error; err != nil {
ErrResponse(w, http.StatusInternalServerError, err);
return;
}
// delete all sessions
err = store.DB.Transaction(func(tx *gorm.DB) error {
for _, session := range sessions {
if res := tx.Where("session_id = ?", session.ID).Delete(&store.PushEvent{}).Error; res != nil {
return res
}
if res := tx.Where("id = ?", session.ID).Delete(&store.Session{}).Error; res != nil {
return res
}
}
return nil
})
if err != nil {
ErrResponse(w, http.StatusInternalServerError, err)
return
2022-11-14 06:44:32 +00:00
}
ClearStatus(account);
} else {
// parse authentication token
target, access, err := ParseToken(r.FormValue("agent"))
if err != nil {
ErrResponse(w, http.StatusBadRequest, err);
return
}
var session store.Session
if err = store.DB.Where("account_id = ? AND token = ?", target, access).Find(&session).Error; err != nil {
if errors.Is(err, gorm.ErrRecordNotFound) {
ErrResponse(w, http.StatusNotFound, err);
} else {
ErrResponse(w, http.StatusInternalServerError, err);
}
return;
}
// delete session
err = store.DB.Transaction(func(tx *gorm.DB) error {
if res := tx.Where("session_id = ?", session.ID).Delete(&store.PushEvent{}).Error; res != nil {
return res
}
if res := tx.Where("id = ?", session.ID).Delete(&store.Session{}).Error; res != nil {
return res
}
return nil
})
if err != nil {
ErrResponse(w, http.StatusInternalServerError, err)
return
2022-11-14 06:44:32 +00:00
}
}
WriteResponse(w, nil)
}