108 lines
4.7 KiB
JavaScript
108 lines
4.7 KiB
JavaScript
"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 = updateTable;
|
|
const handle_indexes_1 = __importDefault(require("../createDbFromSchema/handle-indexes"));
|
|
const handle_unique_constraints_1 = __importDefault(require("../createDbFromSchema/handle-unique-constraints"));
|
|
const handle_table_foreign_key_1 = __importDefault(require("./handle-table-foreign-key"));
|
|
const handle_dsql_schema_fields_1 = __importDefault(require("./handle-dsql-schema-fields"));
|
|
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
|
|
*/
|
|
function updateTable(_a) {
|
|
return __awaiter(this, arguments, void 0, function* ({ dbFullName, tableName, tableFields, userId, dbSchema, tableIndexes, tableSchema, clone, recordedDbEntry, isMain, tableUniqueConstraints, }) {
|
|
/**
|
|
* @description Grab Table Record
|
|
*/
|
|
const { tableID } = yield (0, update_table_init_1.default)({
|
|
dbFullName,
|
|
dbSchema,
|
|
tableName,
|
|
tableSchema,
|
|
isMain,
|
|
recordedDbEntry,
|
|
});
|
|
/**
|
|
* Handle Table updates
|
|
*
|
|
* @description Try to undate table, catch error if anything goes wrong
|
|
*/
|
|
try {
|
|
const { allExistingColumns, upToDateTableFieldsArray } = yield (0, handle_mariadb_existing_columns_1.default)({
|
|
dbFullName,
|
|
dbSchema,
|
|
fields: tableFields,
|
|
tableName,
|
|
userId,
|
|
});
|
|
/**
|
|
* Handle DATASQUIREL schema fields for current table
|
|
* ===================================================
|
|
* @description Iterate through each field object and
|
|
* perform operations
|
|
*/
|
|
yield (0, handle_dsql_schema_fields_1.default)({
|
|
dbFullName,
|
|
tableName,
|
|
fields: upToDateTableFieldsArray,
|
|
allExistingColumns,
|
|
});
|
|
/**
|
|
* Handle MYSQL Foreign Keys
|
|
* ===================================================
|
|
* @description Iterate through each datasquirel schema
|
|
* table index(if available), and perform operations
|
|
*/
|
|
yield (0, handle_table_foreign_key_1.default)({
|
|
dbFullName,
|
|
fields: upToDateTableFieldsArray,
|
|
tableName,
|
|
clone,
|
|
});
|
|
/**
|
|
* Handle DATASQUIREL Table Indexes
|
|
* ===================================================
|
|
* @description Iterate through each datasquirel schema
|
|
* table index(if available), and perform operations
|
|
*/
|
|
if (tableIndexes === null || tableIndexes === void 0 ? void 0 : tableIndexes[0]) {
|
|
(0, handle_indexes_1.default)({
|
|
dbFullName,
|
|
indexes: tableIndexes,
|
|
tableName,
|
|
});
|
|
}
|
|
/**
|
|
* Handle DATASQUIREL Table Unique Indexes
|
|
* ===================================================
|
|
* @description Iterate through each datasquirel schema
|
|
* table unique constraint(if available), and perform operations
|
|
*/
|
|
if (tableUniqueConstraints === null || tableUniqueConstraints === void 0 ? void 0 : tableUniqueConstraints[0]) {
|
|
(0, handle_unique_constraints_1.default)({
|
|
dbFullName,
|
|
tableUniqueConstraints,
|
|
tableName,
|
|
});
|
|
}
|
|
}
|
|
catch (error) {
|
|
console.log('Error in "updateTable" shell function =>', error.message);
|
|
}
|
|
return tableID;
|
|
});
|
|
}
|