UNPKG

@athenna/database

Version:

The Athenna database handler for SQL/NoSQL.

65 lines (64 loc) 2.8 kB
/** * @athenna/database * * (c) João Lenon <lenon@athenna.io> * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; import { Database } from '#src/facades/Database'; import { BaseCommand, Option } from '@athenna/artisan'; export class DbWipeCommand extends BaseCommand { static signature() { return 'db:wipe'; } static description() { return 'Drop all the tables of your database.'; } async handle() { this.logger.simple('({bold,green} [ WIPING DATABASE ])\n'); const task = this.logger.task(); const DB = Database.connection(this.connection); if (this.getConfig('driver') === 'mongo') { task.addPromise('Dropping all database tables', async () => { const tables = await DB.getTables(); return tables.athenna.concurrently(table => DB.dropTable(table)); }); } else { const migrationsTable = this.getConfig('migrations.tableName', 'migrations'); task.addPromise('Reverting migrations', () => DB.revertMigrations()); task.addPromise('Drop migrations table', () => DB.dropTable(migrationsTable)); } await task .run() .then(async () => { const dbName = await DB.getCurrentDatabase(); console.log(); this.logger.success(`Database ({yellow} "${dbName}") successfully wiped.`); }) .finally(() => DB.close()); } getConfig(name, defaultValue) { return Config.get(`database.connections.${this.connection === 'default' ? Config.get('database.default') : this.connection}.${name}`, defaultValue); } } __decorate([ Option({ default: 'default', signature: '-c, --connection <connection>', description: 'Set the the database connection.' }), __metadata("design:type", String) ], DbWipeCommand.prototype, "connection", void 0);