Updates
This commit is contained in:
parent
03d4fdc270
commit
0731e8cb6c
@ -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>;
|
||||||
|
@ -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",
|
||||||
|
@ -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 {};
|
||||||
|
@ -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;
|
||||||
|
1
dist/package-shared/types/index.d.ts
vendored
1
dist/package-shared/types/index.d.ts
vendored
@ -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;
|
||||||
|
@ -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
|
||||||
|
3
dist/users/login-user.d.ts
vendored
3
dist/users/login-user.d.ts
vendored
@ -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 {};
|
||||||
|
19
dist/users/login-user.js
vendored
19
dist/users/login-user.js
vendored
@ -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;
|
||||||
});
|
});
|
||||||
|
@ -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",
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -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": {
|
||||||
|
@ -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;
|
||||||
|
Loading…
Reference in New Issue
Block a user