datasquirel/users/get-token.js

117 lines
3.7 KiB
JavaScript
Raw Permalink Normal View History

2023-09-21 14:00:04 +00:00
// @ts-check
/**
* ==============================================================================
* Imports
* ==============================================================================
*/
const http = require("http");
2024-12-06 10:31:24 +00:00
const decrypt = require("../package-shared/functions/dsql/decrypt");
2024-12-06 11:55:03 +00:00
const getAuthCookieNames = require("../package-shared/functions/backend/cookies/get-auth-cookie-names");
2024-12-10 14:20:48 +00:00
const parseCookies = require("../package-shared/utils/backend/parseCookies");
2023-09-21 14:00:04 +00:00
/** ****************************************************************************** */
/** ****************************************************************************** */
/** ****************************************************************************** */
/** ****************************************************************************** */
/** ****************************************************************************** */
/** ****************************************************************************** */
/**
* Get just the access token for user
* ==============================================================================
* @description This Function takes in a request object and returns a user token
* string and csrf token string
*
* @param {Object} params - Arg
2024-12-13 13:08:41 +00:00
* @param {http.IncomingMessage} [params.request] - Http request object
* @param {string} [params.cookieString]
2023-09-21 14:00:04 +00:00
* @param {string} params.encryptionKey - Encryption Key
* @param {string} params.encryptionSalt - Encryption Salt
* @param {string} params.database - Database Name
2024-12-06 11:55:03 +00:00
* @param {boolean} [params.useLocal]
2023-09-21 14:00:04 +00:00
*
* @returns {{ key: string | undefined, csrf: string | undefined }}
*/
2024-12-06 11:55:03 +00:00
function getToken({
request,
encryptionKey,
encryptionSalt,
database,
useLocal,
2024-12-13 13:08:41 +00:00
cookieString,
2024-12-06 11:55:03 +00:00
}) {
2023-09-21 14:00:04 +00:00
try {
/**
* Grab the payload
*
* @description Grab the payload
*/
2024-12-13 13:08:41 +00:00
const cookies = parseCookies({ request, cookieString });
2024-12-06 11:55:03 +00:00
const keynames = getAuthCookieNames();
const authKeyName = keynames.keyCookieName;
const csrfName = keynames.csrfCookieName;
2023-09-21 14:00:04 +00:00
const key = cookies[authKeyName];
const csrf = cookies[csrfName];
/**
* Grab the payload
*
* @description Grab the payload
*/
let userPayload = decrypt({
encryptedString: key,
encryptionKey,
encryptionSalt,
});
/**
* Grab the payload
*
* @description Grab the payload
*/
if (!userPayload) {
return { key: undefined, csrf: undefined };
}
/**
* Grab the payload
*
* @description Grab the payload
*/
let userObject = JSON.parse(userPayload);
if (!userObject.csrf_k) {
return { key: undefined, csrf: undefined };
}
/** ********************************************** */
/** ********************************************** */
/** ********************************************** */
/**
* Return User Object
*
* @description Return User Object
*/
return { key, csrf };
} catch (error) {
/**
* Return User Object
*
* @description Return User Object
*/
return {
key: undefined,
csrf: undefined,
};
}
}
/** ********************************************** */
/** ********************************************** */
/** ********************************************** */
module.exports = getToken;