This commit is contained in:
Benjamin Toby 2025-01-14 11:53:57 +01:00
parent 03d4fdc270
commit 0731e8cb6c
14 changed files with 133 additions and 138 deletions

View File

@ -2,4 +2,4 @@ import { APILoginFunctionParams, APILoginFunctionReturn } from "../../../types";
/** /**
* # API Login * # API Login
*/ */
export default function apiLoginUser({ encryptionKey, email, username, password, database, additionalFields, email_login, email_login_code, email_login_field, token, skipPassword, social, useLocal, dbUserId, }: APILoginFunctionParams): Promise<APILoginFunctionReturn>; export default function apiLoginUser({ encryptionKey, email, username, password, database, additionalFields, email_login, email_login_code, email_login_field, token, skipPassword, social, useLocal, dbUserId, debug, }: APILoginFunctionParams): Promise<APILoginFunctionReturn>;

View File

@ -20,7 +20,7 @@ const hashPassword_1 = __importDefault(require("../../dsql/hashPassword"));
* # API Login * # API Login
*/ */
function apiLoginUser(_a) { function apiLoginUser(_a) {
return __awaiter(this, arguments, void 0, function* ({ encryptionKey, email, username, password, database, additionalFields, email_login, email_login_code, email_login_field, token, skipPassword, social, useLocal, dbUserId, }) { return __awaiter(this, arguments, void 0, function* ({ encryptionKey, email, username, password, database, additionalFields, email_login, email_login_code, email_login_field, token, skipPassword, social, useLocal, dbUserId, debug, }) {
const dbFullName = (0, grab_db_full_name_1.default)({ dbName: database, userId: dbUserId }); const dbFullName = (0, grab_db_full_name_1.default)({ dbName: database, userId: dbUserId });
/** /**
* Check input validity * Check input validity
@ -46,13 +46,20 @@ function apiLoginUser(_a) {
password: password, password: password,
}) })
: null; : null;
console.log(`Logging in: Checking for Existing user in ${dbFullName} database.`); if (debug) {
console.log("apiLoginUser:database:", dbFullName);
console.log("apiLoginUser:Finding User ...");
}
let foundUser = yield (0, varDatabaseDbHandler_1.default)({ let foundUser = yield (0, varDatabaseDbHandler_1.default)({
queryString: `SELECT * FROM ${dbFullName}.users WHERE email = ? OR username = ?`, queryString: `SELECT * FROM ${dbFullName}.users WHERE email = ? OR username = ?`,
queryValuesArray: [email, username], queryValuesArray: [email, username],
database: dbFullName, database: dbFullName,
useLocal, useLocal,
debug,
}); });
if (debug) {
console.log("apiLoginUser:foundUser:", foundUser);
}
if ((!foundUser || !foundUser[0]) && !social) if ((!foundUser || !foundUser[0]) && !social)
return { return {
success: false, success: false,
@ -60,6 +67,9 @@ function apiLoginUser(_a) {
msg: "No user found", msg: "No user found",
}; };
let isPasswordCorrect = false; let isPasswordCorrect = false;
if (debug) {
console.log("apiLoginUser:isPasswordCorrect:", isPasswordCorrect);
}
if ((foundUser === null || foundUser === void 0 ? void 0 : foundUser[0]) && !email_login && skipPassword) { if ((foundUser === null || foundUser === void 0 ? void 0 : foundUser[0]) && !email_login && skipPassword) {
isPasswordCorrect = true; isPasswordCorrect = true;
} }
@ -72,6 +82,9 @@ function apiLoginUser(_a) {
email_login_code && email_login_code &&
email_login_field) { email_login_field) {
const tempCode = foundUser[0][email_login_field]; const tempCode = foundUser[0][email_login_field];
if (debug) {
console.log("apiLoginUser:tempCode:", tempCode);
}
if (!tempCode) if (!tempCode)
throw new Error("No code Found!"); throw new Error("No code Found!");
const tempCodeArray = tempCode.split("-"); const tempCodeArray = tempCode.split("-");
@ -90,6 +103,10 @@ function apiLoginUser(_a) {
payload: null, payload: null,
}; };
} }
if (debug) {
console.log("apiLoginUser:isPasswordCorrect:", isPasswordCorrect);
console.log("apiLoginUser:email_login:", email_login);
}
if (isPasswordCorrect && email_login) { if (isPasswordCorrect && email_login) {
const resetTempCode = yield (0, varDatabaseDbHandler_1.default)({ const resetTempCode = yield (0, varDatabaseDbHandler_1.default)({
queryString: `UPDATE ${dbFullName}.users SET ${email_login_field} = '' WHERE email = ? OR username = ?`, queryString: `UPDATE ${dbFullName}.users SET ${email_login_field} = '' WHERE email = ? OR username = ?`,
@ -119,6 +136,10 @@ function apiLoginUser(_a) {
logged_in_status: true, logged_in_status: true,
date: Date.now(), date: Date.now(),
}; };
if (debug) {
console.log("apiLoginUser:userPayload:", userPayload);
console.log("apiLoginUser:Sending Response Object ...");
}
const resposeObject = { const resposeObject = {
success: true, success: true,
msg: "Login Successful", msg: "Login Successful",

View File

@ -4,9 +4,10 @@ type Param = {
database?: string; database?: string;
tableSchema?: import("../../types").DSQL_TableSchemaType; tableSchema?: import("../../types").DSQL_TableSchemaType;
useLocal?: boolean; useLocal?: boolean;
debug?: boolean;
}; };
/** /**
* # DB handler for specific database * # DB handler for specific database
*/ */
export default function varDatabaseDbHandler({ queryString, queryValuesArray, database, tableSchema, useLocal, }: Param): Promise<any>; export default function varDatabaseDbHandler({ queryString, queryValuesArray, database, tableSchema, useLocal, debug, }: Param): Promise<any>;
export {}; export {};

View File

@ -15,69 +15,26 @@ Object.defineProperty(exports, "__esModule", { value: true });
exports.default = varDatabaseDbHandler; exports.default = varDatabaseDbHandler;
const parseDbResults_1 = __importDefault(require("./parseDbResults")); const parseDbResults_1 = __importDefault(require("./parseDbResults"));
const serverError_1 = __importDefault(require("./serverError")); const serverError_1 = __importDefault(require("./serverError"));
const DB_HANDLER_1 = __importDefault(require("../../utils/backend/global-db/DB_HANDLER")); const grab_dsql_connection_1 = __importDefault(require("../../utils/grab-dsql-connection"));
const DSQL_USER_DB_HANDLER_1 = __importDefault(require("../../utils/backend/global-db/DSQL_USER_DB_HANDLER")); const conn_db_handler_1 = __importDefault(require("../../utils/db/conn-db-handler"));
const LOCAL_DB_HANDLER_1 = __importDefault(require("../../utils/backend/global-db/LOCAL_DB_HANDLER"));
/** /**
* # DB handler for specific database * # DB handler for specific database
*/ */
function varDatabaseDbHandler(_a) { function varDatabaseDbHandler(_a) {
return __awaiter(this, arguments, void 0, function* ({ queryString, queryValuesArray, database, tableSchema, useLocal, }) { return __awaiter(this, arguments, void 0, function* ({ queryString, queryValuesArray, database, tableSchema, useLocal, debug, }) {
/** let CONNECTION = (0, grab_dsql_connection_1.default)({ fa: true });
* Declare variables if (useLocal)
* CONNECTION = (0, grab_dsql_connection_1.default)({ local: true });
* @description Declare "results" variable if (database === null || database === void 0 ? void 0 : database.match(/^datasquirel$/))
*/ CONNECTION = (0, grab_dsql_connection_1.default)();
const isMaster = useLocal if (debug) {
? true console.log(`varDatabaseDbHandler:query:`, queryString);
: (database === null || database === void 0 ? void 0 : database.match(/^datasquirel$/)) console.log(`varDatabaseDbHandler:values:`, queryValuesArray);
? true
: false;
const FINAL_DB_HANDLER = useLocal
? LOCAL_DB_HANDLER_1.default
: isMaster
? DB_HANDLER_1.default
: DSQL_USER_DB_HANDLER_1.default;
let results;
/**
* Fetch from db
*
* @description Fetch data from db if no cache
*/
try {
if (queryString &&
queryValuesArray &&
Array.isArray(queryValuesArray) &&
queryValuesArray[0]) {
results = isMaster
? yield FINAL_DB_HANDLER(queryString, queryValuesArray)
: yield FINAL_DB_HANDLER({
paradigm: "Full Access",
queryString,
queryValues: queryValuesArray,
});
}
else {
results = isMaster
? yield FINAL_DB_HANDLER(queryString)
: yield FINAL_DB_HANDLER({
paradigm: "Full Access",
queryString,
});
}
} }
catch (error) { let results = yield (0, conn_db_handler_1.default)(CONNECTION, queryString, queryValuesArray);
console.log(`varDatabaseDbHandler Error: ${error.message}`); if (debug) {
(0, serverError_1.default)({ console.log(`varDatabaseDbHandler:results:`, results);
component: "varDatabaseDbHandler/lines-29-32",
message: error.message,
});
} }
/**
* Return results
*
* @description Return results add to cache if "req" param is passed
*/
if (results && tableSchema) { if (results && tableSchema) {
try { try {
const unparsedResults = results; const unparsedResults = results;

View File

@ -1028,6 +1028,7 @@ export type APILoginFunctionParams = {
social?: boolean; social?: boolean;
useLocal?: boolean; useLocal?: boolean;
dbUserId?: number | string; dbUserId?: number | string;
debug?: boolean;
}; };
export type APILoginFunctionReturn = { export type APILoginFunctionReturn = {
success: boolean; success: boolean;

View File

@ -9,9 +9,13 @@ type Param = {
*/ */
fa?: boolean; fa?: boolean;
/** /**
* Full Access? * No Database Connection
*/ */
noDb?: boolean; noDb?: boolean;
/**
* Is this a local connection?
*/
local?: boolean;
}; };
/** /**
* # Grab General CONNECTION for DSQL * # Grab General CONNECTION for DSQL

View File

@ -21,6 +21,7 @@ type Param = {
user_id?: string | number; user_id?: string | number;
skipPassword?: boolean; skipPassword?: boolean;
useLocal?: boolean; useLocal?: boolean;
debug?: boolean;
skipWriteAuthFile?: boolean; skipWriteAuthFile?: boolean;
apiUserID?: string | number; apiUserID?: string | number;
dbUserId?: string | number; dbUserId?: string | number;
@ -28,5 +29,5 @@ type Param = {
/** /**
* # Login A user * # Login A user
*/ */
export default function loginUser({ key, payload, database, additionalFields, response, encryptionKey, encryptionSalt, email_login, email_login_code, temp_code_field, token, user_id, skipPassword, useLocal, apiUserID, skipWriteAuthFile, dbUserId, }: Param): Promise<APILoginFunctionReturn>; export default function loginUser({ key, payload, database, additionalFields, response, encryptionKey, encryptionSalt, email_login, email_login_code, temp_code_field, token, user_id, skipPassword, useLocal, apiUserID, skipWriteAuthFile, dbUserId, debug, }: Param): Promise<APILoginFunctionReturn>;
export {}; export {};

View File

@ -24,7 +24,7 @@ const write_auth_files_1 = require("../package-shared/functions/backend/auth/wri
* # Login A user * # Login A user
*/ */
function loginUser(_a) { function loginUser(_a) {
return __awaiter(this, arguments, void 0, function* ({ key, payload, database, additionalFields, response, encryptionKey, encryptionSalt, email_login, email_login_code, temp_code_field, token, user_id, skipPassword, useLocal, apiUserID, skipWriteAuthFile, dbUserId, }) { return __awaiter(this, arguments, void 0, function* ({ key, payload, database, additionalFields, response, encryptionKey, encryptionSalt, email_login, email_login_code, temp_code_field, token, user_id, skipPassword, useLocal, apiUserID, skipWriteAuthFile, dbUserId, debug, }) {
var _b; var _b;
const grabedHostNames = (0, grab_host_names_1.default)(); const grabedHostNames = (0, grab_host_names_1.default)();
const { host, port, scheme } = grabedHostNames; const { host, port, scheme } = grabedHostNames;
@ -102,6 +102,7 @@ function loginUser(_a) {
token, token,
useLocal, useLocal,
dbUserId, dbUserId,
debug,
}); });
} }
else { else {
@ -147,11 +148,9 @@ function loginUser(_a) {
httpsRequest.end(); httpsRequest.end();
}); });
} }
/** if (debug) {
* Make https request console.log(`loginUser:httpResponse:`, httpResponse);
* }
* @description make a request to datasquirel.com
*/
if (httpResponse === null || httpResponse === void 0 ? void 0 : httpResponse.success) { if (httpResponse === null || httpResponse === void 0 ? void 0 : httpResponse.success) {
let encryptedPayload = (0, encrypt_1.default)({ let encryptedPayload = (0, encrypt_1.default)({
data: JSON.stringify(httpResponse.payload), data: JSON.stringify(httpResponse.payload),
@ -174,10 +173,18 @@ function loginUser(_a) {
httpResponse["key"] = String(encryptedPayload); httpResponse["key"] = String(encryptedPayload);
const authKeyName = cookieNames.keyCookieName; const authKeyName = cookieNames.keyCookieName;
const csrfName = cookieNames.csrfCookieName; const csrfName = cookieNames.csrfCookieName;
if (debug) {
console.log(`loginUser:authKeyName:`, authKeyName);
console.log(`loginUser:csrfName:`, csrfName);
console.log(`loginUser:encryptedPayload:`, encryptedPayload);
}
response === null || response === void 0 ? void 0 : response.setHeader("Set-Cookie", [ response === null || response === void 0 ? void 0 : response.setHeader("Set-Cookie", [
`${authKeyName}=${encryptedPayload};samesite=strict;path=/;HttpOnly=true;Secure=true`, `${authKeyName}=${encryptedPayload};samesite=strict;path=/;HttpOnly=true;Secure=true`,
`${csrfName}=${(_b = httpResponse.payload) === null || _b === void 0 ? void 0 : _b.csrf_k};samesite=strict;path=/;HttpOnly=true`, `${csrfName}=${(_b = httpResponse.payload) === null || _b === void 0 ? void 0 : _b.csrf_k};samesite=strict;path=/;HttpOnly=true`,
]); ]);
if (debug) {
console.log(`loginUser:Response Sent!`);
}
} }
return httpResponse; return httpResponse;
}); });

View File

@ -25,6 +25,7 @@ export default async function apiLoginUser({
social, social,
useLocal, useLocal,
dbUserId, dbUserId,
debug,
}: APILoginFunctionParams): Promise<APILoginFunctionReturn> { }: APILoginFunctionParams): Promise<APILoginFunctionReturn> {
const dbFullName = grabDbFullName({ dbName: database, userId: dbUserId }); const dbFullName = grabDbFullName({ dbName: database, userId: dbUserId });
@ -56,17 +57,23 @@ export default async function apiLoginUser({
}) })
: null; : null;
console.log( if (debug) {
`Logging in: Checking for Existing user in ${dbFullName} database.` console.log("apiLoginUser:database:", dbFullName);
); console.log("apiLoginUser:Finding User ...");
}
let foundUser = await varDatabaseDbHandler({ let foundUser = await varDatabaseDbHandler({
queryString: `SELECT * FROM ${dbFullName}.users WHERE email = ? OR username = ?`, queryString: `SELECT * FROM ${dbFullName}.users WHERE email = ? OR username = ?`,
queryValuesArray: [email, username], queryValuesArray: [email, username],
database: dbFullName, database: dbFullName,
useLocal, useLocal,
debug,
}); });
if (debug) {
console.log("apiLoginUser:foundUser:", foundUser);
}
if ((!foundUser || !foundUser[0]) && !social) if ((!foundUser || !foundUser[0]) && !social)
return { return {
success: false, success: false,
@ -76,6 +83,10 @@ export default async function apiLoginUser({
let isPasswordCorrect = false; let isPasswordCorrect = false;
if (debug) {
console.log("apiLoginUser:isPasswordCorrect:", isPasswordCorrect);
}
if (foundUser?.[0] && !email_login && skipPassword) { if (foundUser?.[0] && !email_login && skipPassword) {
isPasswordCorrect = true; isPasswordCorrect = true;
} else if (foundUser?.[0] && !email_login) { } else if (foundUser?.[0] && !email_login) {
@ -89,6 +100,10 @@ export default async function apiLoginUser({
) { ) {
const tempCode: string = foundUser[0][email_login_field]; const tempCode: string = foundUser[0][email_login_field];
if (debug) {
console.log("apiLoginUser:tempCode:", tempCode);
}
if (!tempCode) throw new Error("No code Found!"); if (!tempCode) throw new Error("No code Found!");
const tempCodeArray = tempCode.split("-"); const tempCodeArray = tempCode.split("-");
@ -111,6 +126,11 @@ export default async function apiLoginUser({
}; };
} }
if (debug) {
console.log("apiLoginUser:isPasswordCorrect:", isPasswordCorrect);
console.log("apiLoginUser:email_login:", email_login);
}
if (isPasswordCorrect && email_login) { if (isPasswordCorrect && email_login) {
const resetTempCode = await varDatabaseDbHandler({ const resetTempCode = await varDatabaseDbHandler({
queryString: `UPDATE ${dbFullName}.users SET ${email_login_field} = '' WHERE email = ? OR username = ?`, queryString: `UPDATE ${dbFullName}.users SET ${email_login_field} = '' WHERE email = ? OR username = ?`,
@ -144,6 +164,11 @@ export default async function apiLoginUser({
date: Date.now(), date: Date.now(),
}; };
if (debug) {
console.log("apiLoginUser:userPayload:", userPayload);
console.log("apiLoginUser:Sending Response Object ...");
}
const resposeObject: APILoginFunctionReturn = { const resposeObject: APILoginFunctionReturn = {
success: true, success: true,
msg: "Login Successful", msg: "Login Successful",

View File

@ -1,8 +1,7 @@
import parseDbResults from "./parseDbResults"; import parseDbResults from "./parseDbResults";
import serverError from "./serverError"; import serverError from "./serverError";
import DB_HANDLER from "../../utils/backend/global-db/DB_HANDLER"; import grabDSQLConnection from "../../utils/grab-dsql-connection";
import DSQL_USER_DB_HANDLER from "../../utils/backend/global-db/DSQL_USER_DB_HANDLER"; import connDbHandler from "../../utils/db/conn-db-handler";
import LOCAL_DB_HANDLER from "../../utils/backend/global-db/LOCAL_DB_HANDLER";
type Param = { type Param = {
queryString: string; queryString: string;
@ -10,6 +9,7 @@ type Param = {
database?: string; database?: string;
tableSchema?: import("../../types").DSQL_TableSchemaType; tableSchema?: import("../../types").DSQL_TableSchemaType;
useLocal?: boolean; useLocal?: boolean;
debug?: boolean;
}; };
/** /**
@ -21,66 +21,27 @@ export default async function varDatabaseDbHandler({
database, database,
tableSchema, tableSchema,
useLocal, useLocal,
debug,
}: Param): Promise<any> { }: Param): Promise<any> {
/** let CONNECTION = grabDSQLConnection({ fa: true });
* Declare variables if (useLocal) CONNECTION = grabDSQLConnection({ local: true });
* if (database?.match(/^datasquirel$/)) CONNECTION = grabDSQLConnection();
* @description Declare "results" variable
*/
const isMaster = useLocal
? true
: database?.match(/^datasquirel$/)
? true
: false;
const FINAL_DB_HANDLER: any = useLocal if (debug) {
? LOCAL_DB_HANDLER console.log(`varDatabaseDbHandler:query:`, queryString);
: isMaster console.log(`varDatabaseDbHandler:values:`, queryValuesArray);
? DB_HANDLER }
: DSQL_USER_DB_HANDLER;
let results = await connDbHandler(
let results; CONNECTION,
queryString,
/** queryValuesArray
* Fetch from db );
*
* @description Fetch data from db if no cache if (debug) {
*/ console.log(`varDatabaseDbHandler:results:`, results);
try {
if (
queryString &&
queryValuesArray &&
Array.isArray(queryValuesArray) &&
queryValuesArray[0]
) {
results = isMaster
? await FINAL_DB_HANDLER(queryString, queryValuesArray)
: await FINAL_DB_HANDLER({
paradigm: "Full Access",
queryString,
queryValues: queryValuesArray,
});
} else {
results = isMaster
? await FINAL_DB_HANDLER(queryString)
: await FINAL_DB_HANDLER({
paradigm: "Full Access",
queryString,
});
}
} catch (error: any) {
console.log(`varDatabaseDbHandler Error: ${error.message}`);
serverError({
component: "varDatabaseDbHandler/lines-29-32",
message: error.message,
});
} }
/**
* Return results
*
* @description Return results add to cache if "req" param is passed
*/
if (results && tableSchema) { if (results && tableSchema) {
try { try {
const unparsedResults = results; const unparsedResults = results;

View File

@ -1210,6 +1210,7 @@ export type APILoginFunctionParams = {
social?: boolean; social?: boolean;
useLocal?: boolean; useLocal?: boolean;
dbUserId?: number | string; dbUserId?: number | string;
debug?: boolean;
}; };
export type APILoginFunctionReturn = { export type APILoginFunctionReturn = {
success: boolean; success: boolean;

View File

@ -10,9 +10,13 @@ type Param = {
*/ */
fa?: boolean; fa?: boolean;
/** /**
* Full Access? * No Database Connection
*/ */
noDb?: boolean; noDb?: boolean;
/**
* Is this a local connection?
*/
local?: boolean;
}; };
/** /**

View File

@ -1,6 +1,6 @@
{ {
"name": "@moduletrace/datasquirel", "name": "@moduletrace/datasquirel",
"version": "3.5.1", "version": "3.5.2",
"description": "Cloud-based SQL data management tool", "description": "Cloud-based SQL data management tool",
"main": "dist/index.js", "main": "dist/index.js",
"bin": { "bin": {

View File

@ -31,6 +31,7 @@ type Param = {
user_id?: string | number; user_id?: string | number;
skipPassword?: boolean; skipPassword?: boolean;
useLocal?: boolean; useLocal?: boolean;
debug?: boolean;
skipWriteAuthFile?: boolean; skipWriteAuthFile?: boolean;
apiUserID?: string | number; apiUserID?: string | number;
dbUserId?: string | number; dbUserId?: string | number;
@ -57,6 +58,7 @@ export default async function loginUser({
apiUserID, apiUserID,
skipWriteAuthFile, skipWriteAuthFile,
dbUserId, dbUserId,
debug,
}: Param): Promise<APILoginFunctionReturn> { }: Param): Promise<APILoginFunctionReturn> {
const grabedHostNames = grabHostNames(); const grabedHostNames = grabHostNames();
const { host, port, scheme } = grabedHostNames; const { host, port, scheme } = grabedHostNames;
@ -152,6 +154,7 @@ export default async function loginUser({
token, token,
useLocal, useLocal,
dbUserId, dbUserId,
debug,
}); });
} else { } else {
httpResponse = await new Promise((resolve, reject) => { httpResponse = await new Promise((resolve, reject) => {
@ -210,11 +213,10 @@ export default async function loginUser({
}); });
} }
/** if (debug) {
* Make https request console.log(`loginUser:httpResponse:`, httpResponse);
* }
* @description make a request to datasquirel.com
*/
if (httpResponse?.success) { if (httpResponse?.success) {
let encryptedPayload = encrypt({ let encryptedPayload = encrypt({
data: JSON.stringify(httpResponse.payload), data: JSON.stringify(httpResponse.payload),
@ -245,10 +247,20 @@ export default async function loginUser({
const authKeyName = cookieNames.keyCookieName; const authKeyName = cookieNames.keyCookieName;
const csrfName = cookieNames.csrfCookieName; const csrfName = cookieNames.csrfCookieName;
if (debug) {
console.log(`loginUser:authKeyName:`, authKeyName);
console.log(`loginUser:csrfName:`, csrfName);
console.log(`loginUser:encryptedPayload:`, encryptedPayload);
}
response?.setHeader("Set-Cookie", [ response?.setHeader("Set-Cookie", [
`${authKeyName}=${encryptedPayload};samesite=strict;path=/;HttpOnly=true;Secure=true`, `${authKeyName}=${encryptedPayload};samesite=strict;path=/;HttpOnly=true;Secure=true`,
`${csrfName}=${httpResponse.payload?.csrf_k};samesite=strict;path=/;HttpOnly=true`, `${csrfName}=${httpResponse.payload?.csrf_k};samesite=strict;path=/;HttpOnly=true`,
]); ]);
if (debug) {
console.log(`loginUser:Response Sent!`);
}
} }
return httpResponse; return httpResponse;