Add force param to logout provisioning API
This commit is contained in:
parent
e6ccdb83b7
commit
b24672d6b4
@ -92,6 +92,7 @@ func (prov *ProvisioningAPI) DeleteSession(w http.ResponseWriter, r *http.Reques
|
|||||||
_, _ = user.Conn.Disconnect()
|
_, _ = user.Conn.Disconnect()
|
||||||
user.Conn.RemoveHandlers()
|
user.Conn.RemoveHandlers()
|
||||||
user.Conn = nil
|
user.Conn = nil
|
||||||
|
user.bridge.Metrics.TrackConnectionState(user.JID, false)
|
||||||
}
|
}
|
||||||
jsonResponse(w, http.StatusOK, Response{true, "Session information purged"})
|
jsonResponse(w, http.StatusOK, Response{true, "Session information purged"})
|
||||||
}
|
}
|
||||||
@ -281,22 +282,38 @@ func (prov *ProvisioningAPI) Logout(w http.ResponseWriter, r *http.Request) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
force := strings.ToLower(r.URL.Query().Get("force")) == "true"
|
||||||
|
|
||||||
|
if user.Conn == nil {
|
||||||
|
if !force {
|
||||||
|
jsonResponse(w, http.StatusNotFound, Error{
|
||||||
|
Error: "You're not connected",
|
||||||
|
ErrCode: "not connected",
|
||||||
|
})
|
||||||
|
}
|
||||||
|
} else {
|
||||||
err := user.Conn.Logout()
|
err := user.Conn.Logout()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
user.log.Warnln("Error while logging out:", err)
|
user.log.Warnln("Error while logging out:", err)
|
||||||
|
if !force {
|
||||||
jsonResponse(w, http.StatusInternalServerError, Error{
|
jsonResponse(w, http.StatusInternalServerError, Error{
|
||||||
Error: fmt.Sprintf("Unknown error while logging out: %v", err),
|
Error: fmt.Sprintf("Unknown error while logging out: %v", err),
|
||||||
ErrCode: err.Error(),
|
ErrCode: err.Error(),
|
||||||
})
|
})
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
}
|
||||||
_, err = user.Conn.Disconnect()
|
_, err = user.Conn.Disconnect()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
user.log.Warnln("Error while disconnecting after logout:", err)
|
user.log.Warnln("Error while disconnecting after logout:", err)
|
||||||
}
|
}
|
||||||
user.Conn.RemoveHandlers()
|
user.Conn.RemoveHandlers()
|
||||||
user.Conn = nil
|
user.Conn = nil
|
||||||
|
}
|
||||||
|
|
||||||
|
user.bridge.Metrics.TrackConnectionState(user.JID, false)
|
||||||
user.removeFromJIDMap()
|
user.removeFromJIDMap()
|
||||||
|
|
||||||
// TODO this causes a foreign key violation, which should be fixed
|
// TODO this causes a foreign key violation, which should be fixed
|
||||||
//ce.User.JID = ""
|
//ce.User.JID = ""
|
||||||
user.SetSession(nil)
|
user.SetSession(nil)
|
||||||
|
Loading…
Reference in New Issue
Block a user