Updates
This commit is contained in:
parent
27887ded41
commit
0dc8f3c787
@ -51,7 +51,10 @@ function checks(_a) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (method == "GET" && getMiddleware) {
|
if (method == "GET" && getMiddleware) {
|
||||||
newQuery = yield getMiddleware({ query: newQuery || {} });
|
newQuery = yield getMiddleware({
|
||||||
|
query: newQuery || {},
|
||||||
|
table,
|
||||||
|
});
|
||||||
}
|
}
|
||||||
if (method !== "GET" && crudMiddleware) {
|
if (method !== "GET" && crudMiddleware) {
|
||||||
const middRes = yield crudMiddleware({
|
const middRes = yield crudMiddleware({
|
||||||
|
|||||||
13
dist/package-shared/shell/createDbFromSchema/grab-all-user-db-schemas.d.ts
vendored
Normal file
13
dist/package-shared/shell/createDbFromSchema/grab-all-user-db-schemas.d.ts
vendored
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
import { DSQL_DatabaseSchemaType } from "../../types";
|
||||||
|
type Params = {
|
||||||
|
userId: string | number | null;
|
||||||
|
parentDbId?: number | string | null;
|
||||||
|
parentTableId?: number | string | null;
|
||||||
|
};
|
||||||
|
/**
|
||||||
|
* # Grab All Database Schemas from Directory
|
||||||
|
* @param params
|
||||||
|
* @returns
|
||||||
|
*/
|
||||||
|
export default function grabAllDbSchemas({ userId, parentDbId, parentTableId, }: Params): DSQL_DatabaseSchemaType[] | undefined;
|
||||||
|
export {};
|
||||||
54
dist/package-shared/shell/createDbFromSchema/grab-all-user-db-schemas.js
vendored
Normal file
54
dist/package-shared/shell/createDbFromSchema/grab-all-user-db-schemas.js
vendored
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
"use strict";
|
||||||
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
||||||
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
||||||
|
};
|
||||||
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
|
exports.default = grabAllDbSchemas;
|
||||||
|
const fs_1 = __importDefault(require("fs"));
|
||||||
|
const path_1 = __importDefault(require("path"));
|
||||||
|
const grab_dir_names_1 = __importDefault(require("../../utils/backend/names/grab-dir-names"));
|
||||||
|
const ejson_1 = __importDefault(require("../../utils/ejson"));
|
||||||
|
const numberfy_1 = __importDefault(require("../../utils/numberfy"));
|
||||||
|
/**
|
||||||
|
* # Grab All Database Schemas from Directory
|
||||||
|
* @param params
|
||||||
|
* @returns
|
||||||
|
*/
|
||||||
|
function grabAllDbSchemas({ userId, parentDbId, parentTableId, }) {
|
||||||
|
try {
|
||||||
|
let dbSchemas = [];
|
||||||
|
const { targetUserPrivateDir } = (0, grab_dir_names_1.default)({
|
||||||
|
userId,
|
||||||
|
});
|
||||||
|
if (!targetUserPrivateDir) {
|
||||||
|
console.log(`targetUserPrivateDir not found!`);
|
||||||
|
return undefined;
|
||||||
|
}
|
||||||
|
const dbSchemasFiles = fs_1.default.readdirSync(targetUserPrivateDir);
|
||||||
|
for (let i = 0; i < dbSchemasFiles.length; i++) {
|
||||||
|
try {
|
||||||
|
const dbSchemaFile = dbSchemasFiles[i];
|
||||||
|
const fullPath = path_1.default.join(targetUserPrivateDir, dbSchemaFile);
|
||||||
|
const json = fs_1.default.readFileSync(fullPath, "utf-8");
|
||||||
|
const dbSchema = ejson_1.default.parse(json);
|
||||||
|
if (!dbSchema) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if (parentDbId) {
|
||||||
|
const isDbChild = (0, numberfy_1.default)(dbSchema.childDatabaseDbId) ==
|
||||||
|
(0, numberfy_1.default)(parentDbId);
|
||||||
|
if (isDbChild) {
|
||||||
|
dbSchemas.push(dbSchema);
|
||||||
|
}
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
dbSchemas.push(dbSchema);
|
||||||
|
}
|
||||||
|
catch (error) { }
|
||||||
|
}
|
||||||
|
return dbSchemas;
|
||||||
|
}
|
||||||
|
catch (error) {
|
||||||
|
return undefined;
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -4,6 +4,11 @@ type Params = {
|
|||||||
dbId?: string | number;
|
dbId?: string | number;
|
||||||
dbSlug?: string;
|
dbSlug?: string;
|
||||||
};
|
};
|
||||||
|
/**
|
||||||
|
* # Grab Database Schemas related to a database
|
||||||
|
* @param params
|
||||||
|
* @returns
|
||||||
|
*/
|
||||||
export default function grabRequiredDatabaseSchemas(params: Params): DSQL_DatabaseSchemaType[] | undefined;
|
export default function grabRequiredDatabaseSchemas(params: Params): DSQL_DatabaseSchemaType[] | undefined;
|
||||||
export declare function grabPrimaryRequiredDbSchema({ userId, dbId, dbSlug }: Params): DSQL_DatabaseSchemaType | undefined;
|
export declare function grabPrimaryRequiredDbSchema({ userId, dbId, dbSlug }: Params): DSQL_DatabaseSchemaType | undefined;
|
||||||
export declare function findDbNameInSchemaDir({ userId, dbName, }: {
|
export declare function findDbNameInSchemaDir({ userId, dbName, }: {
|
||||||
|
|||||||
@ -16,6 +16,11 @@ const grab_dir_names_1 = __importDefault(require("../../utils/backend/names/grab
|
|||||||
const ejson_1 = __importDefault(require("../../utils/ejson"));
|
const ejson_1 = __importDefault(require("../../utils/ejson"));
|
||||||
const numberfy_1 = __importDefault(require("../../utils/numberfy"));
|
const numberfy_1 = __importDefault(require("../../utils/numberfy"));
|
||||||
const unique_by_key_1 = __importDefault(require("../../utils/unique-by-key"));
|
const unique_by_key_1 = __importDefault(require("../../utils/unique-by-key"));
|
||||||
|
/**
|
||||||
|
* # Grab Database Schemas related to a database
|
||||||
|
* @param params
|
||||||
|
* @returns
|
||||||
|
*/
|
||||||
function grabRequiredDatabaseSchemas(params) {
|
function grabRequiredDatabaseSchemas(params) {
|
||||||
const primaryDbSchema = grabPrimaryRequiredDbSchema(params);
|
const primaryDbSchema = grabPrimaryRequiredDbSchema(params);
|
||||||
if (!primaryDbSchema)
|
if (!primaryDbSchema)
|
||||||
|
|||||||
@ -1,37 +1,4 @@
|
|||||||
"use strict";
|
"use strict";
|
||||||
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
||||||
if (k2 === undefined) k2 = k;
|
|
||||||
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
||||||
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
||||||
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
||||||
}
|
|
||||||
Object.defineProperty(o, k2, desc);
|
|
||||||
}) : (function(o, m, k, k2) {
|
|
||||||
if (k2 === undefined) k2 = k;
|
|
||||||
o[k2] = m[k];
|
|
||||||
}));
|
|
||||||
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
||||||
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
||||||
}) : function(o, v) {
|
|
||||||
o["default"] = v;
|
|
||||||
});
|
|
||||||
var __importStar = (this && this.__importStar) || (function () {
|
|
||||||
var ownKeys = function(o) {
|
|
||||||
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
||||||
var ar = [];
|
|
||||||
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
||||||
return ar;
|
|
||||||
};
|
|
||||||
return ownKeys(o);
|
|
||||||
};
|
|
||||||
return function (mod) {
|
|
||||||
if (mod && mod.__esModule) return mod;
|
|
||||||
var result = {};
|
|
||||||
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
||||||
__setModuleDefault(result, mod);
|
|
||||||
return result;
|
|
||||||
};
|
|
||||||
})();
|
|
||||||
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
||||||
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
||||||
return new (P || (P = Promise))(function (resolve, reject) {
|
return new (P || (P = Promise))(function (resolve, reject) {
|
||||||
@ -51,8 +18,9 @@ const updateTable_1 = __importDefault(require("../utils/updateTable"));
|
|||||||
const grab_dir_names_1 = __importDefault(require("../../utils/backend/names/grab-dir-names"));
|
const grab_dir_names_1 = __importDefault(require("../../utils/backend/names/grab-dir-names"));
|
||||||
const check_db_record_1 = __importDefault(require("./check-db-record"));
|
const check_db_record_1 = __importDefault(require("./check-db-record"));
|
||||||
const handle_indexes_1 = __importDefault(require("./handle-indexes"));
|
const handle_indexes_1 = __importDefault(require("./handle-indexes"));
|
||||||
const grab_required_database_schemas_1 = __importStar(require("./grab-required-database-schemas"));
|
const grab_required_database_schemas_1 = require("./grab-required-database-schemas");
|
||||||
const dbHandler_1 = __importDefault(require("../../functions/backend/dbHandler"));
|
const dbHandler_1 = __importDefault(require("../../functions/backend/dbHandler"));
|
||||||
|
const grab_all_user_db_schemas_1 = __importDefault(require("./grab-all-user-db-schemas"));
|
||||||
/**
|
/**
|
||||||
* # Create database from Schema Function
|
* # Create database from Schema Function
|
||||||
* @requires DSQL_DB_CONN - Gobal Variable for Datasquirel Database
|
* @requires DSQL_DB_CONN - Gobal Variable for Datasquirel Database
|
||||||
@ -67,13 +35,15 @@ function createDbFromSchema(_a) {
|
|||||||
let dbSchema = dbSchemaData
|
let dbSchema = dbSchemaData
|
||||||
? dbSchemaData
|
? dbSchemaData
|
||||||
: dbId
|
: dbId
|
||||||
? (0, grab_required_database_schemas_1.default)({
|
? [
|
||||||
dbId,
|
(0, grab_required_database_schemas_1.grabPrimaryRequiredDbSchema)({
|
||||||
userId,
|
dbId,
|
||||||
})
|
userId,
|
||||||
|
}),
|
||||||
|
]
|
||||||
: undefined;
|
: undefined;
|
||||||
if (!dbSchema) {
|
if (!dbSchema) {
|
||||||
console.log("Schema Not Found!");
|
console.log(`Schema Not Found for DB ID ${dbId}!`);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
// fs.writeFileSync(
|
// fs.writeFileSync(
|
||||||
@ -83,7 +53,9 @@ function createDbFromSchema(_a) {
|
|||||||
const isMain = !userSchemaMainJSONFilePath;
|
const isMain = !userSchemaMainJSONFilePath;
|
||||||
for (let i = 0; i < dbSchema.length; i++) {
|
for (let i = 0; i < dbSchema.length; i++) {
|
||||||
const database = dbSchema[i];
|
const database = dbSchema[i];
|
||||||
const { dbFullName, tables, dbSlug, childrenDatabases } = database;
|
if (!database)
|
||||||
|
continue;
|
||||||
|
const { dbFullName, tables, dbSlug } = database;
|
||||||
if (!dbFullName)
|
if (!dbFullName)
|
||||||
continue;
|
continue;
|
||||||
if (targetDatabase && dbFullName != targetDatabase) {
|
if (targetDatabase && dbFullName != targetDatabase) {
|
||||||
@ -225,15 +197,23 @@ function createDbFromSchema(_a) {
|
|||||||
/**
|
/**
|
||||||
* @description Check all children databases
|
* @description Check all children databases
|
||||||
*/
|
*/
|
||||||
if (childrenDatabases === null || childrenDatabases === void 0 ? void 0 : childrenDatabases[0]) {
|
const childrenDatabases = userId
|
||||||
|
? (0, grab_all_user_db_schemas_1.default)({ userId, parentDbId: database.id }) || []
|
||||||
|
: [];
|
||||||
|
if ((childrenDatabases === null || childrenDatabases === void 0 ? void 0 : childrenDatabases[0]) && userId) {
|
||||||
for (let ch = 0; ch < childrenDatabases.length; ch++) {
|
for (let ch = 0; ch < childrenDatabases.length; ch++) {
|
||||||
const childDb = childrenDatabases[ch];
|
const childDb = childrenDatabases[ch];
|
||||||
const { dbId } = childDb;
|
childDb.tables = [...database.tables];
|
||||||
const targetDatabase = dbSchema.find((dbSch) => dbSch.childDatabaseDbId == dbId);
|
childDb.collation = database.collation;
|
||||||
if (targetDatabase === null || targetDatabase === void 0 ? void 0 : targetDatabase.id) {
|
(0, grab_required_database_schemas_1.writeUpdatedDbSchema)({
|
||||||
|
dbSchema: childDb,
|
||||||
|
userId,
|
||||||
|
});
|
||||||
|
if (dbId) {
|
||||||
yield createDbFromSchema({
|
yield createDbFromSchema({
|
||||||
userId,
|
userId,
|
||||||
dbId: targetDatabase === null || targetDatabase === void 0 ? void 0 : targetDatabase.id,
|
dbId: childDb.id,
|
||||||
|
targetTable,
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
9
dist/package-shared/types/index.d.ts
vendored
9
dist/package-shared/types/index.d.ts
vendored
@ -2138,7 +2138,7 @@ export interface GiteaTreeResTree {
|
|||||||
sha: string;
|
sha: string;
|
||||||
url: string;
|
url: string;
|
||||||
}
|
}
|
||||||
export declare const OpsActions: readonly ["exit", "test", "restart-web-app", "restart-web-app-container", "restart-db", "restart-all", "clear"];
|
export declare const OpsActions: readonly ["exit", "test", "restart-web-app", "restart-web-app-container", "restart-db", "restart-all", "clear", "clear-container-logs"];
|
||||||
export type OpsObject = {
|
export type OpsObject = {
|
||||||
action: (typeof OpsActions)[number];
|
action: (typeof OpsActions)[number];
|
||||||
};
|
};
|
||||||
@ -2210,9 +2210,7 @@ export type APIPathsParams<T extends {
|
|||||||
*/
|
*/
|
||||||
basePath?: string;
|
basePath?: string;
|
||||||
auth?: () => Promise<boolean>;
|
auth?: () => Promise<boolean>;
|
||||||
getMiddleware?: (params: {
|
getMiddleware?: APIPathsParamsGetMiddleware<T>;
|
||||||
query: APIPathsQuery<T>;
|
|
||||||
}) => Promise<APIPathsQuery<T>>;
|
|
||||||
postMiddleware?: APIPathsParamsCrudMiddleware<T>;
|
postMiddleware?: APIPathsParamsCrudMiddleware<T>;
|
||||||
putMiddleware?: APIPathsParamsCrudMiddleware<T>;
|
putMiddleware?: APIPathsParamsCrudMiddleware<T>;
|
||||||
deleteMiddleware?: APIPathsParamsCrudMiddleware<T>;
|
deleteMiddleware?: APIPathsParamsCrudMiddleware<T>;
|
||||||
@ -2250,7 +2248,8 @@ export type APIPathsParamsGetMiddleware<T extends {
|
|||||||
[k: string]: any;
|
[k: string]: any;
|
||||||
}> = (params: {
|
}> = (params: {
|
||||||
query: APIPathsQuery<T>;
|
query: APIPathsQuery<T>;
|
||||||
}) => Promise<DsqlCrudQueryObject<T>>;
|
table: string;
|
||||||
|
}) => Promise<APIPathsQuery<T>>;
|
||||||
export type APIPathsParamsCrudMiddleware<T extends {
|
export type APIPathsParamsCrudMiddleware<T extends {
|
||||||
[k: string]: any;
|
[k: string]: any;
|
||||||
} = {
|
} = {
|
||||||
|
|||||||
1
dist/package-shared/types/index.js
vendored
1
dist/package-shared/types/index.js
vendored
@ -465,6 +465,7 @@ exports.OpsActions = [
|
|||||||
"restart-db",
|
"restart-db",
|
||||||
"restart-all",
|
"restart-all",
|
||||||
"clear",
|
"clear",
|
||||||
|
"clear-container-logs",
|
||||||
];
|
];
|
||||||
exports.AIOptions = [
|
exports.AIOptions = [
|
||||||
{
|
{
|
||||||
|
|||||||
@ -70,7 +70,10 @@ export default async function checks<
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (method == "GET" && getMiddleware) {
|
if (method == "GET" && getMiddleware) {
|
||||||
newQuery = await getMiddleware({ query: newQuery || ({} as any) });
|
newQuery = await getMiddleware({
|
||||||
|
query: newQuery || ({} as any),
|
||||||
|
table,
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
if (method !== "GET" && crudMiddleware) {
|
if (method !== "GET" && crudMiddleware) {
|
||||||
|
|||||||
@ -0,0 +1,72 @@
|
|||||||
|
import fs from "fs";
|
||||||
|
import path from "path";
|
||||||
|
import grabDirNames from "../../utils/backend/names/grab-dir-names";
|
||||||
|
import EJSON from "../../utils/ejson";
|
||||||
|
import { DSQL_DatabaseSchemaType } from "../../types";
|
||||||
|
import numberfy from "../../utils/numberfy";
|
||||||
|
import _ from "lodash";
|
||||||
|
import uniqueByKey from "../../utils/unique-by-key";
|
||||||
|
|
||||||
|
type Params = {
|
||||||
|
userId: string | number | null;
|
||||||
|
parentDbId?: number | string | null;
|
||||||
|
parentTableId?: number | string | null;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* # Grab All Database Schemas from Directory
|
||||||
|
* @param params
|
||||||
|
* @returns
|
||||||
|
*/
|
||||||
|
export default function grabAllDbSchemas({
|
||||||
|
userId,
|
||||||
|
parentDbId,
|
||||||
|
parentTableId,
|
||||||
|
}: Params): DSQL_DatabaseSchemaType[] | undefined {
|
||||||
|
try {
|
||||||
|
let dbSchemas: DSQL_DatabaseSchemaType[] = [];
|
||||||
|
|
||||||
|
const { targetUserPrivateDir } = grabDirNames({
|
||||||
|
userId,
|
||||||
|
});
|
||||||
|
|
||||||
|
if (!targetUserPrivateDir) {
|
||||||
|
console.log(`targetUserPrivateDir not found!`);
|
||||||
|
return undefined;
|
||||||
|
}
|
||||||
|
|
||||||
|
const dbSchemasFiles = fs.readdirSync(targetUserPrivateDir);
|
||||||
|
|
||||||
|
for (let i = 0; i < dbSchemasFiles.length; i++) {
|
||||||
|
try {
|
||||||
|
const dbSchemaFile = dbSchemasFiles[i];
|
||||||
|
const fullPath = path.join(targetUserPrivateDir, dbSchemaFile);
|
||||||
|
const json = fs.readFileSync(fullPath, "utf-8");
|
||||||
|
const dbSchema = EJSON.parse(json) as
|
||||||
|
| DSQL_DatabaseSchemaType
|
||||||
|
| undefined;
|
||||||
|
|
||||||
|
if (!dbSchema) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (parentDbId) {
|
||||||
|
const isDbChild =
|
||||||
|
numberfy(dbSchema.childDatabaseDbId) ==
|
||||||
|
numberfy(parentDbId);
|
||||||
|
|
||||||
|
if (isDbChild) {
|
||||||
|
dbSchemas.push(dbSchema);
|
||||||
|
}
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
dbSchemas.push(dbSchema);
|
||||||
|
} catch (error) {}
|
||||||
|
}
|
||||||
|
|
||||||
|
return dbSchemas;
|
||||||
|
} catch (error) {
|
||||||
|
return undefined;
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -13,6 +13,11 @@ type Params = {
|
|||||||
dbSlug?: string;
|
dbSlug?: string;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* # Grab Database Schemas related to a database
|
||||||
|
* @param params
|
||||||
|
* @returns
|
||||||
|
*/
|
||||||
export default function grabRequiredDatabaseSchemas(
|
export default function grabRequiredDatabaseSchemas(
|
||||||
params: Params
|
params: Params
|
||||||
): DSQL_DatabaseSchemaType[] | undefined {
|
): DSQL_DatabaseSchemaType[] | undefined {
|
||||||
@ -22,6 +27,7 @@ export default function grabRequiredDatabaseSchemas(
|
|||||||
let relatedDatabases: DSQL_DatabaseSchemaType[] = [];
|
let relatedDatabases: DSQL_DatabaseSchemaType[] = [];
|
||||||
|
|
||||||
const childrenDatabases = primaryDbSchema.childrenDatabases || [];
|
const childrenDatabases = primaryDbSchema.childrenDatabases || [];
|
||||||
|
|
||||||
const childrenTables =
|
const childrenTables =
|
||||||
primaryDbSchema.tables
|
primaryDbSchema.tables
|
||||||
.map((tbl) => {
|
.map((tbl) => {
|
||||||
|
|||||||
@ -4,10 +4,13 @@ import { DSQL_DatabaseSchemaType } from "../../types";
|
|||||||
import grabDirNames from "../../utils/backend/names/grab-dir-names";
|
import grabDirNames from "../../utils/backend/names/grab-dir-names";
|
||||||
import checkDbRecordCreateDbSchema from "./check-db-record";
|
import checkDbRecordCreateDbSchema from "./check-db-record";
|
||||||
import handleIndexescreateDbFromSchema from "./handle-indexes";
|
import handleIndexescreateDbFromSchema from "./handle-indexes";
|
||||||
import grabRequiredDatabaseSchemas, {
|
import {
|
||||||
grabPrimaryRequiredDbSchema,
|
grabPrimaryRequiredDbSchema,
|
||||||
|
writeUpdatedDbSchema,
|
||||||
} from "./grab-required-database-schemas";
|
} from "./grab-required-database-schemas";
|
||||||
import dbHandler from "../../functions/backend/dbHandler";
|
import dbHandler from "../../functions/backend/dbHandler";
|
||||||
|
import grabAllDbSchemas from "./grab-all-user-db-schemas";
|
||||||
|
import _ from "lodash";
|
||||||
|
|
||||||
type Param = {
|
type Param = {
|
||||||
userId?: number | string | null;
|
userId?: number | string | null;
|
||||||
@ -36,14 +39,16 @@ export default async function createDbFromSchema({
|
|||||||
let dbSchema = dbSchemaData
|
let dbSchema = dbSchemaData
|
||||||
? dbSchemaData
|
? dbSchemaData
|
||||||
: dbId
|
: dbId
|
||||||
? grabRequiredDatabaseSchemas({
|
? [
|
||||||
dbId,
|
grabPrimaryRequiredDbSchema({
|
||||||
userId,
|
dbId,
|
||||||
})
|
userId,
|
||||||
|
}),
|
||||||
|
]
|
||||||
: undefined;
|
: undefined;
|
||||||
|
|
||||||
if (!dbSchema) {
|
if (!dbSchema) {
|
||||||
console.log("Schema Not Found!");
|
console.log(`Schema Not Found for DB ID ${dbId}!`);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -55,9 +60,11 @@ export default async function createDbFromSchema({
|
|||||||
const isMain = !userSchemaMainJSONFilePath;
|
const isMain = !userSchemaMainJSONFilePath;
|
||||||
|
|
||||||
for (let i = 0; i < dbSchema.length; i++) {
|
for (let i = 0; i < dbSchema.length; i++) {
|
||||||
const database: DSQL_DatabaseSchemaType = dbSchema[i];
|
const database: DSQL_DatabaseSchemaType | undefined = dbSchema[i];
|
||||||
|
|
||||||
const { dbFullName, tables, dbSlug, childrenDatabases } = database;
|
if (!database) continue;
|
||||||
|
|
||||||
|
const { dbFullName, tables, dbSlug } = database;
|
||||||
|
|
||||||
if (!dbFullName) continue;
|
if (!dbFullName) continue;
|
||||||
|
|
||||||
@ -233,19 +240,27 @@ export default async function createDbFromSchema({
|
|||||||
/**
|
/**
|
||||||
* @description Check all children databases
|
* @description Check all children databases
|
||||||
*/
|
*/
|
||||||
if (childrenDatabases?.[0]) {
|
const childrenDatabases: DSQL_DatabaseSchemaType[] = userId
|
||||||
|
? grabAllDbSchemas({ userId, parentDbId: database.id }) || []
|
||||||
|
: [];
|
||||||
|
|
||||||
|
if (childrenDatabases?.[0] && userId) {
|
||||||
for (let ch = 0; ch < childrenDatabases.length; ch++) {
|
for (let ch = 0; ch < childrenDatabases.length; ch++) {
|
||||||
const childDb = childrenDatabases[ch];
|
const childDb = childrenDatabases[ch];
|
||||||
const { dbId } = childDb;
|
|
||||||
|
|
||||||
const targetDatabase = dbSchema.find(
|
childDb.tables = [...database.tables];
|
||||||
(dbSch) => dbSch.childDatabaseDbId == dbId
|
childDb.collation = database.collation;
|
||||||
);
|
|
||||||
|
|
||||||
if (targetDatabase?.id) {
|
writeUpdatedDbSchema({
|
||||||
|
dbSchema: childDb,
|
||||||
|
userId,
|
||||||
|
});
|
||||||
|
|
||||||
|
if (dbId) {
|
||||||
await createDbFromSchema({
|
await createDbFromSchema({
|
||||||
userId,
|
userId,
|
||||||
dbId: targetDatabase?.id,
|
dbId: childDb.id,
|
||||||
|
targetTable,
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -2741,6 +2741,7 @@ export const OpsActions = [
|
|||||||
"restart-db",
|
"restart-db",
|
||||||
"restart-all",
|
"restart-all",
|
||||||
"clear",
|
"clear",
|
||||||
|
"clear-container-logs",
|
||||||
] as const;
|
] as const;
|
||||||
|
|
||||||
export type OpsObject = {
|
export type OpsObject = {
|
||||||
@ -2869,9 +2870,7 @@ export type APIPathsParams<
|
|||||||
*/
|
*/
|
||||||
basePath?: string;
|
basePath?: string;
|
||||||
auth?: () => Promise<boolean>;
|
auth?: () => Promise<boolean>;
|
||||||
getMiddleware?: (params: {
|
getMiddleware?: APIPathsParamsGetMiddleware<T>;
|
||||||
query: APIPathsQuery<T>;
|
|
||||||
}) => Promise<APIPathsQuery<T>>;
|
|
||||||
postMiddleware?: APIPathsParamsCrudMiddleware<T>;
|
postMiddleware?: APIPathsParamsCrudMiddleware<T>;
|
||||||
putMiddleware?: APIPathsParamsCrudMiddleware<T>;
|
putMiddleware?: APIPathsParamsCrudMiddleware<T>;
|
||||||
deleteMiddleware?: APIPathsParamsCrudMiddleware<T>;
|
deleteMiddleware?: APIPathsParamsCrudMiddleware<T>;
|
||||||
@ -2912,7 +2911,10 @@ export type APIPathsQuery<
|
|||||||
|
|
||||||
export type APIPathsParamsGetMiddleware<
|
export type APIPathsParamsGetMiddleware<
|
||||||
T extends { [k: string]: any } = { [k: string]: any }
|
T extends { [k: string]: any } = { [k: string]: any }
|
||||||
> = (params: { query: APIPathsQuery<T> }) => Promise<DsqlCrudQueryObject<T>>;
|
> = (params: {
|
||||||
|
query: APIPathsQuery<T>;
|
||||||
|
table: string;
|
||||||
|
}) => Promise<APIPathsQuery<T>>;
|
||||||
|
|
||||||
export type APIPathsParamsCrudMiddleware<
|
export type APIPathsParamsCrudMiddleware<
|
||||||
T extends { [k: string]: any } = { [k: string]: any },
|
T extends { [k: string]: any } = { [k: string]: any },
|
||||||
|
|||||||
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@moduletrace/datasquirel",
|
"name": "@moduletrace/datasquirel",
|
||||||
"version": "5.6.4",
|
"version": "5.6.5",
|
||||||
"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