UNPKG

@forzalabs/remora

Version:

A powerful CLI tool for seamless data translation.

62 lines (61 loc) • 3.13 kB
"use strict"; var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.debug = void 0; const chalk_1 = __importDefault(require("chalk")); const ora_1 = __importDefault(require("ora")); const DriverFactory_1 = __importDefault(require("../drivers/DriverFactory")); const Environment_1 = __importDefault(require("../engines/Environment")); const compile_1 = require("./compile"); const debug = (options) => __awaiter(void 0, void 0, void 0, function* () { try { (0, compile_1.compile)(); console.log('\n'); const spinner = (0, ora_1.default)({ text: 'ā³ Checking producers connections...', color: 'blue' }).start(); const producers = Environment_1.default._env.producers; const failures = []; for (const producer of producers) { spinner.text = `šŸ” Testing producer "${producer.name}" (source: ${producer.source})`; const source = Environment_1.default.getSource(producer.source); const driver = yield DriverFactory_1.default.instantiateSource(source); const canConnect = yield driver.exist(producer); if (canConnect) { spinner.succeed(`Producer "${producer.name}" connected successfully.`); } else { spinner.fail(chalk_1.default.red(`āœ– Producer "${producer.name}" failed to connect.`)); failures.push(producer.name); } // Avoid restarting the spinner unless needed if (producer !== producers[producers.length - 1]) { spinner.start(); } } if (failures.length > 0) { console.log(chalk_1.default.red.bold(`\n‼ ${failures.length} producer(s) could not connect:`)); failures.forEach(name => console.log(chalk_1.default.yellow(` • ${name}`))); process.exit(1); } else { // Stop spinner silently (no āœ” line) spinner.stop(); console.log(chalk_1.default.green.bold('\nšŸŽ‰ All producers are up and running!')); } } catch (err) { console.error(chalk_1.default.red.bold('\nāŒ Unexpected error during debug:'), err instanceof Error ? err.message : String(err)); process.exit(1); } }); exports.debug = debug;