2024-11-05 11:12:42 +00:00
|
|
|
// @ts-check
|
|
|
|
|
2025-01-13 08:00:21 +00:00
|
|
|
import httpsRequest from "../package-shared/functions/backend/httpsRequest";
|
|
|
|
import cron from "cron";
|
|
|
|
import path from "path";
|
|
|
|
import { dbSchemaExecDbUpdate } from "../functions/backend/dbSchemaExec";
|
|
|
|
import dbHandler from "../package-shared/functions/backend/dbHandler";
|
2024-11-05 11:12:42 +00:00
|
|
|
|
2025-01-13 08:00:21 +00:00
|
|
|
export default async function () {
|
2024-11-05 11:12:42 +00:00
|
|
|
////////////////////////////////////////
|
|
|
|
////////////////////////////////////////
|
|
|
|
////////////////////////////////////////
|
|
|
|
|
|
|
|
new cron.CronJob(
|
|
|
|
"20 * * * * *",
|
|
|
|
async () => {
|
|
|
|
/** @type {import("@/package-shared/types").DSQL_MYSQL_user_databases_Type[] | null} */ // @ts-ignore
|
2025-01-13 08:00:21 +00:00
|
|
|
const remoteConnectedDbs:
|
|
|
|
| import("@/package-shared/types").DSQL_MYSQL_user_databases_Type[]
|
|
|
|
| null = await dbHandler(
|
2024-11-05 11:12:42 +00:00
|
|
|
`SELECT * FROM user_databases WHERE remote_connected = 1`
|
|
|
|
);
|
|
|
|
|
|
|
|
if (remoteConnectedDbs?.[0]) {
|
|
|
|
for (let i = 0; i < remoteConnectedDbs.length; i++) {
|
|
|
|
try {
|
|
|
|
const database = remoteConnectedDbs[i];
|
|
|
|
|
|
|
|
const {
|
|
|
|
user_id,
|
|
|
|
remote_connection_host,
|
|
|
|
remote_db_full_name,
|
|
|
|
remote_connection_key,
|
|
|
|
remote_connection_type,
|
|
|
|
db_full_name,
|
|
|
|
} = database;
|
|
|
|
|
|
|
|
if (database.remote_connection_type == "pull") {
|
2025-01-13 08:00:21 +00:00
|
|
|
const dbSchema = (await httpsRequest({
|
2024-11-05 11:12:42 +00:00
|
|
|
url: remote_connection_host,
|
|
|
|
headers: {
|
|
|
|
Authorization: remote_connection_key,
|
|
|
|
"Content-Type": "application/json",
|
|
|
|
},
|
|
|
|
method: "GET",
|
|
|
|
path: `/api/query/get-schema?database=${remote_db_full_name?.replace(
|
|
|
|
/^datasquirel_user_\d+_/i,
|
|
|
|
""
|
|
|
|
)}`,
|
2025-01-13 08:00:21 +00:00
|
|
|
})) as any;
|
2024-11-05 11:12:42 +00:00
|
|
|
|
|
|
|
/** @type {import("@/package-shared/types").DSQL_DatabaseSchemaType | null | undefined} */
|
2025-01-13 08:00:21 +00:00
|
|
|
const remoteDbSchemaData:
|
|
|
|
| import("@/package-shared/types").DSQL_DatabaseSchemaType
|
|
|
|
| null
|
|
|
|
| undefined = JSON.parse(dbSchema).payload;
|
2024-11-05 11:12:42 +00:00
|
|
|
|
|
|
|
if (remoteDbSchemaData) {
|
|
|
|
const update = dbSchemaExecDbUpdate({
|
|
|
|
dbSchema: remoteDbSchemaData,
|
|
|
|
database: database,
|
|
|
|
userId: user_id,
|
|
|
|
});
|
|
|
|
|
|
|
|
console.log(update);
|
|
|
|
}
|
|
|
|
}
|
2025-01-13 08:00:21 +00:00
|
|
|
} catch (/** @type {any} */ error: any) {
|
2024-11-05 11:12:42 +00:00
|
|
|
console.log(error.message);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
null,
|
|
|
|
true,
|
|
|
|
"America/Los_Angeles"
|
|
|
|
);
|
|
|
|
|
|
|
|
////////////////////////////////////////
|
|
|
|
////////////////////////////////////////
|
|
|
|
////////////////////////////////////////
|
2025-01-13 08:00:21 +00:00
|
|
|
}
|