Auth: Remove is_rest cookie

This commit is contained in:
Denis Arnst 2024-01-25 16:05:41 +01:00
parent 82048cd4f3
commit c3ba7daa16

View File

@ -186,6 +186,16 @@ class Auth {
} }
} }
/**
* Returns if the given auth method is API based.
*
* @param {string} authMethod
* @returns {boolean}
*/
isAuthMethodAPIBased(authMethod) {
return ['api', 'openid-mobile'].includes(authMethod)
}
/** /**
* Stores the client's choice of login callback method in temporary cookies. * Stores the client's choice of login callback method in temporary cookies.
* *
@ -201,14 +211,10 @@ class Auth {
*/ */
paramsToCookies(req, res, authMethod = 'local') { paramsToCookies(req, res, authMethod = 'local') {
const TWO_MINUTES = 120000 // 2 minutes in milliseconds const TWO_MINUTES = 120000 // 2 minutes in milliseconds
const isRest = ['api', 'openid-mobile'].includes(authMethod)
const callback = req.query.redirect_uri || req.query.callback const callback = req.query.redirect_uri || req.query.callback
// Set the 'is_rest' cookie based on the authentication method // Additional handling for non-API based authMethod
res.cookie('is_rest', isRest.toString(), { maxAge: TWO_MINUTES, httpOnly: true }) if (!this.isAuthMethodAPIBased(authMethod)) {
// Additional handling for 'local' authMethod
if (!isRest) {
// Store 'auth_state' if present in the request // Store 'auth_state' if present in the request
if (req.query.state) { if (req.query.state) {
res.cookie('auth_state', req.query.state, { maxAge: TWO_MINUTES, httpOnly: true }) res.cookie('auth_state', req.query.state, { maxAge: TWO_MINUTES, httpOnly: true })
@ -236,7 +242,7 @@ class Auth {
// get userLogin json (information about the user, server and the session) // get userLogin json (information about the user, server and the session)
const data_json = await this.getUserLoginResponsePayload(req.user) const data_json = await this.getUserLoginResponsePayload(req.user)
if (req.cookies.is_rest === 'true') { if (this.isAuthMethodAPIBased(req.cookies.auth_method)) {
// REST request - send data // REST request - send data
res.json(data_json) res.json(data_json)
} else { } else {