- Auth: Login/Register con creacion de clinica - Dashboard: KPIs reales, graficas recharts - Pacientes: CRUD completo con busqueda - Agenda: FullCalendar, drag-and-drop, vista recepcion - Expediente: Notas SOAP, signos vitales, CIE-10 - Facturacion: Facturas con IVA, campos CFDI SAT - Inventario: Productos, stock, movimientos, alertas - Configuracion: Clinica, equipo, catalogo servicios - Supabase self-hosted: 18 tablas con RLS multi-tenant - Docker + Nginx para produccion Co-Authored-By: claude-flow <ruv@ruv.net>
107 lines
2.9 KiB
JavaScript
Executable File
107 lines
2.9 KiB
JavaScript
Executable File
#!/usr/bin/env node
|
|
|
|
/**
|
|
* Safe GitHub CLI Helper
|
|
* Prevents timeout issues when using gh commands with special characters
|
|
*
|
|
* Usage:
|
|
* ./github-safe.js issue comment 123 "Message with `backticks`"
|
|
* ./github-safe.js pr create --title "Title" --body "Complex body"
|
|
*/
|
|
|
|
import { execSync } from 'child_process';
|
|
import { writeFileSync, unlinkSync } from 'fs';
|
|
import { tmpdir } from 'os';
|
|
import { join } from 'path';
|
|
import { randomBytes } from 'crypto';
|
|
|
|
const args = process.argv.slice(2);
|
|
|
|
if (args.length < 2) {
|
|
console.log(`
|
|
Safe GitHub CLI Helper
|
|
|
|
Usage:
|
|
./github-safe.js issue comment <number> <body>
|
|
./github-safe.js pr comment <number> <body>
|
|
./github-safe.js issue create --title <title> --body <body>
|
|
./github-safe.js pr create --title <title> --body <body>
|
|
|
|
This helper prevents timeout issues with special characters like:
|
|
- Backticks in code examples
|
|
- Command substitution \$(...)
|
|
- Directory paths
|
|
- Special shell characters
|
|
`);
|
|
process.exit(1);
|
|
}
|
|
|
|
const [command, subcommand, ...restArgs] = args;
|
|
|
|
// Handle commands that need body content
|
|
if ((command === 'issue' || command === 'pr') &&
|
|
(subcommand === 'comment' || subcommand === 'create')) {
|
|
|
|
let bodyIndex = -1;
|
|
let body = '';
|
|
|
|
if (subcommand === 'comment' && restArgs.length >= 2) {
|
|
// Simple format: github-safe.js issue comment 123 "body"
|
|
body = restArgs[1];
|
|
bodyIndex = 1;
|
|
} else {
|
|
// Flag format: --body "content"
|
|
bodyIndex = restArgs.indexOf('--body');
|
|
if (bodyIndex !== -1 && bodyIndex < restArgs.length - 1) {
|
|
body = restArgs[bodyIndex + 1];
|
|
}
|
|
}
|
|
|
|
if (body) {
|
|
// Use temporary file for body content
|
|
const tmpFile = join(tmpdir(), `gh-body-${randomBytes(8).toString('hex')}.tmp`);
|
|
|
|
try {
|
|
writeFileSync(tmpFile, body, 'utf8');
|
|
|
|
// Build new command with --body-file
|
|
const newArgs = [...restArgs];
|
|
if (subcommand === 'comment' && bodyIndex === 1) {
|
|
// Replace body with --body-file
|
|
newArgs[1] = '--body-file';
|
|
newArgs.push(tmpFile);
|
|
} else if (bodyIndex !== -1) {
|
|
// Replace --body with --body-file
|
|
newArgs[bodyIndex] = '--body-file';
|
|
newArgs[bodyIndex + 1] = tmpFile;
|
|
}
|
|
|
|
// Execute safely
|
|
const ghCommand = `gh ${command} ${subcommand} ${newArgs.join(' ')}`;
|
|
console.log(`Executing: ${ghCommand}`);
|
|
|
|
const result = execSync(ghCommand, {
|
|
stdio: 'inherit',
|
|
timeout: 30000 // 30 second timeout
|
|
});
|
|
|
|
} catch (error) {
|
|
console.error('Error:', error.message);
|
|
process.exit(1);
|
|
} finally {
|
|
// Clean up
|
|
try {
|
|
unlinkSync(tmpFile);
|
|
} catch (e) {
|
|
// Ignore cleanup errors
|
|
}
|
|
}
|
|
} else {
|
|
// No body content, execute normally
|
|
execSync(`gh ${args.join(' ')}`, { stdio: 'inherit' });
|
|
}
|
|
} else {
|
|
// Other commands, execute normally
|
|
execSync(`gh ${args.join(' ')}`, { stdio: 'inherit' });
|
|
}
|