const express = require('express'); const { chromium } = require('playwright'); const admin = require('firebase-admin'); const cors = require('cors'); // --- CONFIGURACIÓN 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."); } } 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 🛡️ --- app.use(cors({ origin: '*', // Permitir todo methods: ['GET', 'POST', 'OPTIONS'], // Permitir estos métodos allowedHeaders: ['Content-Type', 'Authorization'] // Permitir estas cabeceras })); // Forzar respuesta OK a las peticiones OPTIONS (Preflight) app.options('*', cors()); app.use(express.json()); // RUTA DE TEST app.get('/', (req, res) => { res.send('🤖 El Robot de Cobros está ONLINE y esperando órdenes.'); }); // RUTA DEL ROBOT app.post('/api/robot-cobros', async (req, res) => { console.log("🔔 Petición POST recibida correctamente."); res.json({ success: true, message: "Orden recibida. Iniciando..." }); // Ejecutar en segundo plano runRobotLogic().catch(err => console.error("❌ Error en lógica robot:", 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); } } const PORT = process.env.PORT || 3000; app.listen(PORT, () => { console.log(`🚀 Servidor escuchando en puerto ${PORT}`); });