datasquirel/package-shared/functions/backend/db/runQuery.js

234 lines
8.1 KiB
JavaScript
Raw Normal View History

2023-09-21 14:00:04 +00:00
/** # MODULE TRACE
======================================================================
2024-11-06 06:26:23 +00:00
* Detected 3 files that call this module. The files are listed below:
2023-09-21 14:00:04 +00:00
======================================================================
2024-11-06 06:26:23 +00:00
* `import` Statement Found in [get.js] => file:///d:\GitHub\datasquirel\pages\api\query\get.js
* `import` Statement Found in [post.js] => file:///d:\GitHub\datasquirel\pages\api\query\post.js
* `import` Statement Found in [add-user.js] => file:///d:\GitHub\datasquirel\pages\api\user\add-user.js
2023-09-21 14:00:04 +00:00
==== MODULE TRACE END ==== */
// @ts-check
const fs = require("fs");
2024-11-17 04:36:56 +00:00
const LOCAL_DB_HANDLER = require("../../../utils/backend/global-db/LOCAL_DB_HANDLER");
2024-11-06 06:26:23 +00:00
const fullAccessDbHandler = require("../fullAccessDbHandler");
const varReadOnlyDatabaseDbHandler = require("../varReadOnlyDatabaseDbHandler");
const serverError = require("../serverError");
2023-09-21 14:00:04 +00:00
const addDbEntry = require("./addDbEntry");
const updateDbEntry = require("./updateDbEntry");
const deleteDbEntry = require("./deleteDbEntry");
2024-11-06 06:26:23 +00:00
const parseDbResults = require("../parseDbResults");
2023-09-21 14:00:04 +00:00
/** ****************************************************************************** */
/** ****************************************************************************** */
/** ****************************************************************************** */
/** ****************************************************************************** */
/** ****************************************************************************** */
/** ****************************************************************************** */
/**
* Run DSQL users queries
* ==============================================================================
* @param {object} params - An object containing the function parameters.
* @param {string} params.dbFullName - Database full name. Eg. "datasquire_user_2_test"
2024-11-06 06:26:23 +00:00
* @param {string | any} params.query - Query string or object
2023-09-21 14:00:04 +00:00
* @param {boolean} [params.readOnly] - Is this operation read only?
2024-11-06 06:26:23 +00:00
* @param {boolean} [params.local] - Is this operation read only?
* @param {import("../../../types").DSQL_DatabaseSchemaType} [params.dbSchema] - Database schema
2023-09-21 14:00:04 +00:00
* @param {string[]} [params.queryValuesArray] - An optional array of query values if "?" is used in the query string
* @param {string} [params.tableName] - Table Name
*
2024-11-06 06:26:23 +00:00
* @return {Promise<any>}
2023-09-21 14:00:04 +00:00
*/
2024-10-14 06:49:01 +00:00
async function runQuery({
dbFullName,
query,
readOnly,
dbSchema,
queryValuesArray,
tableName,
2024-11-06 06:26:23 +00:00
local,
2024-10-14 06:49:01 +00:00
}) {
2023-09-21 14:00:04 +00:00
/**
* Declare variables
*
* @description Declare "results" variable
*/
2024-11-06 06:26:23 +00:00
/** @type {any} */
let result;
/** @type {any} */
let error;
/** @type {import("../../../types").DSQL_TableSchemaType | undefined} */
let tableSchema;
2023-09-21 14:00:04 +00:00
if (dbSchema) {
try {
2024-10-14 06:49:01 +00:00
const table = tableName
? tableName
: typeof query == "string"
? null
: query
? query?.table
: null;
2023-09-21 14:00:04 +00:00
if (!table) throw new Error("No table name provided");
2024-10-14 06:49:01 +00:00
tableSchema = dbSchema.tables.filter(
(tb) => tb?.tableName === table
)[0];
2024-11-06 06:26:23 +00:00
} catch (_err) {
// console.log("ERROR getting tableSchema: ", _err.message);
}
2023-09-21 14:00:04 +00:00
}
/**
* Declare variables
*
* @description Declare "results" variable
*/
try {
if (typeof query === "string") {
2024-11-18 09:47:14 +00:00
const formattedQuery = query
.replace(/\n|\r|\n\r|\r\n/gm, " ")
.replace(/ {2,}/g, " ")
.trim();
2024-11-18 09:59:12 +00:00
/**
* Input Validation
*
* @description Input Validation
*/
if (
readOnly &&
(formattedQuery.match(
/^alter|^delete|information_schema|databases|^create/i
) ||
!formattedQuery.match(/^select|^\( ?select/i))
) {
throw new Error("Wrong Input!");
}
console.log("formattedQuery =>", formattedQuery);
2024-11-06 06:26:23 +00:00
if (local) {
2024-11-17 04:36:56 +00:00
const rawResults = await LOCAL_DB_HANDLER(
2024-11-18 09:47:14 +00:00
formattedQuery,
2024-11-17 04:36:56 +00:00
queryValuesArray
);
2024-11-06 06:26:23 +00:00
result = tableSchema
? parseDbResults({
unparsedResults: rawResults,
tableSchema,
})
: rawResults;
} else if (readOnly) {
result = await varReadOnlyDatabaseDbHandler({
2024-11-18 09:47:14 +00:00
queryString: formattedQuery,
2024-11-06 06:26:23 +00:00
queryValuesArray,
database: dbFullName,
tableSchema,
});
} else {
result = await fullAccessDbHandler({
2024-11-18 09:47:14 +00:00
queryString: formattedQuery,
2024-11-06 06:26:23 +00:00
queryValuesArray,
database: dbFullName,
tableSchema,
});
}
2023-09-21 14:00:04 +00:00
} else if (typeof query === "object") {
/**
* Declare variables
*
* @description Declare "results" variable
*/
2024-10-14 06:49:01 +00:00
const {
data,
action,
table,
identifierColumnName,
identifierValue,
update,
duplicateColumnName,
duplicateColumnValue,
} = query;
2023-09-21 14:00:04 +00:00
switch (action.toLowerCase()) {
case "insert":
result = await addDbEntry({
2024-11-06 06:26:23 +00:00
dbContext: local ? "Master" : "Dsql User",
paradigm: "Full Access",
2023-09-21 14:00:04 +00:00
dbFullName: dbFullName,
tableName: table,
data: data,
update,
duplicateColumnName,
duplicateColumnValue,
tableSchema,
});
if (!result?.insertId) {
error = new Error("Couldn't insert data");
}
break;
case "update":
result = await updateDbEntry({
2024-11-06 06:26:23 +00:00
dbContext: local ? "Master" : "Dsql User",
2023-09-21 14:00:04 +00:00
paradigm: "Full Access",
dbFullName: dbFullName,
tableName: table,
data: data,
identifierColumnName,
identifierValue,
tableSchema,
});
break;
case "delete":
result = await deleteDbEntry({
2024-11-06 06:26:23 +00:00
dbContext: local ? "Master" : "Dsql User",
2023-09-21 14:00:04 +00:00
paradigm: "Full Access",
dbFullName: dbFullName,
tableName: table,
identifierColumnName,
identifierValue,
tableSchema,
});
break;
default:
2024-11-06 06:26:23 +00:00
result = null;
2023-09-21 14:00:04 +00:00
break;
}
}
////////////////////////////////////////
////////////////////////////////////////
////////////////////////////////////////
2024-11-06 06:26:23 +00:00
} catch (/** @type {any} */ error) {
serverError({
component: "functions/backend/runQuery",
message: error.message,
});
result = null;
2023-09-21 14:00:04 +00:00
error = error.message;
}
////////////////////////////////////////
////////////////////////////////////////
////////////////////////////////////////
return { result, error };
////////////////////////////////////////
////////////////////////////////////////
////////////////////////////////////////
}
module.exports = runQuery;