const express = require('express'); const cors = require('cors'); const { chromium } = require('playwright'); const admin = require('firebase-admin'); // --- FIREBASE --- try { if (process.env.FIREBASE_PRIVATE_KEY) { if (!admin.apps.length) { admin.initializeApp({ credential: admin.credential.cert({ projectId: process.env.FIREBASE_PROJECT_ID, clientEmail: process.env.FIREBASE_CLIENT_EMAIL, privateKey: process.env.FIREBASE_PRIVATE_KEY.replace(/\\n/g, '\n'), }), }); } console.log("✅ Firebase inicializado."); } else { console.log("⚠️ FIREBASE_PRIVATE_KEY no está seteada. Firebase OFF."); } } catch (e) { console.error("❌ Error Firebase:", e.message); } const db = admin.apps.length ? admin.firestore() : null; const COLLECTION_NAME = "homeserve_pendientes"; const app = express(); // --- CORS (robusto) --- app.use(cors({ origin: '*', methods: ['GET', 'POST', 'OPTIONS'], allowedHeaders: ['Content-Type', 'Authorization'], })); // 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()); // TEST app.get('/', (req, res) => { res.status(200).send('🤖 El Robot de Cobros está ONLINE y esperando órdenes.'); }); 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("🔔 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 try { await runRobotLogic(); } catch (err) { console.error("❌ Error robot:", err?.message || err); } }); async function runRobotLogic() { 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 || process.env.CAPROVER_PORT || 3000; app.listen(PORT, () => { console.log(`🚀 Servidor escuchando en puerto ${PORT}`); });