Actualizar server.js
This commit is contained in:
50
server.js
50
server.js
@@ -1812,7 +1812,7 @@ app.post("/providers/credentials", authMiddleware, async (req, res) => {
|
||||
});
|
||||
|
||||
// ==========================================
|
||||
// 📥 RECEPCIÓN DE SERVICIOS (EMBUDO INTELIGENTE DEFINITIVO)
|
||||
// 📥 RECEPCIÓN DE SERVICIOS (EL DETECTOR DEFINITIVO Y MÁS LIMPIO)
|
||||
// ==========================================
|
||||
app.post("/providers/scraped", authMiddleware, async (req, res) => {
|
||||
try {
|
||||
@@ -1846,43 +1846,30 @@ app.post("/providers/scraped", authMiddleware, async (req, res) => {
|
||||
continue;
|
||||
}
|
||||
|
||||
// 🔥 2. DETECTOR DEFINITIVO Y A PRUEBA DE BALAS 🔥
|
||||
// 🔥 2. DETECTOR DE URGENCIAS MODO DIOS 🔥
|
||||
let esUrgente = false;
|
||||
|
||||
const checkUrgencia = (obj) => {
|
||||
for (const key in obj) {
|
||||
if (typeof obj[key] === 'object') continue;
|
||||
// Convertimos todo a un texto gigante, minúsculas, sin acentos ni símbolos raros
|
||||
const todoElTexto = JSON.stringify(svc)
|
||||
.toLowerCase()
|
||||
.normalize("NFD")
|
||||
.replace(/[\u0300-\u036f]/g, "")
|
||||
.replace(/\n/g, " "); // Quitamos saltos de línea por si acaso
|
||||
|
||||
const col = String(key).toLowerCase().normalize("NFD").replace(/[\u0300-\u036f]/g, "");
|
||||
const val = String(obj[key]).toLowerCase().normalize("NFD").replace(/[\u0300-\u036f]/g, "");
|
||||
|
||||
// Caso 1: Multiasistencia (La columna se llama "urgencia" y el valor es "si")
|
||||
if ((col.includes('urgent') || col.includes('urgencia')) && (val === 'si' || val === 'true')) {
|
||||
return true;
|
||||
}
|
||||
|
||||
// Caso 2: HomeServe (Buscamos en Descripción, Estado, etc.)
|
||||
// Para no caer en el falso positivo (Nivel de urgencia: Normal), ignoramos la caja si se llama "urgencia"
|
||||
if (!col.includes('urgent') && !col.includes('urgencia')) {
|
||||
// Si en la descripción o el estado pone urgente, urgencia o el texto cortado "por atencion"
|
||||
if (val.includes('urgente') || val.includes('urgencia') || val.includes('por atencion')) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
}
|
||||
return false;
|
||||
};
|
||||
|
||||
// Comprobamos en la raíz y en los datos anidados
|
||||
if (checkUrgencia(svc)) {
|
||||
esUrgente = true;
|
||||
} else if (svc.raw_data && checkUrgencia(svc.raw_data)) {
|
||||
// 1. Detección HomeServe: Busca la frase clave de la Bandeja de Entrada o del Interior
|
||||
if (todoElTexto.includes("atencion presencial urgencias") || todoElTexto.includes("atencion de la urgencia") || todoElTexto.includes("por atencion")) {
|
||||
esUrgente = true;
|
||||
}
|
||||
|
||||
// 2. Detección Multiasistencia: Busca el combo "urgente":"si" literal en el JSON
|
||||
if (todoElTexto.includes('"urgente":"si"') || todoElTexto.includes('"urgencia":"si"')) {
|
||||
esUrgente = true;
|
||||
}
|
||||
|
||||
// 3. Extracción de Gremio
|
||||
const guildId = svc.guild_id || svc['guild_id'] || (svc.raw_data && svc.raw_data.guild_id);
|
||||
|
||||
// 3. GUARDAMOS EN LA BD (CON MEMORIA ETERNA: OR EXCLUDED.is_urgent)
|
||||
// 4. GUARDAMOS EN LA BD (CON MEMORIA ETERNA: OR EXCLUDED.is_urgent)
|
||||
const insertRes = await pool.query(`
|
||||
INSERT INTO scraped_services (owner_id, provider, service_ref, raw_data, is_urgent)
|
||||
VALUES ($1, $2, $3, $4, $5)
|
||||
@@ -1896,11 +1883,10 @@ app.post("/providers/scraped", authMiddleware, async (req, res) => {
|
||||
const newSvcId = insertRes.rows[0].id;
|
||||
const autoStatus = insertRes.rows[0].automation_status;
|
||||
|
||||
// 4. AUTO-DESPACHO
|
||||
// 5. AUTO-DESPACHO
|
||||
if (esUrgente && guildId && autoDispatchEnabled && (autoStatus === 'manual' || autoStatus === 'pending')) {
|
||||
console.log(`⚡ [AUTO-DISPATCH] Lanzando urgencia ${ref} a la bolsa...`);
|
||||
|
||||
const todoElTexto = JSON.stringify(svc).toLowerCase();
|
||||
const cpMatch = todoElTexto.match(/\b\d{5}\b/);
|
||||
const cpFinal = cpMatch ? cpMatch[0] : "00000";
|
||||
|
||||
|
||||
Reference in New Issue
Block a user