datasquirel/engine/dump.js

49 lines
1.5 KiB
JavaScript
Raw Normal View History

2023-08-12 16:00:11 +00:00
#! /usr/bin/env node
// @ts-check
const fs = require("fs");
const path = require("path");
const { execSync } = require("child_process");
require("dotenv").config({
path: path.resolve(process.cwd(), ".env"),
});
const mysqlPath = process.platform?.match(/win/i) ? "'" + "C:\\Program Files\\MySQL\\MySQL Server 8.0\\bin\\mysql.exe" + "'" : "mysql";
const mysqlDumpPath = process.platform?.match(/win/i) ? "'" + "C:\\Program Files\\MySQL\\MySQL Server 8.0\\bin\\mysqldump.exe" + "'" : "mysqldump";
const dbName = process.env.DSQL_DB_NAME || "";
const dumpFilePathArg = process.argv.indexOf("--file");
if (dumpFilePathArg < 0) {
console.log("Please provide a dump file path using `--file` argument");
process.exit();
}
const dumpFilePath = process.argv[dumpFilePathArg + 1];
if (!dbName?.match(/./)) {
console.log("DSQL_DB_NAME is required in your `.env` file");
process.exit();
}
2023-08-12 16:03:48 +00:00
try {
let execSyncOptions = {
cwd: process.cwd(),
};
2023-08-12 16:00:11 +00:00
2023-08-12 16:03:48 +00:00
if (process.platform.match(/win/i)) execSyncOptions.shell = "bash.exe";
2023-08-12 16:00:11 +00:00
2023-08-12 16:03:48 +00:00
const dump = execSync(`${mysqlPath} -u ${process.env.DB_USERNAME} -p${process.env.DB_PASSWORD} ${dbName} < ${dumpFilePath}`, execSyncOptions);
2023-08-12 16:00:11 +00:00
2023-08-12 16:03:48 +00:00
console.log("Dumped successfully", dump.toString());
2023-08-12 16:00:11 +00:00
2023-08-12 16:03:48 +00:00
console.log("Dumped successfully");
////////////////////////////////////////
////////////////////////////////////////
////////////////////////////////////////
} catch (error) {
console.log("Dump Error: ", error.message);
}