68 lines
1.9 KiB
TypeScript
68 lines
1.9 KiB
TypeScript
|
import DB_HANDLER from "../../../utils/backend/global-db/DB_HANDLER";
|
||
|
import DSQL_USER_DB_HANDLER from "../../../utils/backend/global-db/DSQL_USER_DB_HANDLER";
|
||
|
import LOCAL_DB_HANDLER from "../../../utils/backend/global-db/LOCAL_DB_HANDLER";
|
||
|
|
||
|
type Param = {
|
||
|
dbContext?: string;
|
||
|
paradigm?: "Read Only" | "Full Access";
|
||
|
dbFullName: string;
|
||
|
tableName: string;
|
||
|
tableSchema?: import("../../../types").DSQL_TableSchemaType;
|
||
|
identifierColumnName: string;
|
||
|
identifierValue: string | number;
|
||
|
useLocal?: boolean;
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* # Delete DB Entry Function
|
||
|
* @description
|
||
|
*/
|
||
|
export default async function deleteDbEntry({
|
||
|
dbContext,
|
||
|
paradigm,
|
||
|
dbFullName,
|
||
|
tableName,
|
||
|
identifierColumnName,
|
||
|
identifierValue,
|
||
|
useLocal,
|
||
|
}: Param): Promise<object | null> {
|
||
|
try {
|
||
|
const isMaster = useLocal
|
||
|
? true
|
||
|
: dbContext?.match(/dsql.user/i)
|
||
|
? false
|
||
|
: dbFullName && !dbFullName.match(/^datasquirel$/)
|
||
|
? false
|
||
|
: true;
|
||
|
|
||
|
/** @type { (a1:any, a2?:any) => any } */
|
||
|
const dbHandler: (a1: any, a2?: any) => any = useLocal
|
||
|
? LOCAL_DB_HANDLER
|
||
|
: isMaster
|
||
|
? DB_HANDLER
|
||
|
: DSQL_USER_DB_HANDLER;
|
||
|
|
||
|
/**
|
||
|
* Execution
|
||
|
*
|
||
|
* @description
|
||
|
*/
|
||
|
const query = `DELETE FROM \`${dbFullName}\`.\`${tableName}\` WHERE \`${identifierColumnName}\`=?`;
|
||
|
|
||
|
const deletedEntry = isMaster
|
||
|
? await dbHandler(query, [identifierValue])
|
||
|
: await dbHandler({
|
||
|
paradigm,
|
||
|
queryString: query,
|
||
|
queryValues: [identifierValue],
|
||
|
});
|
||
|
|
||
|
/**
|
||
|
* Return statement
|
||
|
*/
|
||
|
return deletedEntry;
|
||
|
} catch (error) {
|
||
|
return null;
|
||
|
}
|
||
|
}
|