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 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 TEST (Para comprobar en el navegador) 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 recibida."); res.json({ success: true, message: "Orden recibida. Iniciando..." }); runRobotLogic().catch(err => console.error("❌ Error robot:", err)); }); // ... (MANTÉN AQUÍ LA FUNCIÓN runRobotLogic IGUAL QUE ANTES) ... async function runRobotLogic() { // ... 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..."); } const PORT = process.env.PORT || 3000; app.listen(PORT, () => { console.log(`🚀 Servidor escuchando en puerto ${PORT}`); });