From effed199788412f673b636d8d0c082b54cecdace Mon Sep 17 00:00:00 2001 From: marsalva Date: Sun, 28 Dec 2025 20:00:50 +0000 Subject: [PATCH] Actualizar robot_cobros.js --- robot_cobros.js | 98 ++++++++++++------------------------------------- 1 file changed, 23 insertions(+), 75 deletions(-) diff --git a/robot_cobros.js b/robot_cobros.js index fe1b808..55d0c2c 100644 --- a/robot_cobros.js +++ b/robot_cobros.js @@ -3,9 +3,7 @@ const { chromium } = require('playwright'); const admin = require('firebase-admin'); const cors = require('cors'); -// --- 1. CONFIGURACIÓN FIREBASE --- -// Si falla al iniciar, simplemente avisa pero no tira el servidor, -// para que al menos responda al ping del HTML. +// --- CONFIGURACIÓN FIREBASE --- try { if (process.env.FIREBASE_PRIVATE_KEY) { if (!admin.apps.length) { @@ -17,96 +15,46 @@ try { }), }); } - console.log("✅ Firebase inicializado correctamente."); - } else { - console.warn("⚠️ NO HAY CLAVES DE FIREBASE. El robot funcionará pero no guardará datos."); + console.log("✅ Firebase inicializado."); } -} 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"; // O la que uses para guardar cobros +const COLLECTION_NAME = "homeserve_pendientes"; -// --- 2. SERVIDOR EXPRESS --- const app = express(); -// IMPORTANTE: CORS para permitir que tu HTML hable con este servidor -app.use(cors({ origin: '*' })); +// --- CORRECCIÓN CORS AGRESIVA --- +app.use(cors({ origin: true })); // Permitir cualquier origen dinámicamente +app.use((req, res, next) => { + res.header("Access-Control-Allow-Origin", "*"); + res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept"); + res.header("Access-Control-Allow-Methods", "GET, POST, OPTIONS"); + next(); +}); + app.use(express.json()); -// Ruta de prueba para ver si el servidor está vivo desde el navegador +// RUTA DE TEST (Para comprobar en el navegador) app.get('/', (req, res) => { res.send('🤖 El Robot de Cobros está ONLINE y esperando órdenes.'); }); -// --- 3. ENDPOINT QUE LLAMA EL HTML --- +// RUTA DEL ROBOT app.post('/api/robot-cobros', async (req, res) => { - console.log("🔔 Petición recibida desde la web."); - - // Respondemos INMEDIATAMENTE para que el HTML sepa que hemos oído - res.json({ success: true, message: "Orden recibida. Iniciando motor..." }); - - // Ejecutamos la lógica pesada sin bloquear - runRobotLogic().catch(err => console.error("❌ Error fatal en robot:", err)); + console.log("🔔 Petición recibida."); + res.json({ success: true, message: "Orden recibida. Iniciando..." }); + runRobotLogic().catch(err => console.error("❌ Error robot:", err)); }); -// --- 4. LÓGICA DEL ROBOT (Playwright) --- +// ... (MANTÉN AQUÍ LA FUNCIÓN runRobotLogic IGUAL QUE ANTES) ... async function runRobotLogic() { - console.log("🚀 Lanzando navegador..."); - let browser = null; - - try { - // 1. Obtener credenciales (o usar simuladas si falla la DB) - let user = "USUARIO_DEFECTO"; - let pass = "PASS_DEFECTO"; - - if (db) { - const doc = await db.collection("providerCredentials").doc("homeserve").get(); - if (doc.exists) { - user = doc.data().user; - pass = doc.data().pass; - } - } - - // 2. Navegador - browser = await chromium.launch({ - headless: true, // true para servidor - args: ['--no-sandbox', '--disable-setuid-sandbox'] - }); - - const page = await browser.newPage(); - - // 3. Login - console.log("🌍 Entrando a HomeServe..."); - await page.goto('https://www.clientes.homeserve.es/cgi-bin/fccgi.exe?w3exec=PROF_PASS', { timeout: 60000 }); - - const selUser = 'input[name="CODIGO"]'; - if (await page.isVisible(selUser)) { - console.log(`🔑 Logueando usuario...`); - await page.fill(selUser, user); - await page.fill('input[type="password"]', pass); - await page.keyboard.press('Enter'); - await page.waitForTimeout(3000); - } - - // 4. Ir a Liquidaciones - console.log("📂 Buscando liquidaciones..."); - await page.goto('https://www.clientes.homeserve.es/cgi-bin/fccgi.exe?w3exec=CONSULTALIQ_WEB'); - - // AQUÍ IRÍA EL RESTO DE TU LÓGICA DE EXTRACCIÓN... - // ... - - console.log("✅ Proceso del robot terminado."); - - } catch (error) { - console.error("❌ Error durante la ejecución del robot:", error); - } finally { - if (browser) await browser.close(); - } + // ... Tu lógica de playwright aquí ... + // Si necesitas que te la pegue entera otra vez dímelo, + // pero es la misma del mensaje anterior. + console.log("Simulando ejecución del robot..."); } -// --- 5. ARRANCAR SERVIDOR --- const PORT = process.env.PORT || 3000; app.listen(PORT, () => { console.log(`🚀 Servidor escuchando en puerto ${PORT}`);