import { Command, Flags } from "@oclif/core"; import { readAuthConfig } from "../../../utils/utils.js"; import chalk from "chalk"; import { getProject, getProjects, type Database } from "../../../utils/shared.js"; import inquirer from "inquirer"; import type { Answers } from "../../app/create.js"; import axios from "axios"; export default class DatabasePostgresStop extends Command { static description = "Stop a PostgreSQL instance in a project."; static examples = ["$ <%= config.bin %> postgres stop"]; static flags = { projectId: Flags.string({ char: "p", description: "ID of the project", required: false, }), environmentId: Flags.string({ char: "e", description: "ID of the environment", required: false, }), postgresId: Flags.string({ char: "d", description: "ID of the PostgreSQL instance to stop", required: false, }), skipConfirm: Flags.boolean({ char: "y", description: "Skip confirmation prompt", default: false, }), }; public async run(): Promise { const auth = await readAuthConfig(this); const { flags } = await this.parse(DatabasePostgresStop); let { projectId, environmentId, postgresId } = flags; // Modo interactivo si no se proporcionan los flags necesarios if (!projectId || !environmentId || !postgresId) { console.log(chalk.blue.bold("\n Listing all Projects \n")); const projects = await getProjects(auth, this); let selectedProject; let selectedEnvironment; // 1. Seleccionar proyecto if (!projectId) { const { project } = await inquirer.prompt([ { choices: projects.map((project) => ({ name: project.name, value: project, })), message: "Select a project to stop the PostgreSQL instance from:", name: "project", type: "list", }, ]); selectedProject = project; projectId = project.projectId; } else { selectedProject = projects.find(p => p.projectId === projectId); } // 2. Seleccionar environment del proyecto if (!environmentId) { if (!selectedProject?.environments || selectedProject.environments.length === 0) { this.error(chalk.yellow("No environments found in this project.")); } const { environment } = await inquirer.prompt([ { choices: selectedProject.environments.map((env) => ({ name: `${env.name} (${env.description})`, value: env, })), message: "Select an environment:", name: "environment", type: "list", }, ]); selectedEnvironment = environment; environmentId = environment.environmentId; } else { selectedEnvironment = selectedProject?.environments?.find(e => e.environmentId === environmentId); } // 3. Seleccionar PostgreSQL del environment if (!postgresId) { if (!selectedEnvironment?.postgres || selectedEnvironment.postgres.length === 0) { this.error(chalk.yellow("No PostgreSQL instances found in this environment.")); } const dbAnswers = await inquirer.prompt([ { choices: selectedEnvironment.postgres.map((db: Database) => ({ name: db.name, value: db.postgresId, })), message: "Select the PostgreSQL instance to stop:", name: "selectedDb", type: "list", }, ]); postgresId = dbAnswers.selectedDb; } } // Confirmar si no se especifica --skipConfirm if (!flags.skipConfirm) { const confirmAnswers = await inquirer.prompt([ { default: false, message: "Are you sure you want to stop this PostgreSQL instance?", name: "confirmStop", type: "confirm", }, ]); if (!confirmAnswers.confirmStop) { this.error(chalk.yellow("PostgreSQL stop cancelled.")); } } try { const response = await axios.post( `${auth.url}/api/trpc/postgres.stop`, { json: { postgresId, }, }, { headers: { "x-api-key": auth.token, "Content-Type": "application/json", }, }, ); if (response.status !== 200) { this.error(chalk.red("Error stopping PostgreSQL instance")); } this.log(chalk.green("PostgreSQL instance stopped successfully.")); } catch (error: any) { this.error(chalk.red(`Error stopping PostgreSQL instance: ${error.message}`)); } } }