100 lines
3.0 KiB
JavaScript
100 lines
3.0 KiB
JavaScript
|
// @ts-check
|
||
|
|
||
|
const LOCAL_DB_HANDLER = require("../../../utils/backend/global-db/LOCAL_DB_HANDLER");
|
||
|
const varDatabaseDbHandler = require("../../backend/varDatabaseDbHandler");
|
||
|
const nodemailer = require("nodemailer");
|
||
|
|
||
|
/**
|
||
|
* # Re-authenticate API user
|
||
|
* @param {object} param
|
||
|
* @param {Object<string, any>} param.existingUser
|
||
|
* @param {string} param.database
|
||
|
* @param {string | number} [param.userId]
|
||
|
* @param {string[]} [param.additionalFields]
|
||
|
* @param {boolean} [param.useLocal]
|
||
|
*
|
||
|
* @returns {Promise<import("../../../types").ApiReauthUserReturn>}
|
||
|
*/
|
||
|
module.exports = async function apiReauthUser({
|
||
|
existingUser,
|
||
|
database,
|
||
|
userId,
|
||
|
additionalFields,
|
||
|
useLocal,
|
||
|
}) {
|
||
|
let foundUser =
|
||
|
existingUser?.id && existingUser.id.toString().match(/./)
|
||
|
? useLocal
|
||
|
? await LOCAL_DB_HANDLER(`SELECT * FROM users WHERE id=?`, [
|
||
|
existingUser.id.toString(),
|
||
|
])
|
||
|
: await varDatabaseDbHandler({
|
||
|
queryString: `SELECT * FROM users WHERE id=?`,
|
||
|
queryValuesArray: [existingUser.id.toString()],
|
||
|
database,
|
||
|
})
|
||
|
: null;
|
||
|
|
||
|
////////////////////////////////////////
|
||
|
////////////////////////////////////////
|
||
|
////////////////////////////////////////
|
||
|
|
||
|
if (!foundUser || !foundUser[0])
|
||
|
return {
|
||
|
success: false,
|
||
|
payload: null,
|
||
|
msg: "No user found",
|
||
|
};
|
||
|
|
||
|
////////////////////////////////////////
|
||
|
////////////////////////////////////////
|
||
|
////////////////////////////////////////
|
||
|
|
||
|
let csrfKey =
|
||
|
Math.random().toString(36).substring(2) +
|
||
|
"-" +
|
||
|
Math.random().toString(36).substring(2);
|
||
|
|
||
|
/** @type {Object<string, string | number | boolean>} */
|
||
|
let userPayload = {
|
||
|
id: foundUser[0].id,
|
||
|
first_name: foundUser[0].first_name,
|
||
|
last_name: foundUser[0].last_name,
|
||
|
username: foundUser[0].username,
|
||
|
email: foundUser[0].email,
|
||
|
phone: foundUser[0].phone,
|
||
|
social_id: foundUser[0].social_id,
|
||
|
image: foundUser[0].image,
|
||
|
image_thumbnail: foundUser[0].image_thumbnail,
|
||
|
verification_status: foundUser[0].verification_status,
|
||
|
social_login: foundUser[0].social_login,
|
||
|
social_platform: foundUser[0].social_platform,
|
||
|
csrf_k: csrfKey,
|
||
|
more_data: foundUser[0].more_user_data,
|
||
|
logged_in_status: true,
|
||
|
date: Date.now(),
|
||
|
};
|
||
|
|
||
|
if (
|
||
|
additionalFields &&
|
||
|
Array.isArray(additionalFields) &&
|
||
|
additionalFields.length > 0
|
||
|
) {
|
||
|
additionalFields.forEach((key) => {
|
||
|
userPayload[key] = foundUser[0][key];
|
||
|
});
|
||
|
}
|
||
|
|
||
|
////////////////////////////////////////
|
||
|
////////////////////////////////////////
|
||
|
////////////////////////////////////////
|
||
|
|
||
|
/** ********************* Send Response */
|
||
|
return {
|
||
|
success: true,
|
||
|
msg: "Login Successful",
|
||
|
payload: userPayload,
|
||
|
userId,
|
||
|
};
|
||
|
};
|