Updates
This commit is contained in:
parent
f0d44092e5
commit
290dfe303c
5
dist/package-shared/data/app-data.d.ts
vendored
Normal file
5
dist/package-shared/data/app-data.d.ts
vendored
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
declare const AppData: {
|
||||||
|
readonly UniqueConstraintComment: "dsql_schema_unique_constraint";
|
||||||
|
readonly IndexComment: "dsql_schema_index";
|
||||||
|
};
|
||||||
|
export default AppData;
|
||||||
7
dist/package-shared/data/app-data.js
vendored
Normal file
7
dist/package-shared/data/app-data.js
vendored
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
"use strict";
|
||||||
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
|
const AppData = {
|
||||||
|
UniqueConstraintComment: `dsql_schema_unique_constraint`,
|
||||||
|
IndexComment: `dsql_schema_index`,
|
||||||
|
};
|
||||||
|
exports.default = AppData;
|
||||||
5
dist/package-shared/data/app-data.ts
vendored
Normal file
5
dist/package-shared/data/app-data.ts
vendored
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
const AppData = {
|
||||||
|
UniqueConstraintComment: `dsql_schema_unique_constraint`,
|
||||||
|
IndexComment: `dsql_schema_index`,
|
||||||
|
} as const;
|
||||||
|
export default AppData;
|
||||||
@ -70,6 +70,7 @@ function apiPost(_a) {
|
|||||||
delete clonedTargetTable.childrenTables;
|
delete clonedTargetTable.childrenTables;
|
||||||
delete clonedTargetTable.updateData;
|
delete clonedTargetTable.updateData;
|
||||||
delete clonedTargetTable.indexes;
|
delete clonedTargetTable.indexes;
|
||||||
|
delete clonedTargetTable.uniqueConstraints;
|
||||||
tableSchema = clonedTargetTable;
|
tableSchema = clonedTargetTable;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,32 +1,7 @@
|
|||||||
import { DbContextsArray } from "./runQuery";
|
import { AddDbEntryParam, APIResponseObject, PostInsertReturn } from "../../../types";
|
||||||
import { APIResponseObject, DSQL_TableSchemaType, PostInsertReturn } from "../../../types";
|
|
||||||
import { ConnectionConfig } from "mariadb";
|
|
||||||
export type AddDbEntryParam<T extends {
|
|
||||||
[k: string]: any;
|
|
||||||
} = any, K extends string = string> = {
|
|
||||||
dbContext?: (typeof DbContextsArray)[number];
|
|
||||||
paradigm?: "Read Only" | "Full Access";
|
|
||||||
dbFullName?: string;
|
|
||||||
tableName: K;
|
|
||||||
data?: T;
|
|
||||||
batchData?: T[];
|
|
||||||
tableSchema?: DSQL_TableSchemaType;
|
|
||||||
duplicateColumnName?: keyof T;
|
|
||||||
duplicateColumnValue?: string | number;
|
|
||||||
/**
|
|
||||||
* Update Entry if a duplicate is found.
|
|
||||||
* Requires `duplicateColumnName` and `duplicateColumnValue` parameters
|
|
||||||
*/
|
|
||||||
update?: boolean;
|
|
||||||
encryptionKey?: string;
|
|
||||||
encryptionSalt?: string;
|
|
||||||
forceLocal?: boolean;
|
|
||||||
debug?: boolean;
|
|
||||||
dbConfig?: ConnectionConfig;
|
|
||||||
};
|
|
||||||
/**
|
/**
|
||||||
* Add a db Entry Function
|
* Add a db Entry Function
|
||||||
*/
|
*/
|
||||||
export default function addDbEntry<T extends {
|
export default function addDbEntry<T extends {
|
||||||
[k: string]: any;
|
[k: string]: any;
|
||||||
} = any, K extends string = string>({ dbContext, paradigm, dbFullName, tableName, data, batchData, tableSchema, duplicateColumnName, duplicateColumnValue, update, encryptionKey, encryptionSalt, forceLocal, debug, dbConfig, }: AddDbEntryParam<T, K>): Promise<APIResponseObject<PostInsertReturn>>;
|
} = any, K extends string = string>({ dbContext, paradigm, dbFullName, tableName, data, batchData, tableSchema, duplicateColumnName, duplicateColumnValue, update, encryptionKey, encryptionSalt, forceLocal, debug, dbConfig, onDuplicate, }: AddDbEntryParam<T, K>): Promise<APIResponseObject<PostInsertReturn>>;
|
||||||
|
|||||||
@ -25,7 +25,7 @@ const grab_parsed_value_1 = __importDefault(require("./grab-parsed-value"));
|
|||||||
* Add a db Entry Function
|
* Add a db Entry Function
|
||||||
*/
|
*/
|
||||||
function addDbEntry(_a) {
|
function addDbEntry(_a) {
|
||||||
return __awaiter(this, arguments, void 0, function* ({ dbContext, paradigm, dbFullName, tableName, data, batchData, tableSchema, duplicateColumnName, duplicateColumnValue, update, encryptionKey, encryptionSalt, forceLocal, debug, dbConfig, }) {
|
return __awaiter(this, arguments, void 0, function* ({ dbContext, paradigm, dbFullName, tableName, data, batchData, tableSchema, duplicateColumnName, duplicateColumnValue, update, encryptionKey, encryptionSalt, forceLocal, debug, dbConfig, onDuplicate, }) {
|
||||||
const isMaster = forceLocal
|
const isMaster = forceLocal
|
||||||
? true
|
? true
|
||||||
: (0, check_if_is_master_1.default)({ dbContext, dbFullName });
|
: (0, check_if_is_master_1.default)({ dbContext, dbFullName });
|
||||||
@ -141,8 +141,14 @@ function addDbEntry(_a) {
|
|||||||
}
|
}
|
||||||
if (newData) {
|
if (newData) {
|
||||||
const { insertKeysArray, insertValuesArray, queryValuesArray } = generateQuery(newData);
|
const { insertKeysArray, insertValuesArray, queryValuesArray } = generateQuery(newData);
|
||||||
const query = `INSERT INTO ${isMaster && !dbFullName ? "" : `\`${dbFullName}\`.`}\`${tableName}\` (${insertKeysArray.join(",")}) VALUES (${grabQueryValuesString(insertValuesArray)})`;
|
let query = `INSERT INTO ${isMaster && !dbFullName ? "" : `\`${dbFullName}\`.`}\`${tableName}\` (${insertKeysArray.join(",")}) VALUES (${grabQueryValuesString(insertValuesArray)})`;
|
||||||
const finalQueryValues = grabFinalQueryValuesArr(queryValuesArray);
|
const finalQueryValues = grabFinalQueryValuesArr(queryValuesArray);
|
||||||
|
if (onDuplicate) {
|
||||||
|
query += ` ON DUPLICATE KEY ${onDuplicate.sql}`;
|
||||||
|
if (onDuplicate.values) {
|
||||||
|
finalQueryValues.push(...onDuplicate.values);
|
||||||
|
}
|
||||||
|
}
|
||||||
const newInsert = yield (0, conn_db_handler_1.default)({
|
const newInsert = yield (0, conn_db_handler_1.default)({
|
||||||
query,
|
query,
|
||||||
values: finalQueryValues,
|
values: finalQueryValues,
|
||||||
@ -171,10 +177,16 @@ function addDbEntry(_a) {
|
|||||||
batchInsertValuesArray.push(insertValuesArray);
|
batchInsertValuesArray.push(insertValuesArray);
|
||||||
batchQueryValuesArray.push(queryValuesArray);
|
batchQueryValuesArray.push(queryValuesArray);
|
||||||
}
|
}
|
||||||
const query = `INSERT INTO ${isMaster && !dbFullName ? "" : `\`${dbFullName}\`.`}\`${tableName}\` (${batchInsertKeysArray === null || batchInsertKeysArray === void 0 ? void 0 : batchInsertKeysArray.join(",")}) VALUES ${batchInsertValuesArray
|
let query = `INSERT INTO ${isMaster && !dbFullName ? "" : `\`${dbFullName}\`.`}\`${tableName}\` (${batchInsertKeysArray === null || batchInsertKeysArray === void 0 ? void 0 : batchInsertKeysArray.join(",")}) VALUES ${batchInsertValuesArray
|
||||||
.map((vl) => `(${grabQueryValuesString(vl)})`)
|
.map((vl) => `(${grabQueryValuesString(vl)})`)
|
||||||
.join(",")}`;
|
.join(",")}`;
|
||||||
const finalQueryValues = grabFinalQueryValuesArr(batchQueryValuesArray.flat());
|
const finalQueryValues = grabFinalQueryValuesArr(batchQueryValuesArray.flat());
|
||||||
|
if (onDuplicate) {
|
||||||
|
query += ` ON DUPLICATE KEY ${onDuplicate.sql}`;
|
||||||
|
if (onDuplicate.values) {
|
||||||
|
finalQueryValues.push(...onDuplicate.values);
|
||||||
|
}
|
||||||
|
}
|
||||||
const newInsert = yield (0, conn_db_handler_1.default)({
|
const newInsert = yield (0, conn_db_handler_1.default)({
|
||||||
query,
|
query,
|
||||||
values: finalQueryValues,
|
values: finalQueryValues,
|
||||||
|
|||||||
@ -13,8 +13,8 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|||||||
};
|
};
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
exports.default = handleIndexescreateDbFromSchema;
|
exports.default = handleIndexescreateDbFromSchema;
|
||||||
const grab_dsql_schema_index_comment_1 = __importDefault(require("../utils/grab-dsql-schema-index-comment"));
|
|
||||||
const dbHandler_1 = __importDefault(require("../../functions/backend/dbHandler"));
|
const dbHandler_1 = __importDefault(require("../../functions/backend/dbHandler"));
|
||||||
|
const app_data_1 = __importDefault(require("../../data/app-data"));
|
||||||
/**
|
/**
|
||||||
* Handle DATASQUIREL Table Indexes
|
* Handle DATASQUIREL Table Indexes
|
||||||
* ===================================================
|
* ===================================================
|
||||||
@ -23,36 +23,47 @@ const dbHandler_1 = __importDefault(require("../../functions/backend/dbHandler")
|
|||||||
*/
|
*/
|
||||||
function handleIndexescreateDbFromSchema(_a) {
|
function handleIndexescreateDbFromSchema(_a) {
|
||||||
return __awaiter(this, arguments, void 0, function* ({ dbFullName, tableName, indexes, }) {
|
return __awaiter(this, arguments, void 0, function* ({ dbFullName, tableName, indexes, }) {
|
||||||
|
/**
|
||||||
|
* Handle MYSQL Table Indexes
|
||||||
|
* ===================================================
|
||||||
|
* @description Iterate through each table index(if available)
|
||||||
|
* and perform operations
|
||||||
|
*/
|
||||||
const allExistingIndexes = (yield (0, dbHandler_1.default)({
|
const allExistingIndexes = (yield (0, dbHandler_1.default)({
|
||||||
query: `SHOW INDEXES FROM \`${dbFullName}\`.\`${tableName}\``,
|
query: `SHOW INDEXES FROM \`${dbFullName}\`.\`${tableName}\` WHERE Index_comment LIKE '%${app_data_1.default["IndexComment"]}%'`,
|
||||||
}));
|
}));
|
||||||
|
if (allExistingIndexes) {
|
||||||
|
for (let f = 0; f < allExistingIndexes.length; f++) {
|
||||||
|
const { Key_name } = allExistingIndexes[f];
|
||||||
|
try {
|
||||||
|
const existingKeyInSchema = indexes === null || indexes === void 0 ? void 0 : indexes.find((indexObject) => indexObject.alias === Key_name);
|
||||||
|
if (!existingKeyInSchema)
|
||||||
|
throw new Error(`This Index(${Key_name}) Has been Deleted!`);
|
||||||
|
}
|
||||||
|
catch (error) {
|
||||||
|
/**
|
||||||
|
* @description Drop Index: This happens when the MYSQL index is not
|
||||||
|
* present in the datasquirel DB schema
|
||||||
|
*/
|
||||||
|
yield (0, dbHandler_1.default)({
|
||||||
|
query: `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` DROP INDEX \`${Key_name}\``,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* # Re-Add New Indexes
|
||||||
|
*/
|
||||||
for (let g = 0; g < indexes.length; g++) {
|
for (let g = 0; g < indexes.length; g++) {
|
||||||
const { indexType, indexName, indexTableFields, alias } = indexes[g];
|
const { indexType, indexName, indexTableFields, alias } = indexes[g];
|
||||||
if (!(alias === null || alias === void 0 ? void 0 : alias.match(/./)))
|
if (!(alias === null || alias === void 0 ? void 0 : alias.match(/./)))
|
||||||
continue;
|
continue;
|
||||||
/**
|
const queryString = `CREATE${indexType == "full_text"
|
||||||
* @description Check for existing Index in MYSQL db
|
? " FULLTEXT"
|
||||||
*/
|
: indexType == "vector"
|
||||||
try {
|
? " VECTOR"
|
||||||
const existingKeyInDb = allExistingIndexes.filter((indexObject) => indexObject.Key_name === alias);
|
: ""} INDEX \`${alias}\` ON \`${dbFullName}\`.\`${tableName}\`(${indexTableFields === null || indexTableFields === void 0 ? void 0 : indexTableFields.map((nm) => nm.value).map((nm) => `\`${nm}\``).join(",")}) COMMENT '${app_data_1.default["IndexComment"]} ${indexName}'`;
|
||||||
if (!existingKeyInDb[0])
|
const addIndex = yield (0, dbHandler_1.default)({ query: queryString });
|
||||||
throw new Error("This Index Does not Exist");
|
|
||||||
}
|
|
||||||
catch (error) {
|
|
||||||
/**
|
|
||||||
* @description Create new index if determined that it
|
|
||||||
* doesn't exist in MYSQL db
|
|
||||||
*/
|
|
||||||
const queryString = `CREATE${indexType == "full_text"
|
|
||||||
? " FULLTEXT"
|
|
||||||
: indexType == "vector"
|
|
||||||
? " VECTOR"
|
|
||||||
: ""} INDEX \`${alias}\` ON \`${dbFullName}\`.\`${tableName}\`(${indexTableFields === null || indexTableFields === void 0 ? void 0 : indexTableFields.map((nm) => nm.value).map((nm) => `\`${nm}\``).join(",")}) COMMENT '${(0, grab_dsql_schema_index_comment_1.default)()} ${indexName}'`;
|
|
||||||
const addIndex = yield (0, dbHandler_1.default)({ query: queryString });
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
const allExistingIndexesAfterUpdate = (yield (0, dbHandler_1.default)({
|
|
||||||
query: `SHOW INDEXES FROM \`${dbFullName}\`.\`${tableName}\``,
|
|
||||||
}));
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|||||||
14
dist/package-shared/shell/createDbFromSchema/handle-unique-constraints.d.ts
vendored
Normal file
14
dist/package-shared/shell/createDbFromSchema/handle-unique-constraints.d.ts
vendored
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
import { DSQL_UniqueConstraintSchemaType } from "../../types";
|
||||||
|
type Param = {
|
||||||
|
tableName: string;
|
||||||
|
dbFullName: string;
|
||||||
|
tableUniqueConstraints: DSQL_UniqueConstraintSchemaType[];
|
||||||
|
};
|
||||||
|
/**
|
||||||
|
* Handle DATASQUIREL Table Unique Constraints
|
||||||
|
* ===================================================
|
||||||
|
* @description Iterate through each datasquirel schema
|
||||||
|
* table unique constraint(if available), and perform operations
|
||||||
|
*/
|
||||||
|
export default function handleUniqueConstraintsCreateDbFromSchema({ dbFullName, tableName, tableUniqueConstraints, }: Param): Promise<void>;
|
||||||
|
export {};
|
||||||
69
dist/package-shared/shell/createDbFromSchema/handle-unique-constraints.js
vendored
Normal file
69
dist/package-shared/shell/createDbFromSchema/handle-unique-constraints.js
vendored
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
"use strict";
|
||||||
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
||||||
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
||||||
|
return new (P || (P = Promise))(function (resolve, reject) {
|
||||||
|
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
||||||
|
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
||||||
|
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
||||||
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
||||||
|
});
|
||||||
|
};
|
||||||
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
||||||
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
||||||
|
};
|
||||||
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
|
exports.default = handleUniqueConstraintsCreateDbFromSchema;
|
||||||
|
const dbHandler_1 = __importDefault(require("../../functions/backend/dbHandler"));
|
||||||
|
const app_data_1 = __importDefault(require("../../data/app-data"));
|
||||||
|
/**
|
||||||
|
* Handle DATASQUIREL Table Unique Constraints
|
||||||
|
* ===================================================
|
||||||
|
* @description Iterate through each datasquirel schema
|
||||||
|
* table unique constraint(if available), and perform operations
|
||||||
|
*/
|
||||||
|
function handleUniqueConstraintsCreateDbFromSchema(_a) {
|
||||||
|
return __awaiter(this, arguments, void 0, function* ({ dbFullName, tableName, tableUniqueConstraints, }) {
|
||||||
|
/**
|
||||||
|
* # Delete All Existing Unique Constraints
|
||||||
|
*/
|
||||||
|
// const allExistingUniqueConstraints = (await dbHandler({
|
||||||
|
// query: `SHOW INDEXES FROM \`${dbFullName}\`.\`${tableName}\` WHERE Index_comment LIKE '%${AppData["UniqueConstraintComment"]}%'`,
|
||||||
|
// })) as DSQL_MYSQL_SHOW_INDEXES_Type[] | null;
|
||||||
|
// if (allExistingUniqueConstraints?.[0]) {
|
||||||
|
// for (let f = 0; f < allExistingUniqueConstraints.length; f++) {
|
||||||
|
// const { Key_name } = allExistingUniqueConstraints[f];
|
||||||
|
// try {
|
||||||
|
// const existingKeyInSchema = tableUniqueConstraints?.find(
|
||||||
|
// (indexObject) => indexObject.alias === Key_name
|
||||||
|
// );
|
||||||
|
// if (!existingKeyInSchema)
|
||||||
|
// throw new Error(
|
||||||
|
// `This Index(${Key_name}) Has been Deleted!`
|
||||||
|
// );
|
||||||
|
// } catch (error) {
|
||||||
|
// /**
|
||||||
|
// * @description Drop Index: This happens when the MYSQL index is not
|
||||||
|
// * present in the datasquirel DB schema
|
||||||
|
// */
|
||||||
|
// await dbHandler({
|
||||||
|
// query: `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` DROP INDEX \`${Key_name}\``,
|
||||||
|
// });
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
/**
|
||||||
|
* # Re-Add New Constraints
|
||||||
|
*/
|
||||||
|
for (let g = 0; g < tableUniqueConstraints.length; g++) {
|
||||||
|
const { constraintName, alias, constraintTableFields } = tableUniqueConstraints[g];
|
||||||
|
if (!(alias === null || alias === void 0 ? void 0 : alias.match(/./)))
|
||||||
|
continue;
|
||||||
|
/**
|
||||||
|
* @description Create new index if determined that it
|
||||||
|
* doesn't exist in MYSQL db
|
||||||
|
*/
|
||||||
|
const queryString = `CREATE UNIQUE INDEX \`${alias}\` ON \`${dbFullName}\`.\`${tableName}\`(${constraintTableFields === null || constraintTableFields === void 0 ? void 0 : constraintTableFields.map((nm) => nm.value).map((nm) => `\`${nm}\``).join(",")}) COMMENT '${app_data_1.default["UniqueConstraintComment"]} ${constraintName}'`;
|
||||||
|
const addIndex = yield (0, dbHandler_1.default)({ query: queryString });
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
@ -104,7 +104,7 @@ function createDbFromSchema(_a) {
|
|||||||
*/
|
*/
|
||||||
for (let t = 0; t < tables.length; t++) {
|
for (let t = 0; t < tables.length; t++) {
|
||||||
const table = tables[t];
|
const table = tables[t];
|
||||||
const { tableName, fields, indexes } = table;
|
const { tableName, fields, indexes, uniqueConstraints } = table;
|
||||||
if (targetTable && tableName !== targetTable)
|
if (targetTable && tableName !== targetTable)
|
||||||
continue;
|
continue;
|
||||||
console.log(`Handling table => ${tableName}`);
|
console.log(`Handling table => ${tableName}`);
|
||||||
@ -139,6 +139,7 @@ function createDbFromSchema(_a) {
|
|||||||
recordedDbEntry,
|
recordedDbEntry,
|
||||||
tableSchema: table,
|
tableSchema: table,
|
||||||
isMain,
|
isMain,
|
||||||
|
tableUniqueConstraints: uniqueConstraints,
|
||||||
});
|
});
|
||||||
if (table.childrenTables && table.childrenTables[0]) {
|
if (table.childrenTables && table.childrenTables[0]) {
|
||||||
for (let ch = 0; ch < table.childrenTables.length; ch++) {
|
for (let ch = 0; ch < table.childrenTables.length; ch++) {
|
||||||
@ -159,6 +160,7 @@ function createDbFromSchema(_a) {
|
|||||||
userId,
|
userId,
|
||||||
dbSchema: childTableParentDbSchema,
|
dbSchema: childTableParentDbSchema,
|
||||||
tableIndexes: childTableSchema.indexes,
|
tableIndexes: childTableSchema.indexes,
|
||||||
|
tableUniqueConstraints: childTableSchema.uniqueConstraints,
|
||||||
clone: true,
|
clone: true,
|
||||||
recordedDbEntry,
|
recordedDbEntry,
|
||||||
tableSchema: table,
|
tableSchema: table,
|
||||||
@ -173,11 +175,13 @@ function createDbFromSchema(_a) {
|
|||||||
*/
|
*/
|
||||||
const createNewTable = yield (0, createTable_1.default)({
|
const createNewTable = yield (0, createTable_1.default)({
|
||||||
tableName: tableName,
|
tableName: tableName,
|
||||||
tableInfoArray: fields,
|
fields,
|
||||||
dbFullName: dbFullName,
|
dbFullName: dbFullName,
|
||||||
tableSchema: table,
|
tableSchema: table,
|
||||||
recordedDbEntry,
|
recordedDbEntry,
|
||||||
isMain,
|
isMain,
|
||||||
|
indexes,
|
||||||
|
uniqueConstraints,
|
||||||
});
|
});
|
||||||
/**
|
/**
|
||||||
* Handle DATASQUIREL Table Indexes
|
* Handle DATASQUIREL Table Indexes
|
||||||
|
|||||||
@ -1,15 +1,17 @@
|
|||||||
import { DSQL_FieldSchemaType, DSQL_TableSchemaType } from "../../types";
|
import { DSQL_FieldSchemaType, DSQL_IndexSchemaType, DSQL_TableSchemaType, DSQL_UniqueConstraintSchemaType } from "../../types";
|
||||||
import { DSQL_DATASQUIREL_USER_DATABASES } from "../../types/dsql";
|
import { DSQL_DATASQUIREL_USER_DATABASES } from "../../types/dsql";
|
||||||
type Param = {
|
type Param = {
|
||||||
dbFullName: string;
|
dbFullName: string;
|
||||||
tableName: string;
|
tableName: string;
|
||||||
tableInfoArray: DSQL_FieldSchemaType[];
|
fields: DSQL_FieldSchemaType[];
|
||||||
tableSchema?: DSQL_TableSchemaType;
|
tableSchema?: DSQL_TableSchemaType;
|
||||||
recordedDbEntry?: DSQL_DATASQUIREL_USER_DATABASES;
|
recordedDbEntry?: DSQL_DATASQUIREL_USER_DATABASES;
|
||||||
isMain?: boolean;
|
isMain?: boolean;
|
||||||
|
indexes?: DSQL_IndexSchemaType[];
|
||||||
|
uniqueConstraints?: DSQL_UniqueConstraintSchemaType[];
|
||||||
};
|
};
|
||||||
/**
|
/**
|
||||||
* # Create Table Functions
|
* # Create Table Functions
|
||||||
*/
|
*/
|
||||||
export default function createTable({ dbFullName, tableName, tableInfoArray, tableSchema, recordedDbEntry, isMain, }: Param): Promise<number | undefined>;
|
export default function createTable({ dbFullName, tableName, fields: passedFields, tableSchema, recordedDbEntry, isMain, indexes, uniqueConstraints, }: Param): Promise<number | undefined>;
|
||||||
export {};
|
export {};
|
||||||
|
|||||||
61
dist/package-shared/shell/utils/createTable.js
vendored
61
dist/package-shared/shell/utils/createTable.js
vendored
@ -18,12 +18,14 @@ const supplementTable_1 = __importDefault(require("./supplementTable"));
|
|||||||
const handle_table_foreign_key_1 = __importDefault(require("./handle-table-foreign-key"));
|
const handle_table_foreign_key_1 = __importDefault(require("./handle-table-foreign-key"));
|
||||||
const create_table_handle_table_record_1 = __importDefault(require("./create-table-handle-table-record"));
|
const create_table_handle_table_record_1 = __importDefault(require("./create-table-handle-table-record"));
|
||||||
const dbHandler_1 = __importDefault(require("../../functions/backend/dbHandler"));
|
const dbHandler_1 = __importDefault(require("../../functions/backend/dbHandler"));
|
||||||
|
const handle_indexes_1 = __importDefault(require("../createDbFromSchema/handle-indexes"));
|
||||||
|
const handle_unique_constraints_1 = __importDefault(require("../createDbFromSchema/handle-unique-constraints"));
|
||||||
/**
|
/**
|
||||||
* # Create Table Functions
|
* # Create Table Functions
|
||||||
*/
|
*/
|
||||||
function createTable(_a) {
|
function createTable(_a) {
|
||||||
return __awaiter(this, arguments, void 0, function* ({ dbFullName, tableName, tableInfoArray, tableSchema, recordedDbEntry, isMain, }) {
|
return __awaiter(this, arguments, void 0, function* ({ dbFullName, tableName, fields: passedFields, tableSchema, recordedDbEntry, isMain, indexes, uniqueConstraints, }) {
|
||||||
const finalTable = (0, supplementTable_1.default)({ tableInfoArray: tableInfoArray });
|
const fields = (0, supplementTable_1.default)({ tableInfoArray: passedFields });
|
||||||
let tableId = yield (0, create_table_handle_table_record_1.default)({
|
let tableId = yield (0, create_table_handle_table_record_1.default)({
|
||||||
recordedDbEntry,
|
recordedDbEntry,
|
||||||
tableSchema,
|
tableSchema,
|
||||||
@ -34,15 +36,15 @@ function createTable(_a) {
|
|||||||
const createTableQueryArray = [];
|
const createTableQueryArray = [];
|
||||||
createTableQueryArray.push(`CREATE TABLE IF NOT EXISTS \`${dbFullName}\`.\`${tableName}\` (`);
|
createTableQueryArray.push(`CREATE TABLE IF NOT EXISTS \`${dbFullName}\`.\`${tableName}\` (`);
|
||||||
let primaryKeySet = false;
|
let primaryKeySet = false;
|
||||||
for (let i = 0; i < finalTable.length; i++) {
|
for (let i = 0; i < fields.length; i++) {
|
||||||
const column = finalTable[i];
|
const column = fields[i];
|
||||||
let { fieldEntryText, newPrimaryKeySet } = (0, generateColumnDescription_1.default)({
|
let { fieldEntryText, newPrimaryKeySet } = (0, generateColumnDescription_1.default)({
|
||||||
columnData: column,
|
columnData: column,
|
||||||
primaryKeySet: primaryKeySet,
|
primaryKeySet: primaryKeySet,
|
||||||
});
|
});
|
||||||
primaryKeySet = newPrimaryKeySet;
|
primaryKeySet = newPrimaryKeySet;
|
||||||
const comma = (() => {
|
const comma = (() => {
|
||||||
if (i === finalTable.length - 1)
|
if (i === fields.length - 1)
|
||||||
return "";
|
return "";
|
||||||
return ",";
|
return ",";
|
||||||
})();
|
})();
|
||||||
@ -53,19 +55,42 @@ function createTable(_a) {
|
|||||||
const newTable = yield (0, dbHandler_1.default)({
|
const newTable = yield (0, dbHandler_1.default)({
|
||||||
query: createTableQuery,
|
query: createTableQuery,
|
||||||
});
|
});
|
||||||
for (let i = 0; i < finalTable.length; i++) {
|
/**
|
||||||
const column = finalTable[i];
|
* Handle MYSQL Foreign Keys
|
||||||
const { foreignKey, fieldName } = column;
|
* ===================================================
|
||||||
if (!fieldName)
|
* @description Iterate through each datasquirel schema
|
||||||
continue;
|
* table index(if available), and perform operations
|
||||||
if (foreignKey) {
|
*/
|
||||||
yield (0, handle_table_foreign_key_1.default)({
|
yield (0, handle_table_foreign_key_1.default)({
|
||||||
dbFullName,
|
dbFullName,
|
||||||
foreignKey,
|
fields,
|
||||||
tableName,
|
tableName,
|
||||||
fieldName,
|
});
|
||||||
});
|
/**
|
||||||
}
|
* Handle DATASQUIREL Table Indexes
|
||||||
|
* ===================================================
|
||||||
|
* @description Iterate through each datasquirel schema
|
||||||
|
* table index(if available), and perform operations
|
||||||
|
*/
|
||||||
|
if (indexes === null || indexes === void 0 ? void 0 : indexes[0]) {
|
||||||
|
(0, handle_indexes_1.default)({
|
||||||
|
dbFullName,
|
||||||
|
indexes,
|
||||||
|
tableName,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* Handle DATASQUIREL Table Unique Indexes
|
||||||
|
* ===================================================
|
||||||
|
* @description Iterate through each datasquirel schema
|
||||||
|
* table unique constraint(if available), and perform operations
|
||||||
|
*/
|
||||||
|
if (uniqueConstraints === null || uniqueConstraints === void 0 ? void 0 : uniqueConstraints[0]) {
|
||||||
|
(0, handle_unique_constraints_1.default)({
|
||||||
|
dbFullName,
|
||||||
|
tableUniqueConstraints: uniqueConstraints,
|
||||||
|
tableName,
|
||||||
|
});
|
||||||
}
|
}
|
||||||
return tableId;
|
return tableId;
|
||||||
});
|
});
|
||||||
|
|||||||
@ -1,9 +0,0 @@
|
|||||||
type Param = {
|
|
||||||
dbFullName: string;
|
|
||||||
tableName: string;
|
|
||||||
};
|
|
||||||
/**
|
|
||||||
* # Drop All Foreign Keys
|
|
||||||
*/
|
|
||||||
export default function dropAllForeignKeys({ dbFullName, tableName, }: Param): Promise<void>;
|
|
||||||
export {};
|
|
||||||
@ -1,52 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
||||||
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
||||||
return new (P || (P = Promise))(function (resolve, reject) {
|
|
||||||
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
||||||
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
||||||
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
||||||
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
||||||
});
|
|
||||||
};
|
|
||||||
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
||||||
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
||||||
};
|
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
|
||||||
exports.default = dropAllForeignKeys;
|
|
||||||
const grab_sql_key_name_1 = __importDefault(require("../../utils/grab-sql-key-name"));
|
|
||||||
const dbHandler_1 = __importDefault(require("../../functions/backend/dbHandler"));
|
|
||||||
/**
|
|
||||||
* # Drop All Foreign Keys
|
|
||||||
*/
|
|
||||||
function dropAllForeignKeys(_a) {
|
|
||||||
return __awaiter(this, arguments, void 0, function* ({ dbFullName, tableName, }) {
|
|
||||||
try {
|
|
||||||
// const rows = await varDatabaseDbHandler({
|
|
||||||
// queryString: `SELECT CONSTRAINT_NAME FROM information_schema.REFERENTIAL_CONSTRAINTS WHERE TABLE_NAME = '${tableName}' AND CONSTRAINT_SCHEMA = '${dbFullName}'`,
|
|
||||||
// });
|
|
||||||
// console.log("rows", rows);
|
|
||||||
// console.log("dbFullName", dbFullName);
|
|
||||||
// console.log("tableName", tableName);
|
|
||||||
// for (const row of rows) {
|
|
||||||
// await varDatabaseDbHandler({
|
|
||||||
// queryString: `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` DROP FOREIGN KEY \`${row.CONSTRAINT_NAME}\`
|
|
||||||
// `,
|
|
||||||
// });
|
|
||||||
// }
|
|
||||||
const foreignKeys = (yield (0, dbHandler_1.default)({
|
|
||||||
query: `SHOW INDEXES FROM \`${dbFullName}\`.\`${tableName}\` WHERE Key_name LIKE '${(0, grab_sql_key_name_1.default)({ type: "foreign_key" })}%'`,
|
|
||||||
}));
|
|
||||||
for (const fk of foreignKeys) {
|
|
||||||
if (fk.Key_name.match(new RegExp((0, grab_sql_key_name_1.default)({ type: "foreign_key" })))) {
|
|
||||||
yield (0, dbHandler_1.default)({
|
|
||||||
query: `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` DROP INDEX \`${fk.Key_name}\`
|
|
||||||
`,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch (error) {
|
|
||||||
console.log(`dropAllForeignKeys ERROR => ${error.message}`);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
16
dist/package-shared/shell/utils/handle-dsql-schema-fields.d.ts
vendored
Normal file
16
dist/package-shared/shell/utils/handle-dsql-schema-fields.d.ts
vendored
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
import { DSQL_FieldSchemaType, DSQL_MYSQL_SHOW_COLUMNS_Type } from "../../types";
|
||||||
|
type Param = {
|
||||||
|
dbFullName: string;
|
||||||
|
tableName: string;
|
||||||
|
fields: DSQL_FieldSchemaType[];
|
||||||
|
clone?: boolean;
|
||||||
|
allExistingColumns: DSQL_MYSQL_SHOW_COLUMNS_Type[];
|
||||||
|
};
|
||||||
|
/**
|
||||||
|
* Handle DATASQUIREL schema fields for current table
|
||||||
|
* ===================================================
|
||||||
|
* @description Iterate through each field object and
|
||||||
|
* perform operations
|
||||||
|
*/
|
||||||
|
export default function handleDSQLSchemaFields({ dbFullName, tableName, fields, allExistingColumns, }: Param): Promise<void>;
|
||||||
|
export {};
|
||||||
72
dist/package-shared/shell/utils/handle-dsql-schema-fields.js
vendored
Normal file
72
dist/package-shared/shell/utils/handle-dsql-schema-fields.js
vendored
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
"use strict";
|
||||||
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
||||||
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
||||||
|
return new (P || (P = Promise))(function (resolve, reject) {
|
||||||
|
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
||||||
|
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
||||||
|
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
||||||
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
||||||
|
});
|
||||||
|
};
|
||||||
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
||||||
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
||||||
|
};
|
||||||
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
|
exports.default = handleDSQLSchemaFields;
|
||||||
|
const dbHandler_1 = __importDefault(require("../../functions/backend/dbHandler"));
|
||||||
|
const default_fields_regexp_1 = __importDefault(require("../../functions/dsql/default-fields-regexp"));
|
||||||
|
const generateColumnDescription_1 = __importDefault(require("./generateColumnDescription"));
|
||||||
|
/**
|
||||||
|
* Handle DATASQUIREL schema fields for current table
|
||||||
|
* ===================================================
|
||||||
|
* @description Iterate through each field object and
|
||||||
|
* perform operations
|
||||||
|
*/
|
||||||
|
function handleDSQLSchemaFields(_a) {
|
||||||
|
return __awaiter(this, arguments, void 0, function* ({ dbFullName, tableName, fields, allExistingColumns, }) {
|
||||||
|
let sql = `ALTER TABLE \`${dbFullName}\`.\`${tableName}\``;
|
||||||
|
for (let i = 0; i < fields.length; i++) {
|
||||||
|
const column = fields[i];
|
||||||
|
// const prevColumn = fields[i - 1];
|
||||||
|
// const nextColumn = fields[i + 1];
|
||||||
|
const { fieldName, dataType, foreignKey } = column;
|
||||||
|
if (!fieldName)
|
||||||
|
continue;
|
||||||
|
if (default_fields_regexp_1.default.test(fieldName))
|
||||||
|
continue;
|
||||||
|
let updateText = "";
|
||||||
|
const existingColumnIndex = allExistingColumns === null || allExistingColumns === void 0 ? void 0 : allExistingColumns.findIndex((_column, _index) => _column.Field === fieldName);
|
||||||
|
const existingColumn = existingColumnIndex >= 0
|
||||||
|
? allExistingColumns[existingColumnIndex]
|
||||||
|
: undefined;
|
||||||
|
let { fieldEntryText } = (0, generateColumnDescription_1.default)({
|
||||||
|
columnData: column,
|
||||||
|
});
|
||||||
|
/**
|
||||||
|
* @description Modify Column(Field) if it already exists
|
||||||
|
* in MYSQL database
|
||||||
|
*/
|
||||||
|
if (existingColumn === null || existingColumn === void 0 ? void 0 : existingColumn.Field) {
|
||||||
|
const { Field, Type } = existingColumn;
|
||||||
|
updateText += ` MODIFY COLUMN ${fieldEntryText}`;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
/**
|
||||||
|
* @description Append new column to the end of existing columns
|
||||||
|
*/
|
||||||
|
updateText += ` ADD COLUMN ${fieldEntryText}`;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* @description Pust SQL code snippet to updateTableQueryArray Array
|
||||||
|
* Add a comma(,) to separate from the next snippet
|
||||||
|
*/
|
||||||
|
if (updateText.match(/./)) {
|
||||||
|
sql += " " + updateText + ",";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
const finalSQL = sql.replace(/\,$/, "");
|
||||||
|
const updateTable = yield (0, dbHandler_1.default)({
|
||||||
|
query: finalSQL,
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
18
dist/package-shared/shell/utils/handle-mariadb-existing-columns.d.ts
vendored
Normal file
18
dist/package-shared/shell/utils/handle-mariadb-existing-columns.d.ts
vendored
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
import { DSQL_DatabaseSchemaType, DSQL_FieldSchemaType, DSQL_MYSQL_SHOW_COLUMNS_Type } from "../../types";
|
||||||
|
type Param = {
|
||||||
|
dbFullName: string;
|
||||||
|
tableName: string;
|
||||||
|
fields: DSQL_FieldSchemaType[];
|
||||||
|
dbSchema: DSQL_DatabaseSchemaType;
|
||||||
|
userId?: number | string | null;
|
||||||
|
};
|
||||||
|
/**
|
||||||
|
* Handle MYSQL Columns (Fields)
|
||||||
|
* ===================================================
|
||||||
|
* @description Now handle all fields/columns
|
||||||
|
*/
|
||||||
|
export default function handleMariaDBExistingColumns({ dbFullName, tableName, fields, dbSchema, userId, }: Param): Promise<{
|
||||||
|
upToDateTableFieldsArray: DSQL_FieldSchemaType[];
|
||||||
|
allExistingColumns: DSQL_MYSQL_SHOW_COLUMNS_Type[];
|
||||||
|
}>;
|
||||||
|
export {};
|
||||||
94
dist/package-shared/shell/utils/handle-mariadb-existing-columns.js
vendored
Normal file
94
dist/package-shared/shell/utils/handle-mariadb-existing-columns.js
vendored
Normal file
@ -0,0 +1,94 @@
|
|||||||
|
"use strict";
|
||||||
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
||||||
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
||||||
|
return new (P || (P = Promise))(function (resolve, reject) {
|
||||||
|
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
||||||
|
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
||||||
|
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
||||||
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
||||||
|
});
|
||||||
|
};
|
||||||
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
||||||
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
||||||
|
};
|
||||||
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
|
exports.default = handleMariaDBExistingColumns;
|
||||||
|
const dbHandler_1 = __importDefault(require("../../functions/backend/dbHandler"));
|
||||||
|
const default_fields_regexp_1 = __importDefault(require("../../functions/dsql/default-fields-regexp"));
|
||||||
|
const grab_required_database_schemas_1 = require("../createDbFromSchema/grab-required-database-schemas");
|
||||||
|
const lodash_1 = __importDefault(require("lodash"));
|
||||||
|
/**
|
||||||
|
* Handle MYSQL Columns (Fields)
|
||||||
|
* ===================================================
|
||||||
|
* @description Now handle all fields/columns
|
||||||
|
*/
|
||||||
|
function handleMariaDBExistingColumns(_a) {
|
||||||
|
return __awaiter(this, arguments, void 0, function* ({ dbFullName, tableName, fields, dbSchema, userId, }) {
|
||||||
|
let upToDateTableFieldsArray = lodash_1.default.cloneDeep(fields);
|
||||||
|
let allExistingColumns = (yield (0, dbHandler_1.default)({
|
||||||
|
query: `SHOW COLUMNS FROM \`${dbFullName}\`.\`${tableName}\``,
|
||||||
|
}));
|
||||||
|
/**
|
||||||
|
* @description Iterate through every existing column
|
||||||
|
*/
|
||||||
|
for (let e = 0; e < allExistingColumns.length; e++) {
|
||||||
|
const { Field } = allExistingColumns[e];
|
||||||
|
if (Field.match(default_fields_regexp_1.default))
|
||||||
|
continue;
|
||||||
|
/**
|
||||||
|
* @description This finds out whether the fieldName corresponds with the MSQL Field name
|
||||||
|
* if the fildName doesn't match any MYSQL Field name, the field is deleted.
|
||||||
|
*/
|
||||||
|
let existingEntry = upToDateTableFieldsArray.find((column) => column.fieldName === Field || column.originName === Field);
|
||||||
|
if (!existingEntry) {
|
||||||
|
yield (0, dbHandler_1.default)({
|
||||||
|
query: `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` DROP COLUMN \`${Field}\``,
|
||||||
|
});
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if (existingEntry) {
|
||||||
|
/**
|
||||||
|
* @description Check if Field name has been updated
|
||||||
|
*/
|
||||||
|
if (existingEntry.updatedField && existingEntry.fieldName) {
|
||||||
|
yield (0, dbHandler_1.default)({
|
||||||
|
query: `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` RENAME COLUMN \`${existingEntry.originName}\` TO \`${existingEntry.fieldName}\``,
|
||||||
|
});
|
||||||
|
console.log(`Column Renamed from "${existingEntry.originName}" to "${existingEntry.fieldName}"`);
|
||||||
|
/**
|
||||||
|
* Update Db Schema
|
||||||
|
* ===================================================
|
||||||
|
* @description Update Db Schema after renaming column
|
||||||
|
*/
|
||||||
|
try {
|
||||||
|
const updatedSchemaData = lodash_1.default.cloneDeep(dbSchema);
|
||||||
|
const targetTableIndex = updatedSchemaData.tables.findIndex((table) => table.tableName === tableName);
|
||||||
|
const targetFieldIndex = updatedSchemaData.tables[targetTableIndex].fields.findIndex((field) => field.fieldName === existingEntry.fieldName);
|
||||||
|
delete updatedSchemaData.tables[targetTableIndex].fields[targetFieldIndex]["originName"];
|
||||||
|
delete updatedSchemaData.tables[targetTableIndex].fields[targetFieldIndex]["updatedField"];
|
||||||
|
/**
|
||||||
|
* @description Set New Table Fields Array
|
||||||
|
*/
|
||||||
|
upToDateTableFieldsArray =
|
||||||
|
updatedSchemaData.tables[targetTableIndex].fields;
|
||||||
|
if (userId) {
|
||||||
|
(0, grab_required_database_schemas_1.writeUpdatedDbSchema)({
|
||||||
|
dbSchema: updatedSchemaData,
|
||||||
|
userId,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
allExistingColumns = (yield (0, dbHandler_1.default)({
|
||||||
|
query: `SHOW COLUMNS FROM \`${dbFullName}\`.\`${tableName}\``,
|
||||||
|
}));
|
||||||
|
}
|
||||||
|
catch (error) {
|
||||||
|
console.log("Update table error =>", error.message);
|
||||||
|
}
|
||||||
|
////////////////////////////////////////
|
||||||
|
}
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return { upToDateTableFieldsArray, allExistingColumns };
|
||||||
|
});
|
||||||
|
}
|
||||||
@ -1,13 +1,15 @@
|
|||||||
import { DSQL_ForeignKeyType } from "../../types";
|
import { DSQL_FieldSchemaType } from "../../types";
|
||||||
type Param = {
|
type Param = {
|
||||||
dbFullName: string;
|
dbFullName: string;
|
||||||
tableName: string;
|
tableName: string;
|
||||||
foreignKey: DSQL_ForeignKeyType;
|
fields: DSQL_FieldSchemaType[];
|
||||||
fieldName: string;
|
clone?: boolean;
|
||||||
errorLogs?: any[];
|
|
||||||
};
|
};
|
||||||
/**
|
/**
|
||||||
* # Update table function
|
* Handle MYSQL Foreign Keys
|
||||||
|
* ===================================================
|
||||||
|
* @description Iterate through each datasquirel schema
|
||||||
|
* table index(if available), and perform operations
|
||||||
*/
|
*/
|
||||||
export default function handleTableForeignKey({ dbFullName, tableName, foreignKey, errorLogs, fieldName, }: Param): Promise<void>;
|
export default function handleTableForeignKey({ dbFullName, tableName, fields, clone, }: Param): Promise<void>;
|
||||||
export {};
|
export {};
|
||||||
|
|||||||
@ -15,27 +15,34 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|||||||
exports.default = handleTableForeignKey;
|
exports.default = handleTableForeignKey;
|
||||||
const dbHandler_1 = __importDefault(require("../../functions/backend/dbHandler"));
|
const dbHandler_1 = __importDefault(require("../../functions/backend/dbHandler"));
|
||||||
/**
|
/**
|
||||||
* # Update table function
|
* Handle MYSQL Foreign Keys
|
||||||
|
* ===================================================
|
||||||
|
* @description Iterate through each datasquirel schema
|
||||||
|
* table index(if available), and perform operations
|
||||||
*/
|
*/
|
||||||
function handleTableForeignKey(_a) {
|
function handleTableForeignKey(_a) {
|
||||||
return __awaiter(this, arguments, void 0, function* ({ dbFullName, tableName, foreignKey, errorLogs, fieldName, }) {
|
return __awaiter(this, arguments, void 0, function* ({ dbFullName, tableName, fields, clone, }) {
|
||||||
const { destinationTableName, destinationTableColumnName, cascadeDelete, cascadeUpdate, foreignKeyName, } = foreignKey;
|
let addFkSQL = `ALTER TABLE \`${dbFullName}\`.\`${tableName}\``;
|
||||||
let finalQueryString = `ALTER TABLE \`${dbFullName}\`.\`${tableName}\``;
|
for (let i = 0; i < fields.length; i++) {
|
||||||
finalQueryString += ` ADD CONSTRAINT \`${foreignKeyName}\` FOREIGN KEY (\`${fieldName}\`)`;
|
const { fieldName, foreignKey } = fields[i];
|
||||||
finalQueryString += ` REFERENCES \`${destinationTableName}\`(\`${destinationTableColumnName}\`)`;
|
if (!clone && foreignKey && fieldName) {
|
||||||
if (cascadeDelete)
|
const { destinationTableName, destinationTableColumnName, cascadeDelete, cascadeUpdate, foreignKeyName, } = foreignKey;
|
||||||
finalQueryString += ` ON DELETE CASCADE`;
|
addFkSQL += ` ADD CONSTRAINT \`${foreignKeyName}\` FOREIGN KEY (\`${fieldName}\`)`;
|
||||||
if (cascadeUpdate)
|
addFkSQL += ` REFERENCES \`${destinationTableName}\`(\`${destinationTableColumnName}\`)`;
|
||||||
finalQueryString += ` ON UPDATE CASCADE`;
|
if (cascadeDelete)
|
||||||
// let foreinKeyText = `ADD CONSTRAINT \`${foreignKeyName}\` FOREIGN KEY (\`${destinationTableColumnType}\`) REFERENCES \`${destinationTableName}\`(\`${destinationTableColumnName}\`)${
|
addFkSQL += ` ON DELETE CASCADE`;
|
||||||
// cascadeDelete ? " ON DELETE CASCADE" : ""
|
if (cascadeUpdate)
|
||||||
// }${cascadeUpdate ? " ON UPDATE CASCADE" : ""}`;
|
addFkSQL += ` ON UPDATE CASCADE`;
|
||||||
// let finalQueryString = `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` ${foreinKeyText}`;
|
addFkSQL += `,`;
|
||||||
const addForeignKey = (yield (0, dbHandler_1.default)({
|
}
|
||||||
query: finalQueryString,
|
}
|
||||||
}));
|
const finalAddFKSQL = addFkSQL.endsWith(",")
|
||||||
if (!(addForeignKey === null || addForeignKey === void 0 ? void 0 : addForeignKey.serverStatus)) {
|
? addFkSQL.replace(/\,$/, "")
|
||||||
errorLogs === null || errorLogs === void 0 ? void 0 : errorLogs.push(addForeignKey);
|
: undefined;
|
||||||
|
if (finalAddFKSQL) {
|
||||||
|
const addForeignKey = (yield (0, dbHandler_1.default)({
|
||||||
|
query: finalAddFKSQL,
|
||||||
|
}));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|||||||
17
dist/package-shared/shell/utils/update-table-init.d.ts
vendored
Normal file
17
dist/package-shared/shell/utils/update-table-init.d.ts
vendored
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
import { DSQL_DatabaseSchemaType, DSQL_TableSchemaType } from "../../types";
|
||||||
|
import { DSQL_DATASQUIREL_USER_DATABASES } from "../../types/dsql";
|
||||||
|
type Params = {
|
||||||
|
dbFullName: string;
|
||||||
|
tableName: string;
|
||||||
|
tableSchema: DSQL_TableSchemaType;
|
||||||
|
dbSchema: DSQL_DatabaseSchemaType;
|
||||||
|
recordedDbEntry?: DSQL_DATASQUIREL_USER_DATABASES;
|
||||||
|
isMain?: boolean;
|
||||||
|
};
|
||||||
|
/**
|
||||||
|
* # Update table function
|
||||||
|
*/
|
||||||
|
export default function updateTableInit({ dbFullName, tableName, tableSchema, recordedDbEntry, isMain, }: Params): Promise<{
|
||||||
|
tableID: number | undefined;
|
||||||
|
}>;
|
||||||
|
export {};
|
||||||
136
dist/package-shared/shell/utils/update-table-init.js
vendored
Normal file
136
dist/package-shared/shell/utils/update-table-init.js
vendored
Normal file
@ -0,0 +1,136 @@
|
|||||||
|
"use strict";
|
||||||
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
||||||
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
||||||
|
return new (P || (P = Promise))(function (resolve, reject) {
|
||||||
|
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
||||||
|
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
||||||
|
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
||||||
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
||||||
|
});
|
||||||
|
};
|
||||||
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
||||||
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
||||||
|
};
|
||||||
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
|
exports.default = updateTableInit;
|
||||||
|
const create_table_handle_table_record_1 = __importDefault(require("./create-table-handle-table-record"));
|
||||||
|
const dbHandler_1 = __importDefault(require("../../functions/backend/dbHandler"));
|
||||||
|
/**
|
||||||
|
* # Update table function
|
||||||
|
*/
|
||||||
|
function updateTableInit(_a) {
|
||||||
|
return __awaiter(this, arguments, void 0, function* ({ dbFullName, tableName, tableSchema, recordedDbEntry, isMain, }) {
|
||||||
|
/**
|
||||||
|
* @description Grab Table Record
|
||||||
|
*/
|
||||||
|
if (!recordedDbEntry && !isMain) {
|
||||||
|
throw new Error("Recorded Db entry not found!");
|
||||||
|
}
|
||||||
|
let tableID = yield (0, create_table_handle_table_record_1.default)({
|
||||||
|
recordedDbEntry,
|
||||||
|
tableSchema,
|
||||||
|
update: true,
|
||||||
|
isMain,
|
||||||
|
});
|
||||||
|
if (!tableID && !isMain) {
|
||||||
|
throw new Error("Recorded Table entry not found!");
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* Handle Table Default Collation
|
||||||
|
*
|
||||||
|
* @description Update Column Collation
|
||||||
|
*/
|
||||||
|
if (tableSchema.collation) {
|
||||||
|
try {
|
||||||
|
const existingCollation = (yield (0, dbHandler_1.default)({
|
||||||
|
query: `SHOW TABLE STATUS LIKE '${tableName}'`,
|
||||||
|
config: { database: dbFullName },
|
||||||
|
}));
|
||||||
|
const existingCollationStr = existingCollation === null || existingCollation === void 0 ? void 0 : existingCollation[0].Collation;
|
||||||
|
if (existingCollationStr !== tableSchema.collation) {
|
||||||
|
yield (0, dbHandler_1.default)({
|
||||||
|
query: `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` CONVERT TO CHARACTER SET utf8mb4 COLLATE ${tableSchema.collation}`,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (error) { }
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* Drop All Foreign Keys
|
||||||
|
* ===================================================
|
||||||
|
* @description Find all existing foreign keys and drop
|
||||||
|
* them
|
||||||
|
*/
|
||||||
|
const allForeignKeys = (yield (0, dbHandler_1.default)({
|
||||||
|
query: `SELECT CONSTRAINT_NAME FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS WHERE CONSTRAINT_SCHEMA = '${dbFullName}' AND TABLE_NAME='${tableName}' AND CONSTRAINT_TYPE='FOREIGN KEY'`,
|
||||||
|
}));
|
||||||
|
if (allForeignKeys === null || allForeignKeys === void 0 ? void 0 : allForeignKeys[0]) {
|
||||||
|
let dropFkSQL = `ALTER TABLE \`${dbFullName}\`.\`${tableName}\``;
|
||||||
|
for (let c = 0; c < allForeignKeys.length; c++) {
|
||||||
|
const { CONSTRAINT_NAME } = allForeignKeys[c];
|
||||||
|
if (CONSTRAINT_NAME.match(/PRIMARY/))
|
||||||
|
continue;
|
||||||
|
dropFkSQL += ` DROP FOREIGN KEY \`${CONSTRAINT_NAME}\`,`;
|
||||||
|
}
|
||||||
|
const finalSQL = dropFkSQL.endsWith(",")
|
||||||
|
? dropFkSQL.replace(/\,$/, "")
|
||||||
|
: undefined;
|
||||||
|
if (finalSQL) {
|
||||||
|
yield (0, dbHandler_1.default)({
|
||||||
|
query: finalSQL,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* Drop All Unique Constraints
|
||||||
|
* ===================================================
|
||||||
|
* @description Find all existing unique field constraints
|
||||||
|
* and remove them
|
||||||
|
*/
|
||||||
|
const allUniqueConstraints = (yield (0, dbHandler_1.default)({
|
||||||
|
query: `SELECT CONSTRAINT_NAME FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS WHERE CONSTRAINT_SCHEMA = '${dbFullName}' AND TABLE_NAME='${tableName}' AND CONSTRAINT_TYPE='UNIQUE'`,
|
||||||
|
}));
|
||||||
|
if (allUniqueConstraints === null || allUniqueConstraints === void 0 ? void 0 : allUniqueConstraints[0]) {
|
||||||
|
let dropIndxSQL = `ALTER TABLE \`${dbFullName}\`.\`${tableName}\``;
|
||||||
|
for (let c = 0; c < allUniqueConstraints.length; c++) {
|
||||||
|
const { CONSTRAINT_NAME } = allUniqueConstraints[c];
|
||||||
|
dropIndxSQL += ` DROP INDEX ${CONSTRAINT_NAME},`;
|
||||||
|
}
|
||||||
|
const finalDropIndxSQL = dropIndxSQL.endsWith(",")
|
||||||
|
? dropIndxSQL.replace(/\,$/, "")
|
||||||
|
: undefined;
|
||||||
|
if (finalDropIndxSQL) {
|
||||||
|
yield (0, dbHandler_1.default)({
|
||||||
|
query: finalDropIndxSQL,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* Drop All Indexes
|
||||||
|
* ===================================================
|
||||||
|
* @description Find all existing foreign keys and drop
|
||||||
|
* them
|
||||||
|
*/
|
||||||
|
const allMariadbIndexes = (yield (0, dbHandler_1.default)({
|
||||||
|
query: `SHOW INDEXES FROM \`${dbFullName}\`.\`${tableName}\``,
|
||||||
|
}));
|
||||||
|
if (allMariadbIndexes === null || allMariadbIndexes === void 0 ? void 0 : allMariadbIndexes[0]) {
|
||||||
|
let dropIndxs = `ALTER TABLE \`${dbFullName}\`.\`${tableName}\``;
|
||||||
|
for (let c = 0; c < allMariadbIndexes.length; c++) {
|
||||||
|
const { Key_name } = allMariadbIndexes[c];
|
||||||
|
if (Key_name.match(/PRIMARY/))
|
||||||
|
continue;
|
||||||
|
dropIndxs += ` DROP INDEX \`${Key_name}\`,`;
|
||||||
|
}
|
||||||
|
const finalDropIndxs = dropIndxs.endsWith(",")
|
||||||
|
? dropIndxs.replace(/\,$/, "")
|
||||||
|
: undefined;
|
||||||
|
if (finalDropIndxs) {
|
||||||
|
const dropFkRes = yield (0, dbHandler_1.default)({
|
||||||
|
query: finalDropIndxs,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return { tableID };
|
||||||
|
});
|
||||||
|
}
|
||||||
@ -1,4 +1,4 @@
|
|||||||
import { DSQL_DatabaseSchemaType, DSQL_FieldSchemaType, DSQL_IndexSchemaType, DSQL_TableSchemaType } from "../../types";
|
import { DSQL_DatabaseSchemaType, DSQL_FieldSchemaType, DSQL_IndexSchemaType, DSQL_TableSchemaType, DSQL_UniqueConstraintSchemaType } from "../../types";
|
||||||
import { DSQL_DATASQUIREL_USER_DATABASES } from "../../types/dsql";
|
import { DSQL_DATASQUIREL_USER_DATABASES } from "../../types/dsql";
|
||||||
type Param = {
|
type Param = {
|
||||||
dbFullName: string;
|
dbFullName: string;
|
||||||
@ -8,6 +8,7 @@ type Param = {
|
|||||||
userId?: number | string | null;
|
userId?: number | string | null;
|
||||||
dbSchema: DSQL_DatabaseSchemaType;
|
dbSchema: DSQL_DatabaseSchemaType;
|
||||||
tableIndexes?: DSQL_IndexSchemaType[];
|
tableIndexes?: DSQL_IndexSchemaType[];
|
||||||
|
tableUniqueConstraints?: DSQL_UniqueConstraintSchemaType[];
|
||||||
clone?: boolean;
|
clone?: boolean;
|
||||||
recordedDbEntry?: DSQL_DATASQUIREL_USER_DATABASES;
|
recordedDbEntry?: DSQL_DATASQUIREL_USER_DATABASES;
|
||||||
isMain?: boolean;
|
isMain?: boolean;
|
||||||
@ -15,5 +16,5 @@ type Param = {
|
|||||||
/**
|
/**
|
||||||
* # Update table function
|
* # Update table function
|
||||||
*/
|
*/
|
||||||
export default function updateTable({ dbFullName, tableName, tableFields, userId, dbSchema, tableIndexes, tableSchema, clone, recordedDbEntry, isMain, }: Param): Promise<number | undefined>;
|
export default function updateTable({ dbFullName, tableName, tableFields, userId, dbSchema, tableIndexes, tableSchema, clone, recordedDbEntry, isMain, tableUniqueConstraints, }: Param): Promise<number | undefined>;
|
||||||
export {};
|
export {};
|
||||||
|
|||||||
345
dist/package-shared/shell/utils/updateTable.js
vendored
345
dist/package-shared/shell/utils/updateTable.js
vendored
@ -13,117 +13,72 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|||||||
};
|
};
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
exports.default = updateTable;
|
exports.default = updateTable;
|
||||||
const generateColumnDescription_1 = __importDefault(require("./generateColumnDescription"));
|
|
||||||
const handle_table_foreign_key_1 = __importDefault(require("./handle-table-foreign-key"));
|
|
||||||
const drop_all_foreign_keys_1 = __importDefault(require("./drop-all-foreign-keys"));
|
|
||||||
const create_table_handle_table_record_1 = __importDefault(require("./create-table-handle-table-record"));
|
|
||||||
const default_fields_regexp_1 = __importDefault(require("../../functions/dsql/default-fields-regexp"));
|
|
||||||
const handle_indexes_1 = __importDefault(require("../createDbFromSchema/handle-indexes"));
|
const handle_indexes_1 = __importDefault(require("../createDbFromSchema/handle-indexes"));
|
||||||
const lodash_1 = __importDefault(require("lodash"));
|
const handle_unique_constraints_1 = __importDefault(require("../createDbFromSchema/handle-unique-constraints"));
|
||||||
const grab_required_database_schemas_1 = require("../createDbFromSchema/grab-required-database-schemas");
|
const handle_table_foreign_key_1 = __importDefault(require("./handle-table-foreign-key"));
|
||||||
const normalize_text_1 = __importDefault(require("../../utils/normalize-text"));
|
const handle_dsql_schema_fields_1 = __importDefault(require("./handle-dsql-schema-fields"));
|
||||||
const dbHandler_1 = __importDefault(require("../../functions/backend/dbHandler"));
|
const handle_mariadb_existing_columns_1 = __importDefault(require("./handle-mariadb-existing-columns"));
|
||||||
|
const update_table_init_1 = __importDefault(require("./update-table-init"));
|
||||||
/**
|
/**
|
||||||
* # Update table function
|
* # Update table function
|
||||||
*/
|
*/
|
||||||
function updateTable(_a) {
|
function updateTable(_a) {
|
||||||
return __awaiter(this, arguments, void 0, function* ({ dbFullName, tableName, tableFields, userId, dbSchema, tableIndexes, tableSchema, clone, recordedDbEntry, isMain, }) {
|
return __awaiter(this, arguments, void 0, function* ({ dbFullName, tableName, tableFields, userId, dbSchema, tableIndexes, tableSchema, clone, recordedDbEntry, isMain, tableUniqueConstraints, }) {
|
||||||
/**
|
|
||||||
* Initialize
|
|
||||||
* ==========================================
|
|
||||||
* @description Initial setup
|
|
||||||
*/
|
|
||||||
let errorLogs = [];
|
|
||||||
/**
|
|
||||||
* @description Initialize table info array. This value will be
|
|
||||||
* changing depending on if a field is renamed or not.
|
|
||||||
*/
|
|
||||||
let upToDateTableFieldsArray = lodash_1.default.cloneDeep(tableFields);
|
|
||||||
/**
|
|
||||||
* @type {string[]}
|
|
||||||
* @description Table update query string array
|
|
||||||
*/
|
|
||||||
const updateTableQueryArray = [];
|
|
||||||
/**
|
|
||||||
* @description Push the query initial value
|
|
||||||
*/
|
|
||||||
updateTableQueryArray.push(`ALTER TABLE \`${dbFullName}\`.\`${tableName}\``);
|
|
||||||
/**
|
/**
|
||||||
* @description Grab Table Record
|
* @description Grab Table Record
|
||||||
*/
|
*/
|
||||||
if (!recordedDbEntry && !isMain) {
|
const { tableID } = yield (0, update_table_init_1.default)({
|
||||||
throw new Error("Recorded Db entry not found!");
|
dbFullName,
|
||||||
}
|
dbSchema,
|
||||||
let tableID = yield (0, create_table_handle_table_record_1.default)({
|
tableName,
|
||||||
recordedDbEntry,
|
|
||||||
tableSchema,
|
tableSchema,
|
||||||
update: true,
|
|
||||||
isMain,
|
isMain,
|
||||||
|
recordedDbEntry,
|
||||||
});
|
});
|
||||||
if (!tableID && !isMain) {
|
|
||||||
throw new Error("Recorded Table entry not found!");
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* Handle Table Default Collation
|
|
||||||
*
|
|
||||||
* @description Update Column Collation
|
|
||||||
*/
|
|
||||||
if (tableSchema.collation) {
|
|
||||||
try {
|
|
||||||
const existingCollation = (yield (0, dbHandler_1.default)({
|
|
||||||
query: `SHOW TABLE STATUS LIKE '${tableName}'`,
|
|
||||||
config: { database: dbFullName },
|
|
||||||
}));
|
|
||||||
const existingCollationStr = existingCollation === null || existingCollation === void 0 ? void 0 : existingCollation[0].Collation;
|
|
||||||
if (existingCollationStr !== tableSchema.collation) {
|
|
||||||
yield (0, dbHandler_1.default)({
|
|
||||||
query: `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` CONVERT TO CHARACTER SET utf8mb4 COLLATE ${tableSchema.collation}`,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch (error) { }
|
|
||||||
}
|
|
||||||
/**
|
/**
|
||||||
* Handle Table updates
|
* Handle Table updates
|
||||||
*
|
*
|
||||||
* @description Try to undate table, catch error if anything goes wrong
|
* @description Try to undate table, catch error if anything goes wrong
|
||||||
*/
|
*/
|
||||||
try {
|
try {
|
||||||
|
const { allExistingColumns, upToDateTableFieldsArray } = yield (0, handle_mariadb_existing_columns_1.default)({
|
||||||
|
dbFullName,
|
||||||
|
dbSchema,
|
||||||
|
fields: tableFields,
|
||||||
|
tableName,
|
||||||
|
userId,
|
||||||
|
});
|
||||||
/**
|
/**
|
||||||
* Handle MYSQL Table Indexes
|
* Handle DATASQUIREL schema fields for current table
|
||||||
* ===================================================
|
* ===================================================
|
||||||
* @description Iterate through each table index(if available)
|
* @description Iterate through each field object and
|
||||||
* and perform operations
|
* perform operations
|
||||||
*/
|
*/
|
||||||
const allExistingIndexes = (yield (0, dbHandler_1.default)({
|
yield (0, handle_dsql_schema_fields_1.default)({
|
||||||
query: `SHOW INDEXES FROM \`${dbFullName}\`.\`${tableName}\` WHERE Index_comment LIKE '%schema_index%'`,
|
dbFullName,
|
||||||
}));
|
tableName,
|
||||||
if (allExistingIndexes) {
|
fields: upToDateTableFieldsArray,
|
||||||
for (let f = 0; f < allExistingIndexes.length; f++) {
|
allExistingColumns,
|
||||||
const { Key_name } = allExistingIndexes[f];
|
});
|
||||||
try {
|
/**
|
||||||
const existingKeyInSchema = tableIndexes === null || tableIndexes === void 0 ? void 0 : tableIndexes.find((indexObject) => indexObject.alias === Key_name);
|
* Handle MYSQL Foreign Keys
|
||||||
if (!existingKeyInSchema)
|
* ===================================================
|
||||||
throw new Error(`This Index(${Key_name}) Has been Deleted!`);
|
* @description Iterate through each datasquirel schema
|
||||||
}
|
* table index(if available), and perform operations
|
||||||
catch (error) {
|
*/
|
||||||
/**
|
yield (0, handle_table_foreign_key_1.default)({
|
||||||
* @description Drop Index: This happens when the MYSQL index is not
|
dbFullName,
|
||||||
* present in the datasquirel DB schema
|
fields: upToDateTableFieldsArray,
|
||||||
*/
|
tableName,
|
||||||
yield (0, dbHandler_1.default)({
|
clone,
|
||||||
query: `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` DROP INDEX \`${Key_name}\``,
|
});
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/**
|
/**
|
||||||
* Handle DATASQUIREL Table Indexes
|
* Handle DATASQUIREL Table Indexes
|
||||||
* ===================================================
|
* ===================================================
|
||||||
* @description Iterate through each datasquirel schema
|
* @description Iterate through each datasquirel schema
|
||||||
* table index(if available), and perform operations
|
* table index(if available), and perform operations
|
||||||
*/
|
*/
|
||||||
if (tableIndexes && tableIndexes[0]) {
|
if (tableIndexes === null || tableIndexes === void 0 ? void 0 : tableIndexes[0]) {
|
||||||
(0, handle_indexes_1.default)({
|
(0, handle_indexes_1.default)({
|
||||||
dbFullName,
|
dbFullName,
|
||||||
indexes: tableIndexes,
|
indexes: tableIndexes,
|
||||||
@ -131,226 +86,22 @@ function updateTable(_a) {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
* Handle MYSQL Foreign Keys
|
* Handle DATASQUIREL Table Unique Indexes
|
||||||
* ===================================================
|
* ===================================================
|
||||||
* @description Iterate through each datasquirel schema
|
* @description Iterate through each datasquirel schema
|
||||||
* table index(if available), and perform operations
|
* table unique constraint(if available), and perform operations
|
||||||
*/
|
*/
|
||||||
const allForeignKeys = (yield (0, dbHandler_1.default)({
|
if (tableUniqueConstraints === null || tableUniqueConstraints === void 0 ? void 0 : tableUniqueConstraints[0]) {
|
||||||
query: `SELECT CONSTRAINT_NAME FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS WHERE CONSTRAINT_SCHEMA = '${dbFullName}' AND TABLE_NAME='${tableName}' AND CONSTRAINT_TYPE='FOREIGN KEY'`,
|
(0, handle_unique_constraints_1.default)({
|
||||||
}));
|
dbFullName,
|
||||||
if (allForeignKeys) {
|
tableUniqueConstraints,
|
||||||
for (let c = 0; c < allForeignKeys.length; c++) {
|
tableName,
|
||||||
const { CONSTRAINT_NAME } = allForeignKeys[c];
|
|
||||||
/**
|
|
||||||
* @description Skip if Key is the PRIMARY Key
|
|
||||||
*/
|
|
||||||
if (CONSTRAINT_NAME.match(/PRIMARY/))
|
|
||||||
continue;
|
|
||||||
/**
|
|
||||||
* @description Drop all foreign Keys to avoid MYSQL errors when adding/updating
|
|
||||||
* Foreign keys
|
|
||||||
*/
|
|
||||||
yield (0, dbHandler_1.default)({
|
|
||||||
query: `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` DROP FOREIGN KEY \`${CONSTRAINT_NAME}\``,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* Handle MYSQL Unique Fields
|
|
||||||
* ===================================================
|
|
||||||
* @description Find all existing unique field constraints
|
|
||||||
* and remove them
|
|
||||||
*/
|
|
||||||
const allUniqueConstraints = (yield (0, dbHandler_1.default)({
|
|
||||||
query: (0, normalize_text_1.default)(`SELECT CONSTRAINT_NAME FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS \
|
|
||||||
WHERE CONSTRAINT_SCHEMA = '${dbFullName}' AND TABLE_NAME='${tableName}' AND \
|
|
||||||
CONSTRAINT_TYPE='UNIQUE'`),
|
|
||||||
}));
|
|
||||||
if (allUniqueConstraints) {
|
|
||||||
for (let c = 0; c < allUniqueConstraints.length; c++) {
|
|
||||||
const { CONSTRAINT_NAME } = allUniqueConstraints[c];
|
|
||||||
yield (0, dbHandler_1.default)({
|
|
||||||
query: `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` DROP INDEX \`${CONSTRAINT_NAME}\``,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* Handle MYSQL Columns (Fields)
|
|
||||||
* ===================================================
|
|
||||||
* @description Now handle all fields/columns
|
|
||||||
*/
|
|
||||||
let allExistingColumns = (yield (0, dbHandler_1.default)({
|
|
||||||
query: `SHOW COLUMNS FROM \`${dbFullName}\`.\`${tableName}\``,
|
|
||||||
}));
|
|
||||||
/**
|
|
||||||
* @type {string[]}
|
|
||||||
* @description Updated column names Array
|
|
||||||
*/
|
|
||||||
const updatedColumnsArray = [];
|
|
||||||
/**
|
|
||||||
* @description Iterate through every existing column
|
|
||||||
*/
|
|
||||||
for (let e = 0; e < allExistingColumns.length; e++) {
|
|
||||||
const { Field } = allExistingColumns[e];
|
|
||||||
if (Field.match(default_fields_regexp_1.default))
|
|
||||||
continue;
|
|
||||||
/**
|
|
||||||
* @description This finds out whether the fieldName corresponds with the MSQL Field name
|
|
||||||
* if the fildName doesn't match any MYSQL Field name, the field is deleted.
|
|
||||||
*/
|
|
||||||
let existingEntry = upToDateTableFieldsArray.find((column) => column.fieldName === Field || column.originName === Field);
|
|
||||||
if (existingEntry) {
|
|
||||||
/**
|
|
||||||
* @description Check if Field name has been updated
|
|
||||||
*/
|
|
||||||
if (existingEntry.updatedField && existingEntry.fieldName) {
|
|
||||||
updatedColumnsArray.push(existingEntry.fieldName);
|
|
||||||
yield (0, dbHandler_1.default)({
|
|
||||||
query: `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` RENAME COLUMN \`${existingEntry.originName}\` TO \`${existingEntry.fieldName}\``,
|
|
||||||
});
|
|
||||||
console.log(`Column Renamed from "${existingEntry.originName}" to "${existingEntry.fieldName}"`);
|
|
||||||
/**
|
|
||||||
* Update Db Schema
|
|
||||||
* ===================================================
|
|
||||||
* @description Update Db Schema after renaming column
|
|
||||||
*/
|
|
||||||
try {
|
|
||||||
const updatedSchemaData = lodash_1.default.cloneDeep(dbSchema);
|
|
||||||
const targetTableIndex = updatedSchemaData.tables.findIndex((table) => table.tableName === tableName);
|
|
||||||
const targetFieldIndex = updatedSchemaData.tables[targetTableIndex].fields.findIndex((field) => field.fieldName === existingEntry.fieldName);
|
|
||||||
delete updatedSchemaData.tables[targetTableIndex]
|
|
||||||
.fields[targetFieldIndex]["originName"];
|
|
||||||
delete updatedSchemaData.tables[targetTableIndex]
|
|
||||||
.fields[targetFieldIndex]["updatedField"];
|
|
||||||
/**
|
|
||||||
* @description Set New Table Fields Array
|
|
||||||
*/
|
|
||||||
upToDateTableFieldsArray =
|
|
||||||
updatedSchemaData.tables[targetTableIndex].fields;
|
|
||||||
if (userId) {
|
|
||||||
(0, grab_required_database_schemas_1.writeUpdatedDbSchema)({
|
|
||||||
dbSchema: updatedSchemaData,
|
|
||||||
userId,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
allExistingColumns = (yield (0, dbHandler_1.default)({
|
|
||||||
query: `SHOW COLUMNS FROM \`${dbFullName}\`.\`${tableName}\``,
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
catch (error) {
|
|
||||||
console.log("Update table error =>", error.message);
|
|
||||||
}
|
|
||||||
////////////////////////////////////////
|
|
||||||
}
|
|
||||||
////////////////////////////////////////
|
|
||||||
continue;
|
|
||||||
////////////////////////////////////////
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
yield (0, dbHandler_1.default)({
|
|
||||||
query: `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` DROP COLUMN \`${Field}\``,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* Handle DATASQUIREL schema fields for current table
|
|
||||||
* ===================================================
|
|
||||||
* @description Iterate through each field object and
|
|
||||||
* perform operations
|
|
||||||
*/
|
|
||||||
for (let i = 0; i < upToDateTableFieldsArray.length; i++) {
|
|
||||||
const column = upToDateTableFieldsArray[i];
|
|
||||||
// const prevColumn = upToDateTableFieldsArray[i - 1];
|
|
||||||
// const nextColumn = upToDateTableFieldsArray[i + 1];
|
|
||||||
const { fieldName, dataType, foreignKey } = column;
|
|
||||||
if (!fieldName)
|
|
||||||
continue;
|
|
||||||
if (default_fields_regexp_1.default.test(fieldName))
|
|
||||||
continue;
|
|
||||||
let updateText = "";
|
|
||||||
const existingColumnIndex = allExistingColumns === null || allExistingColumns === void 0 ? void 0 : allExistingColumns.findIndex((_column, _index) => _column.Field === fieldName);
|
|
||||||
const existingColumn = existingColumnIndex >= 0
|
|
||||||
? allExistingColumns[existingColumnIndex]
|
|
||||||
: undefined;
|
|
||||||
let { fieldEntryText } = (0, generateColumnDescription_1.default)({
|
|
||||||
columnData: column,
|
|
||||||
});
|
});
|
||||||
/**
|
|
||||||
* @description Modify Column(Field) if it already exists
|
|
||||||
* in MYSQL database
|
|
||||||
*/
|
|
||||||
if (existingColumn === null || existingColumn === void 0 ? void 0 : existingColumn.Field) {
|
|
||||||
const { Field, Type } = existingColumn;
|
|
||||||
updateText += `MODIFY COLUMN ${fieldEntryText}`;
|
|
||||||
// if (
|
|
||||||
// Field === fieldName &&
|
|
||||||
// dataType?.toUpperCase() === Type.toUpperCase()
|
|
||||||
// ) {
|
|
||||||
// } else {
|
|
||||||
// updateText += `MODIFY COLUMN ${fieldEntryText}`;
|
|
||||||
// }
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
/**
|
|
||||||
* @description Append new column to the end of existing columns
|
|
||||||
*/
|
|
||||||
updateText += `ADD COLUMN ${fieldEntryText}`;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* @description Pust SQL code snippet to updateTableQueryArray Array
|
|
||||||
* Add a comma(,) to separate from the next snippet
|
|
||||||
*/
|
|
||||||
if (updateText.match(/./)) {
|
|
||||||
updateTableQueryArray.push(updateText + ",");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
/**
|
|
||||||
* @description Construct final SQL query by combning all SQL snippets in
|
|
||||||
* updateTableQueryArray Arry, and trimming the final comma(,)
|
|
||||||
*/
|
|
||||||
const updateTableQuery = updateTableQueryArray
|
|
||||||
.filter((q) => Boolean(q.match(/./)))
|
|
||||||
.join(" ")
|
|
||||||
.replace(/,$/, "");
|
|
||||||
////////////////////////////////////////
|
|
||||||
/**
|
|
||||||
* @description Check if SQL snippets array has more than 1 entries
|
|
||||||
* This is because 1 entry means "ALTER TABLE table_name" only, without any
|
|
||||||
* Alter directives like "ADD COLUMN" or "MODIFY COLUMN"
|
|
||||||
*/
|
|
||||||
if (updateTableQueryArray.length > 1) {
|
|
||||||
const updateTable = yield (0, dbHandler_1.default)({
|
|
||||||
query: updateTableQuery,
|
|
||||||
});
|
|
||||||
/**
|
|
||||||
* # Handle Foreign Keys
|
|
||||||
*/
|
|
||||||
yield (0, drop_all_foreign_keys_1.default)({ dbFullName, tableName });
|
|
||||||
for (let i = 0; i < upToDateTableFieldsArray.length; i++) {
|
|
||||||
const { fieldName, foreignKey } = upToDateTableFieldsArray[i];
|
|
||||||
if (!clone && foreignKey && fieldName) {
|
|
||||||
yield (0, handle_table_foreign_key_1.default)({
|
|
||||||
dbFullName,
|
|
||||||
errorLogs,
|
|
||||||
foreignKey,
|
|
||||||
fieldName,
|
|
||||||
tableName,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
/**
|
|
||||||
* @description If only 1 SQL snippet is left in updateTableQueryArray, this
|
|
||||||
* means that no updates have been made to the table
|
|
||||||
*/
|
|
||||||
}
|
|
||||||
return tableID;
|
|
||||||
}
|
}
|
||||||
catch (error) {
|
catch (error) {
|
||||||
console.log('Error in "updateTable" shell function =>', error.message);
|
console.log('Error in "updateTable" shell function =>', error.message);
|
||||||
return tableID;
|
|
||||||
}
|
}
|
||||||
|
return tableID;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|||||||
59
dist/package-shared/types/index.d.ts
vendored
59
dist/package-shared/types/index.d.ts
vendored
@ -6,6 +6,7 @@ import type DataTypes from "../data/data-types";
|
|||||||
import type { IncomingMessage, ServerResponse } from "http";
|
import type { IncomingMessage, ServerResponse } from "http";
|
||||||
import type { CookieNames } from "../dict/cookie-names";
|
import type { CookieNames } from "../dict/cookie-names";
|
||||||
import { ConnectionConfig } from "mariadb";
|
import { ConnectionConfig } from "mariadb";
|
||||||
|
import { DbContextsArray } from "../functions/backend/db/runQuery";
|
||||||
export type DSQL_DatabaseFullName = string;
|
export type DSQL_DatabaseFullName = string;
|
||||||
export type DSQL_DATASQUIREL_USER_BACKUPS_JOIN = DSQL_DATASQUIREL_BACKUPS & {
|
export type DSQL_DATASQUIREL_USER_BACKUPS_JOIN = DSQL_DATASQUIREL_BACKUPS & {
|
||||||
[k in (typeof UserSelectFields)[number]["alias"]]?: string;
|
[k in (typeof UserSelectFields)[number]["alias"]]?: string;
|
||||||
@ -51,6 +52,7 @@ export interface DSQL_TableSchemaType {
|
|||||||
tableDescription?: string;
|
tableDescription?: string;
|
||||||
fields: DSQL_FieldSchemaType[];
|
fields: DSQL_FieldSchemaType[];
|
||||||
indexes?: DSQL_IndexSchemaType[];
|
indexes?: DSQL_IndexSchemaType[];
|
||||||
|
uniqueConstraints?: DSQL_UniqueConstraintSchemaType[];
|
||||||
childrenTables?: DSQL_ChildrenTablesType[];
|
childrenTables?: DSQL_ChildrenTablesType[];
|
||||||
childTable?: boolean;
|
childTable?: boolean;
|
||||||
updateData?: boolean;
|
updateData?: boolean;
|
||||||
@ -144,6 +146,15 @@ export interface DSQL_IndexSchemaType {
|
|||||||
alias?: string;
|
alias?: string;
|
||||||
newTempIndex?: boolean;
|
newTempIndex?: boolean;
|
||||||
}
|
}
|
||||||
|
export interface DSQL_UniqueConstraintSchemaType {
|
||||||
|
id?: string | number;
|
||||||
|
constraintName?: string;
|
||||||
|
alias?: string;
|
||||||
|
constraintTableFields?: DSQL_UniqueConstraintFieldType[];
|
||||||
|
}
|
||||||
|
export interface DSQL_UniqueConstraintFieldType {
|
||||||
|
value: string;
|
||||||
|
}
|
||||||
export interface DSQL_IndexTableFieldType {
|
export interface DSQL_IndexTableFieldType {
|
||||||
value: string;
|
value: string;
|
||||||
dataType: string;
|
dataType: string;
|
||||||
@ -166,6 +177,21 @@ export interface DSQL_MYSQL_SHOW_COLUMNS_Type {
|
|||||||
Default: string;
|
Default: string;
|
||||||
Extra: string;
|
Extra: string;
|
||||||
}
|
}
|
||||||
|
export interface DSQL_MARIADB_SHOW_INDEXES_TYPE {
|
||||||
|
Table: string;
|
||||||
|
Non_unique: 0 | 1;
|
||||||
|
Key_name: string;
|
||||||
|
Seq_in_index: number;
|
||||||
|
Column_name: string;
|
||||||
|
Collation: string;
|
||||||
|
Cardinality: number;
|
||||||
|
Sub_part?: string;
|
||||||
|
Packed?: string;
|
||||||
|
Index_type?: "BTREE";
|
||||||
|
Comment?: string;
|
||||||
|
Index_comment?: string;
|
||||||
|
Ignored?: "YES" | "NO";
|
||||||
|
}
|
||||||
export interface DSQL_MYSQL_FOREIGN_KEYS_Type {
|
export interface DSQL_MYSQL_FOREIGN_KEYS_Type {
|
||||||
CONSTRAINT_NAME: string;
|
CONSTRAINT_NAME: string;
|
||||||
CONSTRAINT_SCHEMA: string;
|
CONSTRAINT_SCHEMA: string;
|
||||||
@ -1314,6 +1340,7 @@ export type DsqlCrudParam<T extends {
|
|||||||
dbName?: string;
|
dbName?: string;
|
||||||
tableSchema?: DSQL_TableSchemaType;
|
tableSchema?: DSQL_TableSchemaType;
|
||||||
dbConfig?: ConnectionConfig;
|
dbConfig?: ConnectionConfig;
|
||||||
|
onDuplicate?: AddDbEntryParamOnDuplicate;
|
||||||
};
|
};
|
||||||
export type DsqlCrudParamWhereClause = {
|
export type DsqlCrudParamWhereClause = {
|
||||||
clause: string;
|
clause: string;
|
||||||
@ -1594,11 +1621,13 @@ export type MediaUploadDataType = ImageObjectType & FileObjectType & {
|
|||||||
export declare const ImageMimeTypes: (keyof sharp.FormatEnum)[];
|
export declare const ImageMimeTypes: (keyof sharp.FormatEnum)[];
|
||||||
export declare const VideoMimeTypes: readonly ["mp4", "wav"];
|
export declare const VideoMimeTypes: readonly ["mp4", "wav"];
|
||||||
export declare const FileMimeTypes: readonly [...(keyof sharp.FormatEnum)[], "mp4", "wav", "pdf", "csv", "json", "sql", "xlsx", "txt", "zip", "tar.xz", "xz", "yaml", "yml", "sh", "jsx", "js", "tsx", "ts", "html", "css", "md"];
|
export declare const FileMimeTypes: readonly [...(keyof sharp.FormatEnum)[], "mp4", "wav", "pdf", "csv", "json", "sql", "xlsx", "txt", "zip", "tar.xz", "xz", "yaml", "yml", "sh", "jsx", "js", "tsx", "ts", "html", "css", "md"];
|
||||||
export declare const CurrentlyEditedFieldActions: readonly ["edit-field", "edit-index", "delete-field", "delete-index", "new-field", "new-index", "move-up", "move-down", "complete"];
|
export declare const CurrentlyEditedFieldActions: readonly ["edit-field", "edit-index", "edit-unique-constraint", "delete-field", "delete-index", "delete-unique-constraint", "new-field", "new-index", "new-unique-constraint", "move-up", "move-down", "complete"];
|
||||||
export type CurrentlyEditedTableSchemaType = {
|
export type CurrentlyEditedTableSchemaType = {
|
||||||
action: (typeof CurrentlyEditedFieldActions)[number];
|
action: (typeof CurrentlyEditedFieldActions)[number];
|
||||||
field?: DSQL_FieldSchemaType;
|
field?: DSQL_FieldSchemaType;
|
||||||
fieldIndex?: number;
|
fieldIndex?: number;
|
||||||
|
uniqueConstraint?: DSQL_UniqueConstraintSchemaType;
|
||||||
|
uniqueConstraintIndex?: number;
|
||||||
index?: DSQL_IndexSchemaType;
|
index?: DSQL_IndexSchemaType;
|
||||||
indexIndex?: number;
|
indexIndex?: number;
|
||||||
spliceIndex?: number;
|
spliceIndex?: number;
|
||||||
@ -2327,3 +2356,31 @@ export type DSQLFetchApiOptions<T extends {
|
|||||||
csrfKey?: string;
|
csrfKey?: string;
|
||||||
fetchOptions?: RequestInit;
|
fetchOptions?: RequestInit;
|
||||||
};
|
};
|
||||||
|
export type AddDbEntryParam<T extends {
|
||||||
|
[k: string]: any;
|
||||||
|
} = any, K extends string = string> = {
|
||||||
|
dbContext?: (typeof DbContextsArray)[number];
|
||||||
|
paradigm?: "Read Only" | "Full Access";
|
||||||
|
dbFullName?: string;
|
||||||
|
tableName: K;
|
||||||
|
data?: T;
|
||||||
|
batchData?: T[];
|
||||||
|
tableSchema?: DSQL_TableSchemaType;
|
||||||
|
duplicateColumnName?: keyof T;
|
||||||
|
duplicateColumnValue?: string | number;
|
||||||
|
/**
|
||||||
|
* Update Entry if a duplicate is found.
|
||||||
|
* Requires `duplicateColumnName` and `duplicateColumnValue` parameters
|
||||||
|
*/
|
||||||
|
update?: boolean;
|
||||||
|
encryptionKey?: string;
|
||||||
|
encryptionSalt?: string;
|
||||||
|
forceLocal?: boolean;
|
||||||
|
debug?: boolean;
|
||||||
|
dbConfig?: ConnectionConfig;
|
||||||
|
onDuplicate?: AddDbEntryParamOnDuplicate;
|
||||||
|
};
|
||||||
|
export type AddDbEntryParamOnDuplicate = {
|
||||||
|
sql: string;
|
||||||
|
values?: string[];
|
||||||
|
};
|
||||||
|
|||||||
3
dist/package-shared/types/index.js
vendored
3
dist/package-shared/types/index.js
vendored
@ -177,10 +177,13 @@ exports.FileMimeTypes = [
|
|||||||
exports.CurrentlyEditedFieldActions = [
|
exports.CurrentlyEditedFieldActions = [
|
||||||
"edit-field",
|
"edit-field",
|
||||||
"edit-index",
|
"edit-index",
|
||||||
|
"edit-unique-constraint",
|
||||||
"delete-field",
|
"delete-field",
|
||||||
"delete-index",
|
"delete-index",
|
||||||
|
"delete-unique-constraint",
|
||||||
"new-field",
|
"new-field",
|
||||||
"new-index",
|
"new-index",
|
||||||
|
"new-unique-constraint",
|
||||||
"move-up",
|
"move-up",
|
||||||
"move-down",
|
"move-down",
|
||||||
"complete",
|
"complete",
|
||||||
|
|||||||
@ -24,7 +24,7 @@ const deleteDbEntry_1 = __importDefault(require("../../functions/backend/db/dele
|
|||||||
function dsqlCrud(params) {
|
function dsqlCrud(params) {
|
||||||
return __awaiter(this, void 0, void 0, function* () {
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
var _a;
|
var _a;
|
||||||
const { action, data, table, targetValue, sanitize, targetField, targetId, dbFullName, deleteData, batchData, deleteKeyValues, debug, tableSchema, deleteKeyValuesOperator, dbConfig, query, } = params;
|
const { action, data, table, targetValue, sanitize, targetField, targetId, dbFullName, deleteData, batchData, deleteKeyValues, debug, tableSchema, deleteKeyValuesOperator, dbConfig, query, onDuplicate, } = params;
|
||||||
const finalData = (sanitize ? sanitize({ data }) : data);
|
const finalData = (sanitize ? sanitize({ data }) : data);
|
||||||
const finalBatchData = (sanitize ? sanitize({ batchData }) : batchData);
|
const finalBatchData = (sanitize ? sanitize({ batchData }) : batchData);
|
||||||
const queryObject = query
|
const queryObject = query
|
||||||
@ -46,8 +46,6 @@ function dsqlCrud(params) {
|
|||||||
switch (action) {
|
switch (action) {
|
||||||
case "get":
|
case "get":
|
||||||
return yield (0, crud_get_1.default)(params);
|
return yield (0, crud_get_1.default)(params);
|
||||||
// case "batch-get":
|
|
||||||
// return await dsqlCrudBatchGet(params);
|
|
||||||
case "insert":
|
case "insert":
|
||||||
const INSERT_RESULT = yield (0, addDbEntry_1.default)({
|
const INSERT_RESULT = yield (0, addDbEntry_1.default)({
|
||||||
data: finalData,
|
data: finalData,
|
||||||
@ -57,6 +55,7 @@ function dsqlCrud(params) {
|
|||||||
debug,
|
debug,
|
||||||
tableSchema,
|
tableSchema,
|
||||||
dbConfig,
|
dbConfig,
|
||||||
|
onDuplicate,
|
||||||
});
|
});
|
||||||
return INSERT_RESULT;
|
return INSERT_RESULT;
|
||||||
case "update":
|
case "update":
|
||||||
|
|||||||
@ -45,6 +45,9 @@ function default_1({ currentDbSchema, currentTableSchema, currentTableSchemaInde
|
|||||||
if (targetChildTableParentDatabaseTable === null || targetChildTableParentDatabaseTable === void 0 ? void 0 : targetChildTableParentDatabaseTable.childTable) {
|
if (targetChildTableParentDatabaseTable === null || targetChildTableParentDatabaseTable === void 0 ? void 0 : targetChildTableParentDatabaseTable.childTable) {
|
||||||
targetChildTableParentDatabase.tables[targetChildTableParentDatabaseTableIndex].fields = [...currentTableSchema.fields];
|
targetChildTableParentDatabase.tables[targetChildTableParentDatabaseTableIndex].fields = [...currentTableSchema.fields];
|
||||||
targetChildTableParentDatabase.tables[targetChildTableParentDatabaseTableIndex].indexes = [...(currentTableSchema.indexes || [])];
|
targetChildTableParentDatabase.tables[targetChildTableParentDatabaseTableIndex].indexes = [...(currentTableSchema.indexes || [])];
|
||||||
|
targetChildTableParentDatabase.tables[targetChildTableParentDatabaseTableIndex].uniqueConstraints = [
|
||||||
|
...(currentTableSchema.uniqueConstraints || []),
|
||||||
|
];
|
||||||
(0, grab_required_database_schemas_1.writeUpdatedDbSchema)({
|
(0, grab_required_database_schemas_1.writeUpdatedDbSchema)({
|
||||||
dbSchema: targetChildTableParentDatabase,
|
dbSchema: targetChildTableParentDatabase,
|
||||||
userId,
|
userId,
|
||||||
@ -133,6 +136,7 @@ function default_1({ currentDbSchema, currentTableSchema, currentTableSchemaInde
|
|||||||
targetParentDatabaseTable.fields;
|
targetParentDatabaseTable.fields;
|
||||||
newCurrentDbSchema.tables[currentTableSchemaIndex].indexes =
|
newCurrentDbSchema.tables[currentTableSchemaIndex].indexes =
|
||||||
targetParentDatabaseTable.indexes;
|
targetParentDatabaseTable.indexes;
|
||||||
|
newCurrentDbSchema.tables[currentTableSchemaIndex].uniqueConstraints = targetParentDatabaseTable.uniqueConstraints;
|
||||||
(0, grab_required_database_schemas_1.writeUpdatedDbSchema)({ dbSchema: targetParentDatabase, userId });
|
(0, grab_required_database_schemas_1.writeUpdatedDbSchema)({ dbSchema: targetParentDatabase, userId });
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,5 +1,5 @@
|
|||||||
type Param = {
|
type Param = {
|
||||||
type: "foreign_key" | "index" | "user";
|
type: "foreign_key" | "index" | "user" | "unique_constraint";
|
||||||
userId?: string | number;
|
userId?: string | number;
|
||||||
addDate?: boolean;
|
addDate?: boolean;
|
||||||
};
|
};
|
||||||
|
|||||||
@ -7,6 +7,8 @@ exports.default = grabSQLKeyName;
|
|||||||
*/
|
*/
|
||||||
function grabSQLKeyName({ type, userId, addDate }) {
|
function grabSQLKeyName({ type, userId, addDate }) {
|
||||||
let prefixParadigm = (() => {
|
let prefixParadigm = (() => {
|
||||||
|
if (type == "unique_constraint")
|
||||||
|
return "unq";
|
||||||
if (type == "foreign_key")
|
if (type == "foreign_key")
|
||||||
return "fk";
|
return "fk";
|
||||||
if (type == "index")
|
if (type == "index")
|
||||||
@ -15,12 +17,14 @@ function grabSQLKeyName({ type, userId, addDate }) {
|
|||||||
return "user";
|
return "user";
|
||||||
return null;
|
return null;
|
||||||
})();
|
})();
|
||||||
|
const uuid = crypto.randomUUID();
|
||||||
|
const uidPrefx = uuid.split("-")[0];
|
||||||
let key = `dsql`;
|
let key = `dsql`;
|
||||||
if (prefixParadigm)
|
if (prefixParadigm)
|
||||||
key += `_${prefixParadigm}`;
|
key += `_${prefixParadigm}`;
|
||||||
if (userId)
|
if (userId)
|
||||||
key += `_${userId}`;
|
key += `_${userId}`;
|
||||||
if (addDate)
|
if (addDate)
|
||||||
key += `_${Date.now()}`;
|
key += `_${uidPrefx}`;
|
||||||
return key;
|
return key;
|
||||||
}
|
}
|
||||||
|
|||||||
20
dist/package-shared/utils/parse-env.d.ts
vendored
20
dist/package-shared/utils/parse-env.d.ts
vendored
@ -1,5 +1,15 @@
|
|||||||
export default function parseEnv(
|
export default function parseEnv(
|
||||||
/** The file path to the env. Eg. /app/.env */ envFile: string): {
|
/** The file path to the env. Eg. /app/.env */ envFile: string): {
|
||||||
|
DSQL_APP_DIR: string | undefined;
|
||||||
|
DSQL_DATA_DIR: string | undefined;
|
||||||
|
DSQL_USER_DB_PREFIX: string | undefined;
|
||||||
|
DSQL_USER_ID: string | undefined;
|
||||||
|
DSQL_DB_NAME: string | undefined;
|
||||||
|
DSQL_DB_HOST: string | undefined;
|
||||||
|
DSQL_DB_USERNAME: string | undefined;
|
||||||
|
DSQL_DB_PASSWORD: string | undefined;
|
||||||
|
DSQL_ENCRYPTION_PASSWORD: string | undefined;
|
||||||
|
DSQL_ENCRYPTION_SALT: string | undefined;
|
||||||
DSQL_HOST: string | undefined;
|
DSQL_HOST: string | undefined;
|
||||||
NEXT_PUBLIC_DSQL_HOST: string | undefined;
|
NEXT_PUBLIC_DSQL_HOST: string | undefined;
|
||||||
DSQL_STATIC_HOST: string | undefined;
|
DSQL_STATIC_HOST: string | undefined;
|
||||||
@ -13,19 +23,14 @@ export default function parseEnv(
|
|||||||
NEXT_PUBLIC_DSQL_REMOTE_SQL_HOST: string | undefined;
|
NEXT_PUBLIC_DSQL_REMOTE_SQL_HOST: string | undefined;
|
||||||
DSQL_DB_TARGET_IP_ADDRESS: string | undefined;
|
DSQL_DB_TARGET_IP_ADDRESS: string | undefined;
|
||||||
NEXT_PUBLIC_VERSION: string | undefined;
|
NEXT_PUBLIC_VERSION: string | undefined;
|
||||||
DSQL_USER_DB_PREFIX: string | undefined;
|
|
||||||
DSQL_USER_DELEGATED_DB_COOKIE_PREFIX: string | undefined;
|
DSQL_USER_DELEGATED_DB_COOKIE_PREFIX: string | undefined;
|
||||||
DSQL_NETWORK_IP_PREFIX: string | undefined;
|
DSQL_NETWORK_IP_PREFIX: string | undefined;
|
||||||
DSQL_NETWORK_GATEWAY: string | undefined;
|
DSQL_NETWORK_GATEWAY: string | undefined;
|
||||||
DSQL_NETWORK_SUBNET: string | undefined;
|
DSQL_NETWORK_SUBNET: string | undefined;
|
||||||
DSQL_MARIADB_MASTER_HOST: string | undefined;
|
DSQL_MARIADB_MASTER_HOST: string | undefined;
|
||||||
DSQL_DB_HOST: string | undefined;
|
|
||||||
DSQL_WEB_APP_HOST: string | undefined;
|
DSQL_WEB_APP_HOST: string | undefined;
|
||||||
DSQL_DB_USERNAME: string | undefined;
|
|
||||||
DSQL_DB_PASSWORD: string | undefined;
|
|
||||||
DSQL_MARIADB_ROOT_PASSWORD: string | undefined;
|
DSQL_MARIADB_ROOT_PASSWORD: string | undefined;
|
||||||
DSQL_REPLICATION_USER_PASSWORD: string | undefined;
|
DSQL_REPLICATION_USER_PASSWORD: string | undefined;
|
||||||
DSQL_DB_NAME: string | undefined;
|
|
||||||
DSQL_MARIADB_REPLICATION_PASSWORD: string | undefined;
|
DSQL_MARIADB_REPLICATION_PASSWORD: string | undefined;
|
||||||
DSQL_MAXSCALE_PASSWORD: string | undefined;
|
DSQL_MAXSCALE_PASSWORD: string | undefined;
|
||||||
DSQL_DB_READ_ONLY_USERNAME: string | undefined;
|
DSQL_DB_READ_ONLY_USERNAME: string | undefined;
|
||||||
@ -33,8 +38,6 @@ export default function parseEnv(
|
|||||||
DSQL_DB_FULL_ACCESS_USERNAME: string | undefined;
|
DSQL_DB_FULL_ACCESS_USERNAME: string | undefined;
|
||||||
DSQL_DB_FULL_ACCESS_PASSWORD: string | undefined;
|
DSQL_DB_FULL_ACCESS_PASSWORD: string | undefined;
|
||||||
DSQL_DB_EXPOSED_PORT: string | undefined;
|
DSQL_DB_EXPOSED_PORT: string | undefined;
|
||||||
DSQL_ENCRYPTION_PASSWORD: string | undefined;
|
|
||||||
DSQL_ENCRYPTION_SALT: string | undefined;
|
|
||||||
DSQL_SU_USER_ID: string | undefined;
|
DSQL_SU_USER_ID: string | undefined;
|
||||||
DSQL_SU_USER_UUID: string | undefined;
|
DSQL_SU_USER_UUID: string | undefined;
|
||||||
DSQL_SU_EMAIL: string | undefined;
|
DSQL_SU_EMAIL: string | undefined;
|
||||||
@ -47,7 +50,6 @@ export default function parseEnv(
|
|||||||
DSQL_MAIL_PASSWORD: string | undefined;
|
DSQL_MAIL_PASSWORD: string | undefined;
|
||||||
DSQL_TINY_MCE_API_KEY: string | undefined;
|
DSQL_TINY_MCE_API_KEY: string | undefined;
|
||||||
DSQL_GITHUB_ID: string | undefined;
|
DSQL_GITHUB_ID: string | undefined;
|
||||||
DSQL_USER_ID: string | undefined;
|
|
||||||
DSQL_GITHUB_SECRET: string | undefined;
|
DSQL_GITHUB_SECRET: string | undefined;
|
||||||
DSQL_GITHUB_WEBHOOK_SECRET: string | undefined;
|
DSQL_GITHUB_WEBHOOK_SECRET: string | undefined;
|
||||||
DSQL_GITHUB_WEBHOOK_URL: string | undefined;
|
DSQL_GITHUB_WEBHOOK_URL: string | undefined;
|
||||||
@ -62,8 +64,6 @@ export default function parseEnv(
|
|||||||
DSQL_VOLUME_DB_SSL: string | undefined;
|
DSQL_VOLUME_DB_SSL: string | undefined;
|
||||||
DSQL_USER_LOGIN_KEYS_PATH: string | undefined;
|
DSQL_USER_LOGIN_KEYS_PATH: string | undefined;
|
||||||
DSQL_API_KEYS_PATH: string | undefined;
|
DSQL_API_KEYS_PATH: string | undefined;
|
||||||
DSQL_APP_DIR: string | undefined;
|
|
||||||
DSQL_DATA_DIR: string | undefined;
|
|
||||||
DSQL_CONTACT_EMAIL: string | undefined;
|
DSQL_CONTACT_EMAIL: string | undefined;
|
||||||
DSQL_SSL_DIR: string | undefined;
|
DSQL_SSL_DIR: string | undefined;
|
||||||
DSQL_DEPLOYMENT_NAME: string | undefined;
|
DSQL_DEPLOYMENT_NAME: string | undefined;
|
||||||
|
|||||||
5
package-shared/data/app-data.ts
Normal file
5
package-shared/data/app-data.ts
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
const AppData = {
|
||||||
|
UniqueConstraintComment: `dsql_schema_unique_constraint`,
|
||||||
|
IndexComment: `dsql_schema_index`,
|
||||||
|
} as const;
|
||||||
|
export default AppData;
|
||||||
@ -89,6 +89,7 @@ export default async function apiPost({
|
|||||||
delete clonedTargetTable.childrenTables;
|
delete clonedTargetTable.childrenTables;
|
||||||
delete clonedTargetTable.updateData;
|
delete clonedTargetTable.updateData;
|
||||||
delete clonedTargetTable.indexes;
|
delete clonedTargetTable.indexes;
|
||||||
|
delete clonedTargetTable.uniqueConstraints;
|
||||||
|
|
||||||
tableSchema = clonedTargetTable;
|
tableSchema = clonedTargetTable;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -3,41 +3,14 @@ import updateDbEntry from "./updateDbEntry";
|
|||||||
import _ from "lodash";
|
import _ from "lodash";
|
||||||
import connDbHandler from "../../../utils/db/conn-db-handler";
|
import connDbHandler from "../../../utils/db/conn-db-handler";
|
||||||
import checkIfIsMaster from "../../../utils/check-if-is-master";
|
import checkIfIsMaster from "../../../utils/check-if-is-master";
|
||||||
import { DbContextsArray } from "./runQuery";
|
|
||||||
import debugLog from "../../../utils/logging/debug-log";
|
import debugLog from "../../../utils/logging/debug-log";
|
||||||
import {
|
import {
|
||||||
|
AddDbEntryParam,
|
||||||
APIResponseObject,
|
APIResponseObject,
|
||||||
DSQL_TableSchemaType,
|
|
||||||
PostInsertReturn,
|
PostInsertReturn,
|
||||||
} from "../../../types";
|
} from "../../../types";
|
||||||
import purgeDefaultFields from "../../../utils/purge-default-fields";
|
import purgeDefaultFields from "../../../utils/purge-default-fields";
|
||||||
import grabParsedValue from "./grab-parsed-value";
|
import grabParsedValue from "./grab-parsed-value";
|
||||||
import { ConnectionConfig } from "mariadb";
|
|
||||||
|
|
||||||
export type AddDbEntryParam<
|
|
||||||
T extends { [k: string]: any } = any,
|
|
||||||
K extends string = string
|
|
||||||
> = {
|
|
||||||
dbContext?: (typeof DbContextsArray)[number];
|
|
||||||
paradigm?: "Read Only" | "Full Access";
|
|
||||||
dbFullName?: string;
|
|
||||||
tableName: K;
|
|
||||||
data?: T;
|
|
||||||
batchData?: T[];
|
|
||||||
tableSchema?: DSQL_TableSchemaType;
|
|
||||||
duplicateColumnName?: keyof T;
|
|
||||||
duplicateColumnValue?: string | number;
|
|
||||||
/**
|
|
||||||
* Update Entry if a duplicate is found.
|
|
||||||
* Requires `duplicateColumnName` and `duplicateColumnValue` parameters
|
|
||||||
*/
|
|
||||||
update?: boolean;
|
|
||||||
encryptionKey?: string;
|
|
||||||
encryptionSalt?: string;
|
|
||||||
forceLocal?: boolean;
|
|
||||||
debug?: boolean;
|
|
||||||
dbConfig?: ConnectionConfig;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Add a db Entry Function
|
* Add a db Entry Function
|
||||||
@ -61,6 +34,7 @@ export default async function addDbEntry<
|
|||||||
forceLocal,
|
forceLocal,
|
||||||
debug,
|
debug,
|
||||||
dbConfig,
|
dbConfig,
|
||||||
|
onDuplicate,
|
||||||
}: AddDbEntryParam<T, K>): Promise<APIResponseObject<PostInsertReturn>> {
|
}: AddDbEntryParam<T, K>): Promise<APIResponseObject<PostInsertReturn>> {
|
||||||
const isMaster = forceLocal
|
const isMaster = forceLocal
|
||||||
? true
|
? true
|
||||||
@ -205,7 +179,7 @@ export default async function addDbEntry<
|
|||||||
const { insertKeysArray, insertValuesArray, queryValuesArray } =
|
const { insertKeysArray, insertValuesArray, queryValuesArray } =
|
||||||
generateQuery(newData);
|
generateQuery(newData);
|
||||||
|
|
||||||
const query = `INSERT INTO ${
|
let query = `INSERT INTO ${
|
||||||
isMaster && !dbFullName ? "" : `\`${dbFullName}\`.`
|
isMaster && !dbFullName ? "" : `\`${dbFullName}\`.`
|
||||||
}\`${tableName}\` (${insertKeysArray.join(
|
}\`${tableName}\` (${insertKeysArray.join(
|
||||||
","
|
","
|
||||||
@ -213,6 +187,13 @@ export default async function addDbEntry<
|
|||||||
|
|
||||||
const finalQueryValues = grabFinalQueryValuesArr(queryValuesArray);
|
const finalQueryValues = grabFinalQueryValuesArr(queryValuesArray);
|
||||||
|
|
||||||
|
if (onDuplicate) {
|
||||||
|
query += ` ON DUPLICATE KEY ${onDuplicate.sql}`;
|
||||||
|
if (onDuplicate.values) {
|
||||||
|
finalQueryValues.push(...onDuplicate.values);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
const newInsert = await connDbHandler({
|
const newInsert = await connDbHandler({
|
||||||
query,
|
query,
|
||||||
values: finalQueryValues,
|
values: finalQueryValues,
|
||||||
@ -246,7 +227,7 @@ export default async function addDbEntry<
|
|||||||
batchQueryValuesArray.push(queryValuesArray);
|
batchQueryValuesArray.push(queryValuesArray);
|
||||||
}
|
}
|
||||||
|
|
||||||
const query = `INSERT INTO ${
|
let query = `INSERT INTO ${
|
||||||
isMaster && !dbFullName ? "" : `\`${dbFullName}\`.`
|
isMaster && !dbFullName ? "" : `\`${dbFullName}\`.`
|
||||||
}\`${tableName}\` (${batchInsertKeysArray?.join(
|
}\`${tableName}\` (${batchInsertKeysArray?.join(
|
||||||
","
|
","
|
||||||
@ -258,6 +239,13 @@ export default async function addDbEntry<
|
|||||||
batchQueryValuesArray.flat()
|
batchQueryValuesArray.flat()
|
||||||
);
|
);
|
||||||
|
|
||||||
|
if (onDuplicate) {
|
||||||
|
query += ` ON DUPLICATE KEY ${onDuplicate.sql}`;
|
||||||
|
if (onDuplicate.values) {
|
||||||
|
finalQueryValues.push(...onDuplicate.values);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
const newInsert = await connDbHandler({
|
const newInsert = await connDbHandler({
|
||||||
query,
|
query,
|
||||||
values: finalQueryValues,
|
values: finalQueryValues,
|
||||||
|
|||||||
@ -4,6 +4,7 @@ import {
|
|||||||
} from "../../types";
|
} from "../../types";
|
||||||
import grabDSQLSchemaIndexComment from "../utils/grab-dsql-schema-index-comment";
|
import grabDSQLSchemaIndexComment from "../utils/grab-dsql-schema-index-comment";
|
||||||
import dbHandler from "../../functions/backend/dbHandler";
|
import dbHandler from "../../functions/backend/dbHandler";
|
||||||
|
import AppData from "../../data/app-data";
|
||||||
|
|
||||||
type Param = {
|
type Param = {
|
||||||
tableName: string;
|
tableName: string;
|
||||||
@ -22,48 +23,59 @@ export default async function handleIndexescreateDbFromSchema({
|
|||||||
tableName,
|
tableName,
|
||||||
indexes,
|
indexes,
|
||||||
}: Param) {
|
}: Param) {
|
||||||
|
/**
|
||||||
|
* Handle MYSQL Table Indexes
|
||||||
|
* ===================================================
|
||||||
|
* @description Iterate through each table index(if available)
|
||||||
|
* and perform operations
|
||||||
|
*/
|
||||||
const allExistingIndexes = (await dbHandler({
|
const allExistingIndexes = (await dbHandler({
|
||||||
query: `SHOW INDEXES FROM \`${dbFullName}\`.\`${tableName}\``,
|
query: `SHOW INDEXES FROM \`${dbFullName}\`.\`${tableName}\` WHERE Index_comment LIKE '%${AppData["IndexComment"]}%'`,
|
||||||
})) as DSQL_MYSQL_SHOW_INDEXES_Type[];
|
})) as DSQL_MYSQL_SHOW_INDEXES_Type[] | null;
|
||||||
|
|
||||||
|
if (allExistingIndexes) {
|
||||||
|
for (let f = 0; f < allExistingIndexes.length; f++) {
|
||||||
|
const { Key_name } = allExistingIndexes[f];
|
||||||
|
|
||||||
|
try {
|
||||||
|
const existingKeyInSchema = indexes?.find(
|
||||||
|
(indexObject) => indexObject.alias === Key_name
|
||||||
|
);
|
||||||
|
if (!existingKeyInSchema)
|
||||||
|
throw new Error(
|
||||||
|
`This Index(${Key_name}) Has been Deleted!`
|
||||||
|
);
|
||||||
|
} catch (error) {
|
||||||
|
/**
|
||||||
|
* @description Drop Index: This happens when the MYSQL index is not
|
||||||
|
* present in the datasquirel DB schema
|
||||||
|
*/
|
||||||
|
await dbHandler({
|
||||||
|
query: `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` DROP INDEX \`${Key_name}\``,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* # Re-Add New Indexes
|
||||||
|
*/
|
||||||
for (let g = 0; g < indexes.length; g++) {
|
for (let g = 0; g < indexes.length; g++) {
|
||||||
const { indexType, indexName, indexTableFields, alias } = indexes[g];
|
const { indexType, indexName, indexTableFields, alias } = indexes[g];
|
||||||
|
|
||||||
if (!alias?.match(/./)) continue;
|
if (!alias?.match(/./)) continue;
|
||||||
|
|
||||||
/**
|
const queryString = `CREATE${
|
||||||
* @description Check for existing Index in MYSQL db
|
indexType == "full_text"
|
||||||
*/
|
? " FULLTEXT"
|
||||||
try {
|
: indexType == "vector"
|
||||||
const existingKeyInDb = allExistingIndexes.filter(
|
? " VECTOR"
|
||||||
(indexObject) => indexObject.Key_name === alias
|
: ""
|
||||||
);
|
} INDEX \`${alias}\` ON \`${dbFullName}\`.\`${tableName}\`(${indexTableFields
|
||||||
|
?.map((nm) => nm.value)
|
||||||
|
.map((nm) => `\`${nm}\``)
|
||||||
|
.join(",")}) COMMENT '${AppData["IndexComment"]} ${indexName}'`;
|
||||||
|
|
||||||
if (!existingKeyInDb[0])
|
const addIndex = await dbHandler({ query: queryString });
|
||||||
throw new Error("This Index Does not Exist");
|
|
||||||
} catch (error) {
|
|
||||||
/**
|
|
||||||
* @description Create new index if determined that it
|
|
||||||
* doesn't exist in MYSQL db
|
|
||||||
*/
|
|
||||||
const queryString = `CREATE${
|
|
||||||
indexType == "full_text"
|
|
||||||
? " FULLTEXT"
|
|
||||||
: indexType == "vector"
|
|
||||||
? " VECTOR"
|
|
||||||
: ""
|
|
||||||
} INDEX \`${alias}\` ON \`${dbFullName}\`.\`${tableName}\`(${indexTableFields
|
|
||||||
?.map((nm) => nm.value)
|
|
||||||
.map((nm) => `\`${nm}\``)
|
|
||||||
.join(
|
|
||||||
","
|
|
||||||
)}) COMMENT '${grabDSQLSchemaIndexComment()} ${indexName}'`;
|
|
||||||
|
|
||||||
const addIndex = await dbHandler({ query: queryString });
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const allExistingIndexesAfterUpdate = (await dbHandler({
|
|
||||||
query: `SHOW INDEXES FROM \`${dbFullName}\`.\`${tableName}\``,
|
|
||||||
})) as DSQL_MYSQL_SHOW_INDEXES_Type[];
|
|
||||||
}
|
}
|
||||||
|
|||||||
@ -0,0 +1,80 @@
|
|||||||
|
import {
|
||||||
|
DSQL_MYSQL_FOREIGN_KEYS_Type,
|
||||||
|
DSQL_MYSQL_SHOW_INDEXES_Type,
|
||||||
|
DSQL_UniqueConstraintSchemaType,
|
||||||
|
} from "../../types";
|
||||||
|
import dbHandler from "../../functions/backend/dbHandler";
|
||||||
|
import AppData from "../../data/app-data";
|
||||||
|
import normalizeText from "../../utils/normalize-text";
|
||||||
|
|
||||||
|
type Param = {
|
||||||
|
tableName: string;
|
||||||
|
dbFullName: string;
|
||||||
|
tableUniqueConstraints: DSQL_UniqueConstraintSchemaType[];
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Handle DATASQUIREL Table Unique Constraints
|
||||||
|
* ===================================================
|
||||||
|
* @description Iterate through each datasquirel schema
|
||||||
|
* table unique constraint(if available), and perform operations
|
||||||
|
*/
|
||||||
|
export default async function handleUniqueConstraintsCreateDbFromSchema({
|
||||||
|
dbFullName,
|
||||||
|
tableName,
|
||||||
|
tableUniqueConstraints,
|
||||||
|
}: Param) {
|
||||||
|
/**
|
||||||
|
* # Delete All Existing Unique Constraints
|
||||||
|
*/
|
||||||
|
// const allExistingUniqueConstraints = (await dbHandler({
|
||||||
|
// query: `SHOW INDEXES FROM \`${dbFullName}\`.\`${tableName}\` WHERE Index_comment LIKE '%${AppData["UniqueConstraintComment"]}%'`,
|
||||||
|
// })) as DSQL_MYSQL_SHOW_INDEXES_Type[] | null;
|
||||||
|
|
||||||
|
// if (allExistingUniqueConstraints?.[0]) {
|
||||||
|
// for (let f = 0; f < allExistingUniqueConstraints.length; f++) {
|
||||||
|
// const { Key_name } = allExistingUniqueConstraints[f];
|
||||||
|
|
||||||
|
// try {
|
||||||
|
// const existingKeyInSchema = tableUniqueConstraints?.find(
|
||||||
|
// (indexObject) => indexObject.alias === Key_name
|
||||||
|
// );
|
||||||
|
// if (!existingKeyInSchema)
|
||||||
|
// throw new Error(
|
||||||
|
// `This Index(${Key_name}) Has been Deleted!`
|
||||||
|
// );
|
||||||
|
// } catch (error) {
|
||||||
|
// /**
|
||||||
|
// * @description Drop Index: This happens when the MYSQL index is not
|
||||||
|
// * present in the datasquirel DB schema
|
||||||
|
// */
|
||||||
|
// await dbHandler({
|
||||||
|
// query: `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` DROP INDEX \`${Key_name}\``,
|
||||||
|
// });
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* # Re-Add New Constraints
|
||||||
|
*/
|
||||||
|
for (let g = 0; g < tableUniqueConstraints.length; g++) {
|
||||||
|
const { constraintName, alias, constraintTableFields } =
|
||||||
|
tableUniqueConstraints[g];
|
||||||
|
|
||||||
|
if (!alias?.match(/./)) continue;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @description Create new index if determined that it
|
||||||
|
* doesn't exist in MYSQL db
|
||||||
|
*/
|
||||||
|
const queryString = `CREATE UNIQUE INDEX \`${alias}\` ON \`${dbFullName}\`.\`${tableName}\`(${constraintTableFields
|
||||||
|
?.map((nm) => nm.value)
|
||||||
|
.map((nm) => `\`${nm}\``)
|
||||||
|
.join(",")}) COMMENT '${
|
||||||
|
AppData["UniqueConstraintComment"]
|
||||||
|
} ${constraintName}'`;
|
||||||
|
|
||||||
|
const addIndex = await dbHandler({ query: queryString });
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -131,7 +131,7 @@ export default async function createDbFromSchema({
|
|||||||
for (let t = 0; t < tables.length; t++) {
|
for (let t = 0; t < tables.length; t++) {
|
||||||
const table = tables[t];
|
const table = tables[t];
|
||||||
|
|
||||||
const { tableName, fields, indexes } = table;
|
const { tableName, fields, indexes, uniqueConstraints } = table;
|
||||||
|
|
||||||
if (targetTable && tableName !== targetTable) continue;
|
if (targetTable && tableName !== targetTable) continue;
|
||||||
|
|
||||||
@ -169,6 +169,7 @@ export default async function createDbFromSchema({
|
|||||||
recordedDbEntry,
|
recordedDbEntry,
|
||||||
tableSchema: table,
|
tableSchema: table,
|
||||||
isMain,
|
isMain,
|
||||||
|
tableUniqueConstraints: uniqueConstraints,
|
||||||
});
|
});
|
||||||
|
|
||||||
if (table.childrenTables && table.childrenTables[0]) {
|
if (table.childrenTables && table.childrenTables[0]) {
|
||||||
@ -201,6 +202,8 @@ export default async function createDbFromSchema({
|
|||||||
userId,
|
userId,
|
||||||
dbSchema: childTableParentDbSchema,
|
dbSchema: childTableParentDbSchema,
|
||||||
tableIndexes: childTableSchema.indexes,
|
tableIndexes: childTableSchema.indexes,
|
||||||
|
tableUniqueConstraints:
|
||||||
|
childTableSchema.uniqueConstraints,
|
||||||
clone: true,
|
clone: true,
|
||||||
recordedDbEntry,
|
recordedDbEntry,
|
||||||
tableSchema: table,
|
tableSchema: table,
|
||||||
@ -214,11 +217,13 @@ export default async function createDbFromSchema({
|
|||||||
*/
|
*/
|
||||||
const createNewTable = await createTable({
|
const createNewTable = await createTable({
|
||||||
tableName: tableName,
|
tableName: tableName,
|
||||||
tableInfoArray: fields,
|
fields,
|
||||||
dbFullName: dbFullName,
|
dbFullName: dbFullName,
|
||||||
tableSchema: table,
|
tableSchema: table,
|
||||||
recordedDbEntry,
|
recordedDbEntry,
|
||||||
isMain,
|
isMain,
|
||||||
|
indexes,
|
||||||
|
uniqueConstraints,
|
||||||
});
|
});
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@ -1,18 +1,27 @@
|
|||||||
import generateColumnDescription from "./generateColumnDescription";
|
import generateColumnDescription from "./generateColumnDescription";
|
||||||
import supplementTable from "./supplementTable";
|
import supplementTable from "./supplementTable";
|
||||||
import { DSQL_FieldSchemaType, DSQL_TableSchemaType } from "../../types";
|
import {
|
||||||
|
DSQL_FieldSchemaType,
|
||||||
|
DSQL_IndexSchemaType,
|
||||||
|
DSQL_TableSchemaType,
|
||||||
|
DSQL_UniqueConstraintSchemaType,
|
||||||
|
} from "../../types";
|
||||||
import { DSQL_DATASQUIREL_USER_DATABASES } from "../../types/dsql";
|
import { DSQL_DATASQUIREL_USER_DATABASES } from "../../types/dsql";
|
||||||
import handleTableForeignKey from "./handle-table-foreign-key";
|
import handleTableForeignKey from "./handle-table-foreign-key";
|
||||||
import createTableHandleTableRecord from "./create-table-handle-table-record";
|
import createTableHandleTableRecord from "./create-table-handle-table-record";
|
||||||
import dbHandler from "../../functions/backend/dbHandler";
|
import dbHandler from "../../functions/backend/dbHandler";
|
||||||
|
import handleIndexescreateDbFromSchema from "../createDbFromSchema/handle-indexes";
|
||||||
|
import handleUniqueConstraintsCreateDbFromSchema from "../createDbFromSchema/handle-unique-constraints";
|
||||||
|
|
||||||
type Param = {
|
type Param = {
|
||||||
dbFullName: string;
|
dbFullName: string;
|
||||||
tableName: string;
|
tableName: string;
|
||||||
tableInfoArray: DSQL_FieldSchemaType[];
|
fields: DSQL_FieldSchemaType[];
|
||||||
tableSchema?: DSQL_TableSchemaType;
|
tableSchema?: DSQL_TableSchemaType;
|
||||||
recordedDbEntry?: DSQL_DATASQUIREL_USER_DATABASES;
|
recordedDbEntry?: DSQL_DATASQUIREL_USER_DATABASES;
|
||||||
isMain?: boolean;
|
isMain?: boolean;
|
||||||
|
indexes?: DSQL_IndexSchemaType[];
|
||||||
|
uniqueConstraints?: DSQL_UniqueConstraintSchemaType[];
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -21,12 +30,14 @@ type Param = {
|
|||||||
export default async function createTable({
|
export default async function createTable({
|
||||||
dbFullName,
|
dbFullName,
|
||||||
tableName,
|
tableName,
|
||||||
tableInfoArray,
|
fields: passedFields,
|
||||||
tableSchema,
|
tableSchema,
|
||||||
recordedDbEntry,
|
recordedDbEntry,
|
||||||
isMain,
|
isMain,
|
||||||
|
indexes,
|
||||||
|
uniqueConstraints,
|
||||||
}: Param) {
|
}: Param) {
|
||||||
const finalTable = supplementTable({ tableInfoArray: tableInfoArray });
|
const fields = supplementTable({ tableInfoArray: passedFields });
|
||||||
|
|
||||||
let tableId = await createTableHandleTableRecord({
|
let tableId = await createTableHandleTableRecord({
|
||||||
recordedDbEntry,
|
recordedDbEntry,
|
||||||
@ -44,8 +55,8 @@ export default async function createTable({
|
|||||||
|
|
||||||
let primaryKeySet = false;
|
let primaryKeySet = false;
|
||||||
|
|
||||||
for (let i = 0; i < finalTable.length; i++) {
|
for (let i = 0; i < fields.length; i++) {
|
||||||
const column = finalTable[i];
|
const column = fields[i];
|
||||||
|
|
||||||
let { fieldEntryText, newPrimaryKeySet } = generateColumnDescription({
|
let { fieldEntryText, newPrimaryKeySet } = generateColumnDescription({
|
||||||
columnData: column,
|
columnData: column,
|
||||||
@ -55,7 +66,7 @@ export default async function createTable({
|
|||||||
primaryKeySet = newPrimaryKeySet;
|
primaryKeySet = newPrimaryKeySet;
|
||||||
|
|
||||||
const comma = (() => {
|
const comma = (() => {
|
||||||
if (i === finalTable.length - 1) return "";
|
if (i === fields.length - 1) return "";
|
||||||
return ",";
|
return ",";
|
||||||
})();
|
})();
|
||||||
|
|
||||||
@ -74,20 +85,44 @@ export default async function createTable({
|
|||||||
query: createTableQuery,
|
query: createTableQuery,
|
||||||
});
|
});
|
||||||
|
|
||||||
for (let i = 0; i < finalTable.length; i++) {
|
/**
|
||||||
const column = finalTable[i];
|
* Handle MYSQL Foreign Keys
|
||||||
const { foreignKey, fieldName } = column;
|
* ===================================================
|
||||||
|
* @description Iterate through each datasquirel schema
|
||||||
|
* table index(if available), and perform operations
|
||||||
|
*/
|
||||||
|
await handleTableForeignKey({
|
||||||
|
dbFullName,
|
||||||
|
fields,
|
||||||
|
tableName,
|
||||||
|
});
|
||||||
|
|
||||||
if (!fieldName) continue;
|
/**
|
||||||
|
* Handle DATASQUIREL Table Indexes
|
||||||
|
* ===================================================
|
||||||
|
* @description Iterate through each datasquirel schema
|
||||||
|
* table index(if available), and perform operations
|
||||||
|
*/
|
||||||
|
if (indexes?.[0]) {
|
||||||
|
handleIndexescreateDbFromSchema({
|
||||||
|
dbFullName,
|
||||||
|
indexes,
|
||||||
|
tableName,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
if (foreignKey) {
|
/**
|
||||||
await handleTableForeignKey({
|
* Handle DATASQUIREL Table Unique Indexes
|
||||||
dbFullName,
|
* ===================================================
|
||||||
foreignKey,
|
* @description Iterate through each datasquirel schema
|
||||||
tableName,
|
* table unique constraint(if available), and perform operations
|
||||||
fieldName,
|
*/
|
||||||
});
|
if (uniqueConstraints?.[0]) {
|
||||||
}
|
handleUniqueConstraintsCreateDbFromSchema({
|
||||||
|
dbFullName,
|
||||||
|
tableUniqueConstraints: uniqueConstraints,
|
||||||
|
tableName,
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
return tableId;
|
return tableId;
|
||||||
|
|||||||
@ -1,53 +0,0 @@
|
|||||||
import grabSQLKeyName from "../../utils/grab-sql-key-name";
|
|
||||||
import dbHandler from "../../functions/backend/dbHandler";
|
|
||||||
|
|
||||||
type Param = {
|
|
||||||
dbFullName: string;
|
|
||||||
tableName: string;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* # Drop All Foreign Keys
|
|
||||||
*/
|
|
||||||
export default async function dropAllForeignKeys({
|
|
||||||
dbFullName,
|
|
||||||
tableName,
|
|
||||||
}: Param) {
|
|
||||||
try {
|
|
||||||
// const rows = await varDatabaseDbHandler({
|
|
||||||
// queryString: `SELECT CONSTRAINT_NAME FROM information_schema.REFERENTIAL_CONSTRAINTS WHERE TABLE_NAME = '${tableName}' AND CONSTRAINT_SCHEMA = '${dbFullName}'`,
|
|
||||||
// });
|
|
||||||
|
|
||||||
// console.log("rows", rows);
|
|
||||||
// console.log("dbFullName", dbFullName);
|
|
||||||
// console.log("tableName", tableName);
|
|
||||||
|
|
||||||
// for (const row of rows) {
|
|
||||||
// await varDatabaseDbHandler({
|
|
||||||
// queryString: `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` DROP FOREIGN KEY \`${row.CONSTRAINT_NAME}\`
|
|
||||||
// `,
|
|
||||||
// });
|
|
||||||
// }
|
|
||||||
|
|
||||||
const foreignKeys = (await dbHandler({
|
|
||||||
query: `SHOW INDEXES FROM \`${dbFullName}\`.\`${tableName}\` WHERE Key_name LIKE '${grabSQLKeyName(
|
|
||||||
{ type: "foreign_key" }
|
|
||||||
)}%'`,
|
|
||||||
})) as any;
|
|
||||||
|
|
||||||
for (const fk of foreignKeys) {
|
|
||||||
if (
|
|
||||||
fk.Key_name.match(
|
|
||||||
new RegExp(grabSQLKeyName({ type: "foreign_key" }))
|
|
||||||
)
|
|
||||||
) {
|
|
||||||
await dbHandler({
|
|
||||||
query: `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` DROP INDEX \`${fk.Key_name}\`
|
|
||||||
`,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} catch (error: any) {
|
|
||||||
console.log(`dropAllForeignKeys ERROR => ${error.message}`);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
85
package-shared/shell/utils/handle-dsql-schema-fields.ts
Normal file
85
package-shared/shell/utils/handle-dsql-schema-fields.ts
Normal file
@ -0,0 +1,85 @@
|
|||||||
|
import {
|
||||||
|
DSQL_FieldSchemaType,
|
||||||
|
DSQL_MYSQL_SHOW_COLUMNS_Type,
|
||||||
|
} from "../../types";
|
||||||
|
import dbHandler from "../../functions/backend/dbHandler";
|
||||||
|
import defaultFieldsRegexp from "../../functions/dsql/default-fields-regexp";
|
||||||
|
import generateColumnDescription from "./generateColumnDescription";
|
||||||
|
|
||||||
|
type Param = {
|
||||||
|
dbFullName: string;
|
||||||
|
tableName: string;
|
||||||
|
fields: DSQL_FieldSchemaType[];
|
||||||
|
clone?: boolean;
|
||||||
|
allExistingColumns: DSQL_MYSQL_SHOW_COLUMNS_Type[];
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Handle DATASQUIREL schema fields for current table
|
||||||
|
* ===================================================
|
||||||
|
* @description Iterate through each field object and
|
||||||
|
* perform operations
|
||||||
|
*/
|
||||||
|
export default async function handleDSQLSchemaFields({
|
||||||
|
dbFullName,
|
||||||
|
tableName,
|
||||||
|
fields,
|
||||||
|
allExistingColumns,
|
||||||
|
}: Param) {
|
||||||
|
let sql = `ALTER TABLE \`${dbFullName}\`.\`${tableName}\``;
|
||||||
|
|
||||||
|
for (let i = 0; i < fields.length; i++) {
|
||||||
|
const column = fields[i];
|
||||||
|
// const prevColumn = fields[i - 1];
|
||||||
|
// const nextColumn = fields[i + 1];
|
||||||
|
|
||||||
|
const { fieldName, dataType, foreignKey } = column;
|
||||||
|
|
||||||
|
if (!fieldName) continue;
|
||||||
|
if (defaultFieldsRegexp.test(fieldName)) continue;
|
||||||
|
|
||||||
|
let updateText = "";
|
||||||
|
|
||||||
|
const existingColumnIndex = allExistingColumns?.findIndex(
|
||||||
|
(_column, _index) => _column.Field === fieldName
|
||||||
|
);
|
||||||
|
|
||||||
|
const existingColumn =
|
||||||
|
existingColumnIndex >= 0
|
||||||
|
? allExistingColumns[existingColumnIndex]
|
||||||
|
: undefined;
|
||||||
|
|
||||||
|
let { fieldEntryText } = generateColumnDescription({
|
||||||
|
columnData: column,
|
||||||
|
});
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @description Modify Column(Field) if it already exists
|
||||||
|
* in MYSQL database
|
||||||
|
*/
|
||||||
|
if (existingColumn?.Field) {
|
||||||
|
const { Field, Type } = existingColumn;
|
||||||
|
|
||||||
|
updateText += ` MODIFY COLUMN ${fieldEntryText}`;
|
||||||
|
} else {
|
||||||
|
/**
|
||||||
|
* @description Append new column to the end of existing columns
|
||||||
|
*/
|
||||||
|
updateText += ` ADD COLUMN ${fieldEntryText}`;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @description Pust SQL code snippet to updateTableQueryArray Array
|
||||||
|
* Add a comma(,) to separate from the next snippet
|
||||||
|
*/
|
||||||
|
if (updateText.match(/./)) {
|
||||||
|
sql += " " + updateText + ",";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const finalSQL = sql.replace(/\,$/, "");
|
||||||
|
|
||||||
|
const updateTable = await dbHandler({
|
||||||
|
query: finalSQL,
|
||||||
|
});
|
||||||
|
}
|
||||||
126
package-shared/shell/utils/handle-mariadb-existing-columns.ts
Normal file
126
package-shared/shell/utils/handle-mariadb-existing-columns.ts
Normal file
@ -0,0 +1,126 @@
|
|||||||
|
import {
|
||||||
|
DSQL_DatabaseSchemaType,
|
||||||
|
DSQL_FieldSchemaType,
|
||||||
|
DSQL_MYSQL_SHOW_COLUMNS_Type,
|
||||||
|
} from "../../types";
|
||||||
|
import dbHandler from "../../functions/backend/dbHandler";
|
||||||
|
import defaultFieldsRegexp from "../../functions/dsql/default-fields-regexp";
|
||||||
|
import { writeUpdatedDbSchema } from "../createDbFromSchema/grab-required-database-schemas";
|
||||||
|
import _ from "lodash";
|
||||||
|
|
||||||
|
type Param = {
|
||||||
|
dbFullName: string;
|
||||||
|
tableName: string;
|
||||||
|
fields: DSQL_FieldSchemaType[];
|
||||||
|
dbSchema: DSQL_DatabaseSchemaType;
|
||||||
|
userId?: number | string | null;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Handle MYSQL Columns (Fields)
|
||||||
|
* ===================================================
|
||||||
|
* @description Now handle all fields/columns
|
||||||
|
*/
|
||||||
|
export default async function handleMariaDBExistingColumns({
|
||||||
|
dbFullName,
|
||||||
|
tableName,
|
||||||
|
fields,
|
||||||
|
dbSchema,
|
||||||
|
userId,
|
||||||
|
}: Param) {
|
||||||
|
let upToDateTableFieldsArray = _.cloneDeep(fields);
|
||||||
|
|
||||||
|
let allExistingColumns: DSQL_MYSQL_SHOW_COLUMNS_Type[] = (await dbHandler({
|
||||||
|
query: `SHOW COLUMNS FROM \`${dbFullName}\`.\`${tableName}\``,
|
||||||
|
})) as DSQL_MYSQL_SHOW_COLUMNS_Type[];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @description Iterate through every existing column
|
||||||
|
*/
|
||||||
|
for (let e = 0; e < allExistingColumns.length; e++) {
|
||||||
|
const { Field } = allExistingColumns[e];
|
||||||
|
|
||||||
|
if (Field.match(defaultFieldsRegexp)) continue;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @description This finds out whether the fieldName corresponds with the MSQL Field name
|
||||||
|
* if the fildName doesn't match any MYSQL Field name, the field is deleted.
|
||||||
|
*/
|
||||||
|
let existingEntry = upToDateTableFieldsArray.find(
|
||||||
|
(column) =>
|
||||||
|
column.fieldName === Field || column.originName === Field
|
||||||
|
);
|
||||||
|
|
||||||
|
if (!existingEntry) {
|
||||||
|
await dbHandler({
|
||||||
|
query: `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` DROP COLUMN \`${Field}\``,
|
||||||
|
});
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (existingEntry) {
|
||||||
|
/**
|
||||||
|
* @description Check if Field name has been updated
|
||||||
|
*/
|
||||||
|
if (existingEntry.updatedField && existingEntry.fieldName) {
|
||||||
|
await dbHandler({
|
||||||
|
query: `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` RENAME COLUMN \`${existingEntry.originName}\` TO \`${existingEntry.fieldName}\``,
|
||||||
|
});
|
||||||
|
|
||||||
|
console.log(
|
||||||
|
`Column Renamed from "${existingEntry.originName}" to "${existingEntry.fieldName}"`
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Update Db Schema
|
||||||
|
* ===================================================
|
||||||
|
* @description Update Db Schema after renaming column
|
||||||
|
*/
|
||||||
|
try {
|
||||||
|
const updatedSchemaData = _.cloneDeep(dbSchema);
|
||||||
|
|
||||||
|
const targetTableIndex = updatedSchemaData.tables.findIndex(
|
||||||
|
(table) => table.tableName === tableName
|
||||||
|
);
|
||||||
|
const targetFieldIndex = updatedSchemaData.tables[
|
||||||
|
targetTableIndex
|
||||||
|
].fields.findIndex(
|
||||||
|
(field) => field.fieldName === existingEntry.fieldName
|
||||||
|
);
|
||||||
|
|
||||||
|
delete updatedSchemaData.tables[targetTableIndex].fields[
|
||||||
|
targetFieldIndex
|
||||||
|
]["originName"];
|
||||||
|
delete updatedSchemaData.tables[targetTableIndex].fields[
|
||||||
|
targetFieldIndex
|
||||||
|
]["updatedField"];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @description Set New Table Fields Array
|
||||||
|
*/
|
||||||
|
upToDateTableFieldsArray =
|
||||||
|
updatedSchemaData.tables[targetTableIndex].fields;
|
||||||
|
|
||||||
|
if (userId) {
|
||||||
|
writeUpdatedDbSchema({
|
||||||
|
dbSchema: updatedSchemaData,
|
||||||
|
userId,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
allExistingColumns = (await dbHandler({
|
||||||
|
query: `SHOW COLUMNS FROM \`${dbFullName}\`.\`${tableName}\``,
|
||||||
|
})) as DSQL_MYSQL_SHOW_COLUMNS_Type[];
|
||||||
|
} catch (error: any) {
|
||||||
|
console.log("Update table error =>", error.message);
|
||||||
|
}
|
||||||
|
|
||||||
|
////////////////////////////////////////
|
||||||
|
}
|
||||||
|
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return { upToDateTableFieldsArray, allExistingColumns };
|
||||||
|
}
|
||||||
@ -1,51 +1,60 @@
|
|||||||
import { DSQL_ForeignKeyType } from "../../types";
|
import {
|
||||||
|
DSQL_FieldSchemaType,
|
||||||
|
DSQL_ForeignKeyType,
|
||||||
|
DSQL_MYSQL_FOREIGN_KEYS_Type,
|
||||||
|
} from "../../types";
|
||||||
import dbHandler from "../../functions/backend/dbHandler";
|
import dbHandler from "../../functions/backend/dbHandler";
|
||||||
|
|
||||||
type Param = {
|
type Param = {
|
||||||
dbFullName: string;
|
dbFullName: string;
|
||||||
tableName: string;
|
tableName: string;
|
||||||
foreignKey: DSQL_ForeignKeyType;
|
fields: DSQL_FieldSchemaType[];
|
||||||
fieldName: string;
|
clone?: boolean;
|
||||||
errorLogs?: any[];
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* # Update table function
|
* Handle MYSQL Foreign Keys
|
||||||
|
* ===================================================
|
||||||
|
* @description Iterate through each datasquirel schema
|
||||||
|
* table index(if available), and perform operations
|
||||||
*/
|
*/
|
||||||
export default async function handleTableForeignKey({
|
export default async function handleTableForeignKey({
|
||||||
dbFullName,
|
dbFullName,
|
||||||
tableName,
|
tableName,
|
||||||
foreignKey,
|
fields,
|
||||||
errorLogs,
|
clone,
|
||||||
fieldName,
|
|
||||||
}: Param) {
|
}: Param) {
|
||||||
const {
|
let addFkSQL = `ALTER TABLE \`${dbFullName}\`.\`${tableName}\``;
|
||||||
destinationTableName,
|
|
||||||
destinationTableColumnName,
|
|
||||||
cascadeDelete,
|
|
||||||
cascadeUpdate,
|
|
||||||
foreignKeyName,
|
|
||||||
} = foreignKey;
|
|
||||||
|
|
||||||
let finalQueryString = `ALTER TABLE \`${dbFullName}\`.\`${tableName}\``;
|
for (let i = 0; i < fields.length; i++) {
|
||||||
|
const { fieldName, foreignKey } = fields[i];
|
||||||
|
|
||||||
finalQueryString += ` ADD CONSTRAINT \`${foreignKeyName}\` FOREIGN KEY (\`${fieldName}\`)`;
|
if (!clone && foreignKey && fieldName) {
|
||||||
finalQueryString += ` REFERENCES \`${destinationTableName}\`(\`${destinationTableColumnName}\`)`;
|
const {
|
||||||
|
destinationTableName,
|
||||||
|
destinationTableColumnName,
|
||||||
|
cascadeDelete,
|
||||||
|
cascadeUpdate,
|
||||||
|
foreignKeyName,
|
||||||
|
} = foreignKey;
|
||||||
|
|
||||||
if (cascadeDelete) finalQueryString += ` ON DELETE CASCADE`;
|
addFkSQL += ` ADD CONSTRAINT \`${foreignKeyName}\` FOREIGN KEY (\`${fieldName}\`)`;
|
||||||
if (cascadeUpdate) finalQueryString += ` ON UPDATE CASCADE`;
|
addFkSQL += ` REFERENCES \`${destinationTableName}\`(\`${destinationTableColumnName}\`)`;
|
||||||
|
|
||||||
// let foreinKeyText = `ADD CONSTRAINT \`${foreignKeyName}\` FOREIGN KEY (\`${destinationTableColumnType}\`) REFERENCES \`${destinationTableName}\`(\`${destinationTableColumnName}\`)${
|
if (cascadeDelete) addFkSQL += ` ON DELETE CASCADE`;
|
||||||
// cascadeDelete ? " ON DELETE CASCADE" : ""
|
if (cascadeUpdate) addFkSQL += ` ON UPDATE CASCADE`;
|
||||||
// }${cascadeUpdate ? " ON UPDATE CASCADE" : ""}`;
|
|
||||||
|
|
||||||
// let finalQueryString = `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` ${foreinKeyText}`;
|
addFkSQL += `,`;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
const addForeignKey = (await dbHandler({
|
const finalAddFKSQL = addFkSQL.endsWith(",")
|
||||||
query: finalQueryString,
|
? addFkSQL.replace(/\,$/, "")
|
||||||
})) as any;
|
: undefined;
|
||||||
|
|
||||||
if (!addForeignKey?.serverStatus) {
|
if (finalAddFKSQL) {
|
||||||
errorLogs?.push(addForeignKey);
|
const addForeignKey = (await dbHandler({
|
||||||
|
query: finalAddFKSQL,
|
||||||
|
})) as any;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
166
package-shared/shell/utils/update-table-init.ts
Normal file
166
package-shared/shell/utils/update-table-init.ts
Normal file
@ -0,0 +1,166 @@
|
|||||||
|
import {
|
||||||
|
DSQL_DatabaseSchemaType,
|
||||||
|
DSQL_MARIADB_SHOW_INDEXES_TYPE,
|
||||||
|
DSQL_MYSQL_FOREIGN_KEYS_Type,
|
||||||
|
DSQL_TableSchemaType,
|
||||||
|
} from "../../types";
|
||||||
|
import createTableHandleTableRecord from "./create-table-handle-table-record";
|
||||||
|
import { DSQL_DATASQUIREL_USER_DATABASES } from "../../types/dsql";
|
||||||
|
import _ from "lodash";
|
||||||
|
import dbHandler from "../../functions/backend/dbHandler";
|
||||||
|
|
||||||
|
type Params = {
|
||||||
|
dbFullName: string;
|
||||||
|
tableName: string;
|
||||||
|
tableSchema: DSQL_TableSchemaType;
|
||||||
|
dbSchema: DSQL_DatabaseSchemaType;
|
||||||
|
recordedDbEntry?: DSQL_DATASQUIREL_USER_DATABASES;
|
||||||
|
isMain?: boolean;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* # Update table function
|
||||||
|
*/
|
||||||
|
export default async function updateTableInit({
|
||||||
|
dbFullName,
|
||||||
|
tableName,
|
||||||
|
tableSchema,
|
||||||
|
recordedDbEntry,
|
||||||
|
isMain,
|
||||||
|
}: Params) {
|
||||||
|
/**
|
||||||
|
* @description Grab Table Record
|
||||||
|
*/
|
||||||
|
if (!recordedDbEntry && !isMain) {
|
||||||
|
throw new Error("Recorded Db entry not found!");
|
||||||
|
}
|
||||||
|
|
||||||
|
let tableID = await createTableHandleTableRecord({
|
||||||
|
recordedDbEntry,
|
||||||
|
tableSchema,
|
||||||
|
update: true,
|
||||||
|
isMain,
|
||||||
|
});
|
||||||
|
|
||||||
|
if (!tableID && !isMain) {
|
||||||
|
throw new Error("Recorded Table entry not found!");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Handle Table Default Collation
|
||||||
|
*
|
||||||
|
* @description Update Column Collation
|
||||||
|
*/
|
||||||
|
if (tableSchema.collation) {
|
||||||
|
try {
|
||||||
|
const existingCollation = (await dbHandler({
|
||||||
|
query: `SHOW TABLE STATUS LIKE '${tableName}'`,
|
||||||
|
config: { database: dbFullName },
|
||||||
|
})) as any[];
|
||||||
|
|
||||||
|
const existingCollationStr = existingCollation?.[0].Collation;
|
||||||
|
|
||||||
|
if (existingCollationStr !== tableSchema.collation) {
|
||||||
|
await dbHandler({
|
||||||
|
query: `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` CONVERT TO CHARACTER SET utf8mb4 COLLATE ${tableSchema.collation}`,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
} catch (error) {}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Drop All Foreign Keys
|
||||||
|
* ===================================================
|
||||||
|
* @description Find all existing foreign keys and drop
|
||||||
|
* them
|
||||||
|
*/
|
||||||
|
const allForeignKeys = (await dbHandler({
|
||||||
|
query: `SELECT CONSTRAINT_NAME FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS WHERE CONSTRAINT_SCHEMA = '${dbFullName}' AND TABLE_NAME='${tableName}' AND CONSTRAINT_TYPE='FOREIGN KEY'`,
|
||||||
|
})) as DSQL_MYSQL_FOREIGN_KEYS_Type[] | null;
|
||||||
|
|
||||||
|
if (allForeignKeys?.[0]) {
|
||||||
|
let dropFkSQL = `ALTER TABLE \`${dbFullName}\`.\`${tableName}\``;
|
||||||
|
|
||||||
|
for (let c = 0; c < allForeignKeys.length; c++) {
|
||||||
|
const { CONSTRAINT_NAME } = allForeignKeys[c];
|
||||||
|
|
||||||
|
if (CONSTRAINT_NAME.match(/PRIMARY/)) continue;
|
||||||
|
|
||||||
|
dropFkSQL += ` DROP FOREIGN KEY \`${CONSTRAINT_NAME}\`,`;
|
||||||
|
}
|
||||||
|
|
||||||
|
const finalSQL = dropFkSQL.endsWith(",")
|
||||||
|
? dropFkSQL.replace(/\,$/, "")
|
||||||
|
: undefined;
|
||||||
|
|
||||||
|
if (finalSQL) {
|
||||||
|
await dbHandler({
|
||||||
|
query: finalSQL,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Drop All Unique Constraints
|
||||||
|
* ===================================================
|
||||||
|
* @description Find all existing unique field constraints
|
||||||
|
* and remove them
|
||||||
|
*/
|
||||||
|
const allUniqueConstraints = (await dbHandler({
|
||||||
|
query: `SELECT CONSTRAINT_NAME FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS WHERE CONSTRAINT_SCHEMA = '${dbFullName}' AND TABLE_NAME='${tableName}' AND CONSTRAINT_TYPE='UNIQUE'`,
|
||||||
|
})) as DSQL_MYSQL_FOREIGN_KEYS_Type[] | null;
|
||||||
|
|
||||||
|
if (allUniqueConstraints?.[0]) {
|
||||||
|
let dropIndxSQL = `ALTER TABLE \`${dbFullName}\`.\`${tableName}\``;
|
||||||
|
|
||||||
|
for (let c = 0; c < allUniqueConstraints.length; c++) {
|
||||||
|
const { CONSTRAINT_NAME } = allUniqueConstraints[c];
|
||||||
|
|
||||||
|
dropIndxSQL += ` DROP INDEX ${CONSTRAINT_NAME},`;
|
||||||
|
}
|
||||||
|
|
||||||
|
const finalDropIndxSQL = dropIndxSQL.endsWith(",")
|
||||||
|
? dropIndxSQL.replace(/\,$/, "")
|
||||||
|
: undefined;
|
||||||
|
|
||||||
|
if (finalDropIndxSQL) {
|
||||||
|
await dbHandler({
|
||||||
|
query: finalDropIndxSQL,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Drop All Indexes
|
||||||
|
* ===================================================
|
||||||
|
* @description Find all existing foreign keys and drop
|
||||||
|
* them
|
||||||
|
*/
|
||||||
|
const allMariadbIndexes = (await dbHandler({
|
||||||
|
query: `SHOW INDEXES FROM \`${dbFullName}\`.\`${tableName}\``,
|
||||||
|
})) as DSQL_MARIADB_SHOW_INDEXES_TYPE[] | null;
|
||||||
|
|
||||||
|
if (allMariadbIndexes?.[0]) {
|
||||||
|
let dropIndxs = `ALTER TABLE \`${dbFullName}\`.\`${tableName}\``;
|
||||||
|
|
||||||
|
for (let c = 0; c < allMariadbIndexes.length; c++) {
|
||||||
|
const { Key_name } = allMariadbIndexes[c];
|
||||||
|
|
||||||
|
if (Key_name.match(/PRIMARY/)) continue;
|
||||||
|
|
||||||
|
dropIndxs += ` DROP INDEX \`${Key_name}\`,`;
|
||||||
|
}
|
||||||
|
|
||||||
|
const finalDropIndxs = dropIndxs.endsWith(",")
|
||||||
|
? dropIndxs.replace(/\,$/, "")
|
||||||
|
: undefined;
|
||||||
|
|
||||||
|
if (finalDropIndxs) {
|
||||||
|
const dropFkRes = await dbHandler({
|
||||||
|
query: finalDropIndxs,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return { tableID };
|
||||||
|
}
|
||||||
@ -1,23 +1,18 @@
|
|||||||
import generateColumnDescription from "./generateColumnDescription";
|
|
||||||
import {
|
import {
|
||||||
DSQL_DatabaseSchemaType,
|
DSQL_DatabaseSchemaType,
|
||||||
DSQL_FieldSchemaType,
|
DSQL_FieldSchemaType,
|
||||||
DSQL_IndexSchemaType,
|
DSQL_IndexSchemaType,
|
||||||
DSQL_MYSQL_FOREIGN_KEYS_Type,
|
|
||||||
DSQL_MYSQL_SHOW_COLUMNS_Type,
|
|
||||||
DSQL_MYSQL_SHOW_INDEXES_Type,
|
|
||||||
DSQL_TableSchemaType,
|
DSQL_TableSchemaType,
|
||||||
|
DSQL_UniqueConstraintSchemaType,
|
||||||
} from "../../types";
|
} from "../../types";
|
||||||
import handleTableForeignKey from "./handle-table-foreign-key";
|
|
||||||
import dropAllForeignKeys from "./drop-all-foreign-keys";
|
|
||||||
import createTableHandleTableRecord from "./create-table-handle-table-record";
|
|
||||||
import { DSQL_DATASQUIREL_USER_DATABASES } from "../../types/dsql";
|
import { DSQL_DATASQUIREL_USER_DATABASES } from "../../types/dsql";
|
||||||
import defaultFieldsRegexp from "../../functions/dsql/default-fields-regexp";
|
|
||||||
import handleIndexescreateDbFromSchema from "../createDbFromSchema/handle-indexes";
|
import handleIndexescreateDbFromSchema from "../createDbFromSchema/handle-indexes";
|
||||||
import _ from "lodash";
|
import _ from "lodash";
|
||||||
import { writeUpdatedDbSchema } from "../createDbFromSchema/grab-required-database-schemas";
|
import handleUniqueConstraintsCreateDbFromSchema from "../createDbFromSchema/handle-unique-constraints";
|
||||||
import normalizeText from "../../utils/normalize-text";
|
import handleTableForeignKey from "./handle-table-foreign-key";
|
||||||
import dbHandler from "../../functions/backend/dbHandler";
|
import handleDSQLSchemaFields from "./handle-dsql-schema-fields";
|
||||||
|
import handleMariaDBExistingColumns from "./handle-mariadb-existing-columns";
|
||||||
|
import updateTableInit from "./update-table-init";
|
||||||
|
|
||||||
type Param = {
|
type Param = {
|
||||||
dbFullName: string;
|
dbFullName: string;
|
||||||
@ -27,6 +22,7 @@ type Param = {
|
|||||||
userId?: number | string | null;
|
userId?: number | string | null;
|
||||||
dbSchema: DSQL_DatabaseSchemaType;
|
dbSchema: DSQL_DatabaseSchemaType;
|
||||||
tableIndexes?: DSQL_IndexSchemaType[];
|
tableIndexes?: DSQL_IndexSchemaType[];
|
||||||
|
tableUniqueConstraints?: DSQL_UniqueConstraintSchemaType[];
|
||||||
clone?: boolean;
|
clone?: boolean;
|
||||||
recordedDbEntry?: DSQL_DATASQUIREL_USER_DATABASES;
|
recordedDbEntry?: DSQL_DATASQUIREL_USER_DATABASES;
|
||||||
isMain?: boolean;
|
isMain?: boolean;
|
||||||
@ -46,113 +42,60 @@ export default async function updateTable({
|
|||||||
clone,
|
clone,
|
||||||
recordedDbEntry,
|
recordedDbEntry,
|
||||||
isMain,
|
isMain,
|
||||||
|
tableUniqueConstraints,
|
||||||
}: Param): Promise<number | undefined> {
|
}: Param): Promise<number | undefined> {
|
||||||
/**
|
|
||||||
* Initialize
|
|
||||||
* ==========================================
|
|
||||||
* @description Initial setup
|
|
||||||
*/
|
|
||||||
|
|
||||||
let errorLogs: any[] = [];
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @description Initialize table info array. This value will be
|
|
||||||
* changing depending on if a field is renamed or not.
|
|
||||||
*/
|
|
||||||
let upToDateTableFieldsArray = _.cloneDeep(tableFields);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @type {string[]}
|
|
||||||
* @description Table update query string array
|
|
||||||
*/
|
|
||||||
const updateTableQueryArray: string[] = [];
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @description Push the query initial value
|
|
||||||
*/
|
|
||||||
updateTableQueryArray.push(
|
|
||||||
`ALTER TABLE \`${dbFullName}\`.\`${tableName}\``
|
|
||||||
);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @description Grab Table Record
|
* @description Grab Table Record
|
||||||
*/
|
*/
|
||||||
if (!recordedDbEntry && !isMain) {
|
const { tableID } = await updateTableInit({
|
||||||
throw new Error("Recorded Db entry not found!");
|
dbFullName,
|
||||||
}
|
dbSchema,
|
||||||
|
tableName,
|
||||||
let tableID = await createTableHandleTableRecord({
|
|
||||||
recordedDbEntry,
|
|
||||||
tableSchema,
|
tableSchema,
|
||||||
update: true,
|
|
||||||
isMain,
|
isMain,
|
||||||
|
recordedDbEntry,
|
||||||
});
|
});
|
||||||
|
|
||||||
if (!tableID && !isMain) {
|
|
||||||
throw new Error("Recorded Table entry not found!");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Handle Table Default Collation
|
|
||||||
*
|
|
||||||
* @description Update Column Collation
|
|
||||||
*/
|
|
||||||
if (tableSchema.collation) {
|
|
||||||
try {
|
|
||||||
const existingCollation = (await dbHandler({
|
|
||||||
query: `SHOW TABLE STATUS LIKE '${tableName}'`,
|
|
||||||
config: { database: dbFullName },
|
|
||||||
})) as any[];
|
|
||||||
|
|
||||||
const existingCollationStr = existingCollation?.[0].Collation;
|
|
||||||
|
|
||||||
if (existingCollationStr !== tableSchema.collation) {
|
|
||||||
await dbHandler({
|
|
||||||
query: `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` CONVERT TO CHARACTER SET utf8mb4 COLLATE ${tableSchema.collation}`,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
} catch (error) {}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handle Table updates
|
* Handle Table updates
|
||||||
*
|
*
|
||||||
* @description Try to undate table, catch error if anything goes wrong
|
* @description Try to undate table, catch error if anything goes wrong
|
||||||
*/
|
*/
|
||||||
try {
|
try {
|
||||||
|
const { allExistingColumns, upToDateTableFieldsArray } =
|
||||||
|
await handleMariaDBExistingColumns({
|
||||||
|
dbFullName,
|
||||||
|
dbSchema,
|
||||||
|
fields: tableFields,
|
||||||
|
tableName,
|
||||||
|
userId,
|
||||||
|
});
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handle MYSQL Table Indexes
|
* Handle DATASQUIREL schema fields for current table
|
||||||
* ===================================================
|
* ===================================================
|
||||||
* @description Iterate through each table index(if available)
|
* @description Iterate through each field object and
|
||||||
* and perform operations
|
* perform operations
|
||||||
*/
|
*/
|
||||||
const allExistingIndexes = (await dbHandler({
|
await handleDSQLSchemaFields({
|
||||||
query: `SHOW INDEXES FROM \`${dbFullName}\`.\`${tableName}\` WHERE Index_comment LIKE '%schema_index%'`,
|
dbFullName,
|
||||||
})) as DSQL_MYSQL_SHOW_INDEXES_Type[] | null;
|
tableName,
|
||||||
|
fields: upToDateTableFieldsArray,
|
||||||
|
allExistingColumns,
|
||||||
|
});
|
||||||
|
|
||||||
if (allExistingIndexes) {
|
/**
|
||||||
for (let f = 0; f < allExistingIndexes.length; f++) {
|
* Handle MYSQL Foreign Keys
|
||||||
const { Key_name } = allExistingIndexes[f];
|
* ===================================================
|
||||||
|
* @description Iterate through each datasquirel schema
|
||||||
try {
|
* table index(if available), and perform operations
|
||||||
const existingKeyInSchema = tableIndexes?.find(
|
*/
|
||||||
(indexObject) => indexObject.alias === Key_name
|
await handleTableForeignKey({
|
||||||
);
|
dbFullName,
|
||||||
if (!existingKeyInSchema)
|
fields: upToDateTableFieldsArray,
|
||||||
throw new Error(
|
tableName,
|
||||||
`This Index(${Key_name}) Has been Deleted!`
|
clone,
|
||||||
);
|
});
|
||||||
} catch (error) {
|
|
||||||
/**
|
|
||||||
* @description Drop Index: This happens when the MYSQL index is not
|
|
||||||
* present in the datasquirel DB schema
|
|
||||||
*/
|
|
||||||
await dbHandler({
|
|
||||||
query: `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` DROP INDEX \`${Key_name}\``,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handle DATASQUIREL Table Indexes
|
* Handle DATASQUIREL Table Indexes
|
||||||
@ -160,7 +103,7 @@ export default async function updateTable({
|
|||||||
* @description Iterate through each datasquirel schema
|
* @description Iterate through each datasquirel schema
|
||||||
* table index(if available), and perform operations
|
* table index(if available), and perform operations
|
||||||
*/
|
*/
|
||||||
if (tableIndexes && tableIndexes[0]) {
|
if (tableIndexes?.[0]) {
|
||||||
handleIndexescreateDbFromSchema({
|
handleIndexescreateDbFromSchema({
|
||||||
dbFullName,
|
dbFullName,
|
||||||
indexes: tableIndexes,
|
indexes: tableIndexes,
|
||||||
@ -169,274 +112,21 @@ export default async function updateTable({
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handle MYSQL Foreign Keys
|
* Handle DATASQUIREL Table Unique Indexes
|
||||||
* ===================================================
|
* ===================================================
|
||||||
* @description Iterate through each datasquirel schema
|
* @description Iterate through each datasquirel schema
|
||||||
* table index(if available), and perform operations
|
* table unique constraint(if available), and perform operations
|
||||||
*/
|
*/
|
||||||
const allForeignKeys = (await dbHandler({
|
if (tableUniqueConstraints?.[0]) {
|
||||||
query: `SELECT CONSTRAINT_NAME FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS WHERE CONSTRAINT_SCHEMA = '${dbFullName}' AND TABLE_NAME='${tableName}' AND CONSTRAINT_TYPE='FOREIGN KEY'`,
|
handleUniqueConstraintsCreateDbFromSchema({
|
||||||
})) as DSQL_MYSQL_FOREIGN_KEYS_Type[] | null;
|
dbFullName,
|
||||||
|
tableUniqueConstraints,
|
||||||
if (allForeignKeys) {
|
tableName,
|
||||||
for (let c = 0; c < allForeignKeys.length; c++) {
|
|
||||||
const { CONSTRAINT_NAME } = allForeignKeys[c];
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @description Skip if Key is the PRIMARY Key
|
|
||||||
*/
|
|
||||||
if (CONSTRAINT_NAME.match(/PRIMARY/)) continue;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @description Drop all foreign Keys to avoid MYSQL errors when adding/updating
|
|
||||||
* Foreign keys
|
|
||||||
*/
|
|
||||||
await dbHandler({
|
|
||||||
query: `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` DROP FOREIGN KEY \`${CONSTRAINT_NAME}\``,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Handle MYSQL Unique Fields
|
|
||||||
* ===================================================
|
|
||||||
* @description Find all existing unique field constraints
|
|
||||||
* and remove them
|
|
||||||
*/
|
|
||||||
const allUniqueConstraints = (await dbHandler({
|
|
||||||
query: normalizeText(`SELECT CONSTRAINT_NAME FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS \
|
|
||||||
WHERE CONSTRAINT_SCHEMA = '${dbFullName}' AND TABLE_NAME='${tableName}' AND \
|
|
||||||
CONSTRAINT_TYPE='UNIQUE'`),
|
|
||||||
})) as DSQL_MYSQL_FOREIGN_KEYS_Type[] | null;
|
|
||||||
|
|
||||||
if (allUniqueConstraints) {
|
|
||||||
for (let c = 0; c < allUniqueConstraints.length; c++) {
|
|
||||||
const { CONSTRAINT_NAME } = allUniqueConstraints[c];
|
|
||||||
await dbHandler({
|
|
||||||
query: `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` DROP INDEX \`${CONSTRAINT_NAME}\``,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Handle MYSQL Columns (Fields)
|
|
||||||
* ===================================================
|
|
||||||
* @description Now handle all fields/columns
|
|
||||||
*/
|
|
||||||
let allExistingColumns: DSQL_MYSQL_SHOW_COLUMNS_Type[] =
|
|
||||||
(await dbHandler({
|
|
||||||
query: `SHOW COLUMNS FROM \`${dbFullName}\`.\`${tableName}\``,
|
|
||||||
})) as DSQL_MYSQL_SHOW_COLUMNS_Type[];
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @type {string[]}
|
|
||||||
* @description Updated column names Array
|
|
||||||
*/
|
|
||||||
const updatedColumnsArray: string[] = [];
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @description Iterate through every existing column
|
|
||||||
*/
|
|
||||||
for (let e = 0; e < allExistingColumns.length; e++) {
|
|
||||||
const { Field } = allExistingColumns[e];
|
|
||||||
|
|
||||||
if (Field.match(defaultFieldsRegexp)) continue;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @description This finds out whether the fieldName corresponds with the MSQL Field name
|
|
||||||
* if the fildName doesn't match any MYSQL Field name, the field is deleted.
|
|
||||||
*/
|
|
||||||
let existingEntry = upToDateTableFieldsArray.find(
|
|
||||||
(column) =>
|
|
||||||
column.fieldName === Field || column.originName === Field
|
|
||||||
);
|
|
||||||
|
|
||||||
if (existingEntry) {
|
|
||||||
/**
|
|
||||||
* @description Check if Field name has been updated
|
|
||||||
*/
|
|
||||||
if (existingEntry.updatedField && existingEntry.fieldName) {
|
|
||||||
updatedColumnsArray.push(existingEntry.fieldName);
|
|
||||||
|
|
||||||
await dbHandler({
|
|
||||||
query: `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` RENAME COLUMN \`${existingEntry.originName}\` TO \`${existingEntry.fieldName}\``,
|
|
||||||
});
|
|
||||||
|
|
||||||
console.log(
|
|
||||||
`Column Renamed from "${existingEntry.originName}" to "${existingEntry.fieldName}"`
|
|
||||||
);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Update Db Schema
|
|
||||||
* ===================================================
|
|
||||||
* @description Update Db Schema after renaming column
|
|
||||||
*/
|
|
||||||
try {
|
|
||||||
const updatedSchemaData = _.cloneDeep(dbSchema);
|
|
||||||
|
|
||||||
const targetTableIndex =
|
|
||||||
updatedSchemaData.tables.findIndex(
|
|
||||||
(table) => table.tableName === tableName
|
|
||||||
);
|
|
||||||
const targetFieldIndex = updatedSchemaData.tables[
|
|
||||||
targetTableIndex
|
|
||||||
].fields.findIndex(
|
|
||||||
(field) =>
|
|
||||||
field.fieldName === existingEntry.fieldName
|
|
||||||
);
|
|
||||||
|
|
||||||
delete updatedSchemaData.tables[targetTableIndex]
|
|
||||||
.fields[targetFieldIndex]["originName"];
|
|
||||||
delete updatedSchemaData.tables[targetTableIndex]
|
|
||||||
.fields[targetFieldIndex]["updatedField"];
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @description Set New Table Fields Array
|
|
||||||
*/
|
|
||||||
upToDateTableFieldsArray =
|
|
||||||
updatedSchemaData.tables[targetTableIndex].fields;
|
|
||||||
|
|
||||||
if (userId) {
|
|
||||||
writeUpdatedDbSchema({
|
|
||||||
dbSchema: updatedSchemaData,
|
|
||||||
userId,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
allExistingColumns = (await dbHandler({
|
|
||||||
query: `SHOW COLUMNS FROM \`${dbFullName}\`.\`${tableName}\``,
|
|
||||||
})) as DSQL_MYSQL_SHOW_COLUMNS_Type[];
|
|
||||||
} catch (error: any) {
|
|
||||||
console.log("Update table error =>", error.message);
|
|
||||||
}
|
|
||||||
|
|
||||||
////////////////////////////////////////
|
|
||||||
}
|
|
||||||
|
|
||||||
////////////////////////////////////////
|
|
||||||
|
|
||||||
continue;
|
|
||||||
|
|
||||||
////////////////////////////////////////
|
|
||||||
} else {
|
|
||||||
await dbHandler({
|
|
||||||
query: `ALTER TABLE \`${dbFullName}\`.\`${tableName}\` DROP COLUMN \`${Field}\``,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Handle DATASQUIREL schema fields for current table
|
|
||||||
* ===================================================
|
|
||||||
* @description Iterate through each field object and
|
|
||||||
* perform operations
|
|
||||||
*/
|
|
||||||
for (let i = 0; i < upToDateTableFieldsArray.length; i++) {
|
|
||||||
const column = upToDateTableFieldsArray[i];
|
|
||||||
// const prevColumn = upToDateTableFieldsArray[i - 1];
|
|
||||||
// const nextColumn = upToDateTableFieldsArray[i + 1];
|
|
||||||
|
|
||||||
const { fieldName, dataType, foreignKey } = column;
|
|
||||||
|
|
||||||
if (!fieldName) continue;
|
|
||||||
if (defaultFieldsRegexp.test(fieldName)) continue;
|
|
||||||
|
|
||||||
let updateText = "";
|
|
||||||
|
|
||||||
const existingColumnIndex = allExistingColumns?.findIndex(
|
|
||||||
(_column, _index) => _column.Field === fieldName
|
|
||||||
);
|
|
||||||
|
|
||||||
const existingColumn =
|
|
||||||
existingColumnIndex >= 0
|
|
||||||
? allExistingColumns[existingColumnIndex]
|
|
||||||
: undefined;
|
|
||||||
|
|
||||||
let { fieldEntryText } = generateColumnDescription({
|
|
||||||
columnData: column,
|
|
||||||
});
|
});
|
||||||
|
|
||||||
/**
|
|
||||||
* @description Modify Column(Field) if it already exists
|
|
||||||
* in MYSQL database
|
|
||||||
*/
|
|
||||||
if (existingColumn?.Field) {
|
|
||||||
const { Field, Type } = existingColumn;
|
|
||||||
|
|
||||||
updateText += `MODIFY COLUMN ${fieldEntryText}`;
|
|
||||||
|
|
||||||
// if (
|
|
||||||
// Field === fieldName &&
|
|
||||||
// dataType?.toUpperCase() === Type.toUpperCase()
|
|
||||||
// ) {
|
|
||||||
// } else {
|
|
||||||
// updateText += `MODIFY COLUMN ${fieldEntryText}`;
|
|
||||||
// }
|
|
||||||
} else {
|
|
||||||
/**
|
|
||||||
* @description Append new column to the end of existing columns
|
|
||||||
*/
|
|
||||||
updateText += `ADD COLUMN ${fieldEntryText}`;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @description Pust SQL code snippet to updateTableQueryArray Array
|
|
||||||
* Add a comma(,) to separate from the next snippet
|
|
||||||
*/
|
|
||||||
if (updateText.match(/./)) {
|
|
||||||
updateTableQueryArray.push(updateText + ",");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @description Construct final SQL query by combning all SQL snippets in
|
|
||||||
* updateTableQueryArray Arry, and trimming the final comma(,)
|
|
||||||
*/
|
|
||||||
const updateTableQuery = updateTableQueryArray
|
|
||||||
.filter((q) => Boolean(q.match(/./)))
|
|
||||||
.join(" ")
|
|
||||||
.replace(/,$/, "");
|
|
||||||
|
|
||||||
////////////////////////////////////////
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @description Check if SQL snippets array has more than 1 entries
|
|
||||||
* This is because 1 entry means "ALTER TABLE table_name" only, without any
|
|
||||||
* Alter directives like "ADD COLUMN" or "MODIFY COLUMN"
|
|
||||||
*/
|
|
||||||
if (updateTableQueryArray.length > 1) {
|
|
||||||
const updateTable = await dbHandler({
|
|
||||||
query: updateTableQuery,
|
|
||||||
});
|
|
||||||
|
|
||||||
/**
|
|
||||||
* # Handle Foreign Keys
|
|
||||||
*/
|
|
||||||
await dropAllForeignKeys({ dbFullName, tableName });
|
|
||||||
|
|
||||||
for (let i = 0; i < upToDateTableFieldsArray.length; i++) {
|
|
||||||
const { fieldName, foreignKey } = upToDateTableFieldsArray[i];
|
|
||||||
if (!clone && foreignKey && fieldName) {
|
|
||||||
await handleTableForeignKey({
|
|
||||||
dbFullName,
|
|
||||||
errorLogs,
|
|
||||||
foreignKey,
|
|
||||||
fieldName,
|
|
||||||
tableName,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
/**
|
|
||||||
* @description If only 1 SQL snippet is left in updateTableQueryArray, this
|
|
||||||
* means that no updates have been made to the table
|
|
||||||
*/
|
|
||||||
}
|
|
||||||
|
|
||||||
return tableID;
|
|
||||||
} catch (error: any) {
|
} catch (error: any) {
|
||||||
console.log('Error in "updateTable" shell function =>', error.message);
|
console.log('Error in "updateTable" shell function =>', error.message);
|
||||||
|
|
||||||
return tableID;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return tableID;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -23,6 +23,7 @@ import type DataTypes from "../data/data-types";
|
|||||||
import type { IncomingMessage, ServerResponse } from "http";
|
import type { IncomingMessage, ServerResponse } from "http";
|
||||||
import type { CookieNames } from "../dict/cookie-names";
|
import type { CookieNames } from "../dict/cookie-names";
|
||||||
import { ConnectionConfig } from "mariadb";
|
import { ConnectionConfig } from "mariadb";
|
||||||
|
import { DbContextsArray } from "../functions/backend/db/runQuery";
|
||||||
|
|
||||||
export type DSQL_DatabaseFullName = string;
|
export type DSQL_DatabaseFullName = string;
|
||||||
|
|
||||||
@ -98,6 +99,7 @@ export interface DSQL_TableSchemaType {
|
|||||||
tableDescription?: string;
|
tableDescription?: string;
|
||||||
fields: DSQL_FieldSchemaType[];
|
fields: DSQL_FieldSchemaType[];
|
||||||
indexes?: DSQL_IndexSchemaType[];
|
indexes?: DSQL_IndexSchemaType[];
|
||||||
|
uniqueConstraints?: DSQL_UniqueConstraintSchemaType[];
|
||||||
childrenTables?: DSQL_ChildrenTablesType[];
|
childrenTables?: DSQL_ChildrenTablesType[];
|
||||||
childTable?: boolean;
|
childTable?: boolean;
|
||||||
updateData?: boolean;
|
updateData?: boolean;
|
||||||
@ -178,6 +180,17 @@ export interface DSQL_IndexSchemaType {
|
|||||||
newTempIndex?: boolean;
|
newTempIndex?: boolean;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export interface DSQL_UniqueConstraintSchemaType {
|
||||||
|
id?: string | number;
|
||||||
|
constraintName?: string;
|
||||||
|
alias?: string;
|
||||||
|
constraintTableFields?: DSQL_UniqueConstraintFieldType[];
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface DSQL_UniqueConstraintFieldType {
|
||||||
|
value: string;
|
||||||
|
}
|
||||||
|
|
||||||
export interface DSQL_IndexTableFieldType {
|
export interface DSQL_IndexTableFieldType {
|
||||||
value: string;
|
value: string;
|
||||||
dataType: string;
|
dataType: string;
|
||||||
@ -203,6 +216,22 @@ export interface DSQL_MYSQL_SHOW_COLUMNS_Type {
|
|||||||
Extra: string;
|
Extra: string;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export interface DSQL_MARIADB_SHOW_INDEXES_TYPE {
|
||||||
|
Table: string;
|
||||||
|
Non_unique: 0 | 1;
|
||||||
|
Key_name: string;
|
||||||
|
Seq_in_index: number;
|
||||||
|
Column_name: string;
|
||||||
|
Collation: string;
|
||||||
|
Cardinality: number;
|
||||||
|
Sub_part?: string;
|
||||||
|
Packed?: string;
|
||||||
|
Index_type?: "BTREE";
|
||||||
|
Comment?: string;
|
||||||
|
Index_comment?: string;
|
||||||
|
Ignored?: "YES" | "NO";
|
||||||
|
}
|
||||||
|
|
||||||
export interface DSQL_MYSQL_FOREIGN_KEYS_Type {
|
export interface DSQL_MYSQL_FOREIGN_KEYS_Type {
|
||||||
CONSTRAINT_NAME: string;
|
CONSTRAINT_NAME: string;
|
||||||
CONSTRAINT_SCHEMA: string;
|
CONSTRAINT_SCHEMA: string;
|
||||||
@ -1541,6 +1570,7 @@ export type DsqlCrudParam<
|
|||||||
dbName?: string;
|
dbName?: string;
|
||||||
tableSchema?: DSQL_TableSchemaType;
|
tableSchema?: DSQL_TableSchemaType;
|
||||||
dbConfig?: ConnectionConfig;
|
dbConfig?: ConnectionConfig;
|
||||||
|
onDuplicate?: AddDbEntryParamOnDuplicate;
|
||||||
};
|
};
|
||||||
|
|
||||||
export type DsqlCrudParamWhereClause = {
|
export type DsqlCrudParamWhereClause = {
|
||||||
@ -1939,10 +1969,13 @@ export const FileMimeTypes = [
|
|||||||
export const CurrentlyEditedFieldActions = [
|
export const CurrentlyEditedFieldActions = [
|
||||||
"edit-field",
|
"edit-field",
|
||||||
"edit-index",
|
"edit-index",
|
||||||
|
"edit-unique-constraint",
|
||||||
"delete-field",
|
"delete-field",
|
||||||
"delete-index",
|
"delete-index",
|
||||||
|
"delete-unique-constraint",
|
||||||
"new-field",
|
"new-field",
|
||||||
"new-index",
|
"new-index",
|
||||||
|
"new-unique-constraint",
|
||||||
"move-up",
|
"move-up",
|
||||||
"move-down",
|
"move-down",
|
||||||
"complete",
|
"complete",
|
||||||
@ -1952,6 +1985,8 @@ export type CurrentlyEditedTableSchemaType = {
|
|||||||
action: (typeof CurrentlyEditedFieldActions)[number];
|
action: (typeof CurrentlyEditedFieldActions)[number];
|
||||||
field?: DSQL_FieldSchemaType;
|
field?: DSQL_FieldSchemaType;
|
||||||
fieldIndex?: number;
|
fieldIndex?: number;
|
||||||
|
uniqueConstraint?: DSQL_UniqueConstraintSchemaType;
|
||||||
|
uniqueConstraintIndex?: number;
|
||||||
index?: DSQL_IndexSchemaType;
|
index?: DSQL_IndexSchemaType;
|
||||||
indexIndex?: number;
|
indexIndex?: number;
|
||||||
spliceIndex?: number;
|
spliceIndex?: number;
|
||||||
@ -3001,3 +3036,34 @@ export type DSQLFetchApiOptions<
|
|||||||
csrfKey?: string;
|
csrfKey?: string;
|
||||||
fetchOptions?: RequestInit;
|
fetchOptions?: RequestInit;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
export type AddDbEntryParam<
|
||||||
|
T extends { [k: string]: any } = any,
|
||||||
|
K extends string = string
|
||||||
|
> = {
|
||||||
|
dbContext?: (typeof DbContextsArray)[number];
|
||||||
|
paradigm?: "Read Only" | "Full Access";
|
||||||
|
dbFullName?: string;
|
||||||
|
tableName: K;
|
||||||
|
data?: T;
|
||||||
|
batchData?: T[];
|
||||||
|
tableSchema?: DSQL_TableSchemaType;
|
||||||
|
duplicateColumnName?: keyof T;
|
||||||
|
duplicateColumnValue?: string | number;
|
||||||
|
/**
|
||||||
|
* Update Entry if a duplicate is found.
|
||||||
|
* Requires `duplicateColumnName` and `duplicateColumnValue` parameters
|
||||||
|
*/
|
||||||
|
update?: boolean;
|
||||||
|
encryptionKey?: string;
|
||||||
|
encryptionSalt?: string;
|
||||||
|
forceLocal?: boolean;
|
||||||
|
debug?: boolean;
|
||||||
|
dbConfig?: ConnectionConfig;
|
||||||
|
onDuplicate?: AddDbEntryParamOnDuplicate;
|
||||||
|
};
|
||||||
|
|
||||||
|
export type AddDbEntryParamOnDuplicate = {
|
||||||
|
sql: string;
|
||||||
|
values?: string[];
|
||||||
|
};
|
||||||
|
|||||||
@ -33,6 +33,7 @@ export default async function dsqlCrud<
|
|||||||
deleteKeyValuesOperator,
|
deleteKeyValuesOperator,
|
||||||
dbConfig,
|
dbConfig,
|
||||||
query,
|
query,
|
||||||
|
onDuplicate,
|
||||||
} = params;
|
} = params;
|
||||||
|
|
||||||
const finalData = (sanitize ? sanitize({ data }) : data) as T;
|
const finalData = (sanitize ? sanitize({ data }) : data) as T;
|
||||||
@ -65,9 +66,6 @@ export default async function dsqlCrud<
|
|||||||
case "get":
|
case "get":
|
||||||
return await dsqlCrudGet<T, K>(params);
|
return await dsqlCrudGet<T, K>(params);
|
||||||
|
|
||||||
// case "batch-get":
|
|
||||||
// return await dsqlCrudBatchGet(params);
|
|
||||||
|
|
||||||
case "insert":
|
case "insert":
|
||||||
const INSERT_RESULT = await addDbEntry({
|
const INSERT_RESULT = await addDbEntry({
|
||||||
data: finalData,
|
data: finalData,
|
||||||
@ -77,7 +75,9 @@ export default async function dsqlCrud<
|
|||||||
debug,
|
debug,
|
||||||
tableSchema,
|
tableSchema,
|
||||||
dbConfig,
|
dbConfig,
|
||||||
|
onDuplicate,
|
||||||
});
|
});
|
||||||
|
|
||||||
return INSERT_RESULT;
|
return INSERT_RESULT;
|
||||||
|
|
||||||
case "update":
|
case "update":
|
||||||
|
|||||||
@ -84,10 +84,17 @@ export default function ({
|
|||||||
targetChildTableParentDatabase.tables[
|
targetChildTableParentDatabase.tables[
|
||||||
targetChildTableParentDatabaseTableIndex
|
targetChildTableParentDatabaseTableIndex
|
||||||
].fields = [...currentTableSchema.fields];
|
].fields = [...currentTableSchema.fields];
|
||||||
|
|
||||||
targetChildTableParentDatabase.tables[
|
targetChildTableParentDatabase.tables[
|
||||||
targetChildTableParentDatabaseTableIndex
|
targetChildTableParentDatabaseTableIndex
|
||||||
].indexes = [...(currentTableSchema.indexes || [])];
|
].indexes = [...(currentTableSchema.indexes || [])];
|
||||||
|
|
||||||
|
targetChildTableParentDatabase.tables[
|
||||||
|
targetChildTableParentDatabaseTableIndex
|
||||||
|
].uniqueConstraints = [
|
||||||
|
...(currentTableSchema.uniqueConstraints || []),
|
||||||
|
];
|
||||||
|
|
||||||
writeUpdatedDbSchema({
|
writeUpdatedDbSchema({
|
||||||
dbSchema: targetChildTableParentDatabase,
|
dbSchema: targetChildTableParentDatabase,
|
||||||
userId,
|
userId,
|
||||||
@ -221,6 +228,9 @@ export default function ({
|
|||||||
targetParentDatabaseTable.fields;
|
targetParentDatabaseTable.fields;
|
||||||
newCurrentDbSchema.tables[currentTableSchemaIndex].indexes =
|
newCurrentDbSchema.tables[currentTableSchemaIndex].indexes =
|
||||||
targetParentDatabaseTable.indexes;
|
targetParentDatabaseTable.indexes;
|
||||||
|
newCurrentDbSchema.tables[
|
||||||
|
currentTableSchemaIndex
|
||||||
|
].uniqueConstraints = targetParentDatabaseTable.uniqueConstraints;
|
||||||
|
|
||||||
writeUpdatedDbSchema({ dbSchema: targetParentDatabase, userId });
|
writeUpdatedDbSchema({ dbSchema: targetParentDatabase, userId });
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,5 +1,5 @@
|
|||||||
type Param = {
|
type Param = {
|
||||||
type: "foreign_key" | "index" | "user";
|
type: "foreign_key" | "index" | "user" | "unique_constraint";
|
||||||
userId?: string | number;
|
userId?: string | number;
|
||||||
addDate?: boolean;
|
addDate?: boolean;
|
||||||
};
|
};
|
||||||
@ -10,15 +10,21 @@ type Param = {
|
|||||||
*/
|
*/
|
||||||
export default function grabSQLKeyName({ type, userId, addDate }: Param) {
|
export default function grabSQLKeyName({ type, userId, addDate }: Param) {
|
||||||
let prefixParadigm = (() => {
|
let prefixParadigm = (() => {
|
||||||
|
if (type == "unique_constraint") return "unq";
|
||||||
if (type == "foreign_key") return "fk";
|
if (type == "foreign_key") return "fk";
|
||||||
if (type == "index") return "indx";
|
if (type == "index") return "indx";
|
||||||
if (type == "user") return "user";
|
if (type == "user") return "user";
|
||||||
return null;
|
return null;
|
||||||
})();
|
})();
|
||||||
|
|
||||||
|
const uuid = crypto.randomUUID();
|
||||||
|
const uidPrefx = uuid.split("-")[0];
|
||||||
|
|
||||||
let key = `dsql`;
|
let key = `dsql`;
|
||||||
|
|
||||||
if (prefixParadigm) key += `_${prefixParadigm}`;
|
if (prefixParadigm) key += `_${prefixParadigm}`;
|
||||||
if (userId) key += `_${userId}`;
|
if (userId) key += `_${userId}`;
|
||||||
if (addDate) key += `_${Date.now()}`;
|
if (addDate) key += `_${uidPrefx}`;
|
||||||
|
|
||||||
return key;
|
return key;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@moduletrace/datasquirel",
|
"name": "@moduletrace/datasquirel",
|
||||||
"version": "5.7.15",
|
"version": "5.7.16",
|
||||||
"description": "Cloud-based SQL data management tool",
|
"description": "Cloud-based SQL data management tool",
|
||||||
"main": "dist/index.js",
|
"main": "dist/index.js",
|
||||||
"bin": {
|
"bin": {
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user