typeorm
Version:
Data-Mapper ORM for TypeScript and ES2021+. Supports MySQL/MariaDB, PostgreSQL, MS SQL Server, Oracle, SAP HANA, SQLite, MongoDB databases.
52 lines (50 loc) • 2.01 kB
JavaScript
Object.defineProperty(exports, "__esModule", { value: true });
exports.SchemaDropCommand = void 0;
const tslib_1 = require("tslib");
const ansis_1 = tslib_1.__importDefault(require("ansis"));
const path_1 = tslib_1.__importDefault(require("path"));
const process_1 = tslib_1.__importDefault(require("process"));
const PlatformTools_1 = require("../platform/PlatformTools");
const CommandUtils_1 = require("./CommandUtils");
/**
* Drops all tables of the database from the given dataSource.
*/
class SchemaDropCommand {
constructor() {
this.command = "schema:drop";
this.describe = "Drops all tables in the database on your default dataSource. " +
"To drop table of a concrete connection's database use -c option.";
}
builder(args) {
return args.option("dataSource", {
alias: "d",
describe: "Path to the file where your DataSource instance is defined.",
demandOption: true,
});
}
async handler(args) {
let dataSource = undefined;
try {
dataSource = await CommandUtils_1.CommandUtils.loadDataSource(path_1.default.resolve(process_1.default.cwd(), args.dataSource));
dataSource.setOptions({
synchronize: false,
migrationsRun: false,
dropSchema: false,
logging: ["query", "schema"],
});
await dataSource.initialize();
await dataSource.dropDatabase();
await dataSource.destroy();
console.log(ansis_1.default.green `Database schema has been successfully dropped.`);
}
catch (err) {
PlatformTools_1.PlatformTools.logCmdErr("Error during schema drop:", err);
if (dataSource && dataSource.isInitialized)
await dataSource.destroy();
process_1.default.exit(1);
}
}
}
exports.SchemaDropCommand = SchemaDropCommand;
//# sourceMappingURL=SchemaDropCommand.js.map
;