Actualizar robot_cobros.js

This commit is contained in:
marsalva 2025-12-28 20:07:10 +00:00
parent 140a7da912
commit e90bc209c0
1 changed files with 61 additions and 41 deletions

View File

@ -1,9 +1,9 @@
const express = require('express');
const cors = require('cors');
const { chromium } = require('playwright');
const admin = require('firebase-admin');
const cors = require('cors');
// --- CONFIGURACIÓN FIREBASE ---
// --- FIREBASE ---
try {
if (process.env.FIREBASE_PRIVATE_KEY) {
if (!admin.apps.length) {
@ -16,54 +16,74 @@ try {
});
}
console.log("✅ Firebase inicializado.");
} else {
console.log("⚠️ FIREBASE_PRIVATE_KEY no está seteada. Firebase OFF.");
}
} catch (e) {
console.error("❌ Error Firebase:", e.message);
}
} catch (e) { console.error("❌ Error Firebase:", e.message); }
const db = admin.apps.length ? admin.firestore() : null;
const COLLECTION_NAME = "homeserve_pendientes";
const app = express();
// --- 🛡️ CORRECCIÓN CORS DEFINITIVA 🛡️ ---
// --- CORS (robusto) ---
app.use(cors({
origin: '*', // Permitir todo
methods: ['GET', 'POST', 'OPTIONS'], // Permitir estos métodos
allowedHeaders: ['Content-Type', 'Authorization'] // Permitir estas cabeceras
origin: '*',
methods: ['GET', 'POST', 'OPTIONS'],
allowedHeaders: ['Content-Type', 'Authorization'],
}));
// Forzar respuesta OK a las peticiones OPTIONS (Preflight)
app.options('*', cors());
// IMPORTANTÍSIMO: responder preflight
app.options('*', (req, res) => {
res.header("Access-Control-Allow-Origin", "*");
res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept, Authorization");
res.header("Access-Control-Allow-Methods", "GET, POST, OPTIONS");
return res.sendStatus(204);
});
app.use(express.json());
// RUTA DE TEST
// TEST
app.get('/', (req, res) => {
res.send('🤖 El Robot de Cobros está ONLINE y esperando órdenes.');
res.status(200).send('🤖 El Robot de Cobros está ONLINE y esperando órdenes.');
});
// RUTA DEL ROBOT
app.get('/health', (req, res) => {
res.status(200).json({ ok: true, firebase: !!db, ts: new Date().toISOString() });
});
// ROBOT
app.post('/api/robot-cobros', async (req, res) => {
console.log("🔔 Petición POST recibida correctamente.");
res.json({ success: true, message: "Orden recibida. Iniciando..." });
console.log("🔔 POST /api/robot-cobros recibido.");
// Respuesta inmediata para que el navegador no espere
res.status(200).json({ success: true, message: "Orden recibida. Iniciando..." });
// Ejecutar en segundo plano
runRobotLogic().catch(err => console.error("❌ Error en lógica robot:", err));
try {
await runRobotLogic();
} catch (err) {
console.error("❌ Error robot:", err?.message || err);
}
});
async function runRobotLogic() {
console.log("🚀 Lanzando navegador (Simulación)...");
let browser = null;
try {
// AQUÍ VA TU LÓGICA DE PLAYWRIGHT (Puedes pegar la que tenías antes si quieres la real)
// De momento dejamos esto para probar la conexión
await new Promise(resolve => setTimeout(resolve, 2000));
console.log("✅ Proceso simulado terminado.");
} catch (e) {
console.error(e);
}
console.log("🚀 runRobotLogic() arrancando...");
// Si aquí tu lógica usa Firebase, asegúrate:
// if (!db) throw new Error("Firebase no inicializado (faltan env vars)");
// Ejemplo mínimo
// const browser = await chromium.launch({ headless: true });
// ...
// await browser.close();
console.log("✅ runRobotLogic() terminado (simulación).");
}
const PORT = process.env.PORT || 3000;
const PORT = process.env.PORT || process.env.CAPROVER_PORT || 3000;
app.listen(PORT, () => {
console.log(`🚀 Servidor escuchando en puerto ${PORT}`);
});