import { Command, Flags } from "@oclif/core"; import axios from "axios"; import chalk from "chalk"; import inquirer from "inquirer"; import { slugify } from "../../../utils/slug.js"; import { readAuthConfig } from "../../../utils/utils.js"; import { getProjects } from "../../../utils/shared.js"; import type { Answers } from "../../app/create.js"; export default class DatabasePostgresCreate extends Command { static description = "Create a new PostgreSQL database within a project."; static examples = ["$ <%= config.bin %> postgres create"]; static flags = { projectId: Flags.string({ char: "p", description: "ID of the project", required: false, }), name: Flags.string({ char: "n", description: "Database name", required: false, }), databaseName: Flags.string({ description: "PostgreSQL database name", required: false, }), description: Flags.string({ char: "d", description: "Database description", required: false, }), databasePassword: Flags.string({ description: "Database password", required: false, }), databaseUser: Flags.string({ description: "Database user", default: "postgres", }), dockerImage: Flags.string({ description: "Docker image", default: "postgres:15", }), skipConfirm: Flags.boolean({ char: "y", description: "Skip confirmation prompt", default: false, }), appName: Flags.string({ description: "App name", required: false, }), }; public async run(): Promise { const auth = await readAuthConfig(this); const { flags } = await this.parse(DatabasePostgresCreate); let { projectId, name, databaseName, description, databasePassword, databaseUser, dockerImage, appName } = flags; // Modo interactivo si no se proporcionan los flags necesarios if (!projectId || !name || !databaseName || !appName || !databasePassword) { console.log(chalk.blue.bold("\n Listing all Projects \n")); const projects = await getProjects(auth, this); if (!projectId) { const { project } = await inquirer.prompt([ { choices: projects.map((project) => ({ name: project.name, value: project, })), message: "Select a project to create the PostgreSQL instance in:", name: "project", type: "list", }, ]); projectId = project.projectId; } if (!name || !databaseName || !appName || !databasePassword) { const dbDetails = await inquirer.prompt([ { message: "Enter the name:", name: "name", type: "input", validate: (input) => (input ? true : "Database name is required"), default: name, }, { message: "Database name:", name: "databaseName", type: "input", validate: (input) => (input ? true : "Database name is required"), default: databaseName, }, { message: "Enter the database description (optional):", name: "description", type: "input", default: description, }, { message: "Database password:", name: "databasePassword", type: "password", default: databasePassword, }, { default: dockerImage || "postgres:15", message: "Docker Image (default: postgres:15):", name: "dockerImage", type: "input", }, { default: databaseUser || "postgres", message: "Database User: (default: postgres):", name: "databaseUser", type: "input", }, ]); name = dbDetails.name; databaseName = dbDetails.databaseName; description = dbDetails.description; databasePassword = dbDetails.databasePassword; dockerImage = dbDetails.dockerImage; databaseUser = dbDetails.databaseUser; const appNamePrompt = await inquirer.prompt([ { default: appName || `${slugify(name)}`, message: "Enter the App name:", name: "appName", type: "input", validate: (input) => (input ? true : "App name is required"), }, ]); appName = appNamePrompt.appName; } } // Confirmar si no se especifica --skipConfirm if (!flags.skipConfirm) { const confirm = await inquirer.prompt([ { type: 'confirm', name: 'proceed', message: 'Do you want to create this PostgreSQL instance?', default: false, }, ]); if (!confirm.proceed) { this.error(chalk.yellow("PostgreSQL creation cancelled.")); return; } } try { console.log(JSON.stringify({ name, databaseName, description, databasePassword, databaseUser, dockerImage, appName, projectId, }, null, 2)); const response = await axios.post( `${auth.url}/api/trpc/postgres.create`, { json: { name, databaseName, description, databasePassword, databaseUser, dockerImage, appName, projectId, }, }, { headers: { Authorization: `Bearer ${auth.token}`, "Content-Type": "application/json", }, }, ); if (!response.data.result.data.json) { this.error(chalk.red("Error creating PostgreSQL instance", response.data.result.data.json)); } this.log(chalk.green(`PostgreSQL instance '${name}' created successfully.`)); } catch (error: any) { this.error(chalk.red(`Error creating PostgreSQL instance: ${error.message}`)); } } }