"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; }); }