@athenna/database
Version:
The Athenna database handler for SQL/NoSQL.
67 lines (66 loc) • 2.86 kB
JavaScript
/**
* @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 { sep } from 'node:path';
import { Path, String } from '@athenna/common';
import { BaseCommand, Argument } from '@athenna/artisan';
export class MakeMigrationCommand extends BaseCommand {
static signature() {
return 'make:migration';
}
static description() {
return 'Make a new migration file.';
}
async handle() {
this.logger.simple('({bold,green} [ MAKING MIGRATION ])\n');
const nameUp = this.name.toUpperCase();
const nameCamel = String.toCamelCase(this.name);
const namePlural = String.pluralize(this.name);
const namePascal = String.toPascalCase(this.name);
const namePluralCamel = String.toCamelCase(String.pluralize(this.name));
const namePluralPascal = String.toPascalCase(String.pluralize(this.name));
const destination = Config.get('rc.commands.make:migration.destination', Path.migrations());
const tableName = String.pluralize(namePascal
.replace('Migration', '')
.replace('Migrations', '')
.toLowerCase());
let [date, time] = new Date().toISOString().split('T');
date = date.replace(/-/g, '_');
time = time.split('.')[0].replace(/:/g, '');
const file = await this.generator
.fileName(`${sep}${date}_${time}_create_${tableName}_table`)
.destination(destination)
.properties({
nameUp,
nameCamel,
namePlural,
namePascal,
namePluralCamel,
namePluralPascal,
tableName
})
.template('migration')
.make();
this.logger.success(`Migration ({yellow} "${file.name}") successfully created.`);
}
}
__decorate([
Argument({
description: 'The migration name.'
}),
__metadata("design:type", String)
], MakeMigrationCommand.prototype, "name", void 0);