Se agregaron cambios de XMLController

This commit is contained in:
2025-09-12 15:30:03 -06:00
parent c58e9dd3b9
commit a3b3e73e37
2 changed files with 45 additions and 10 deletions

View File

@@ -1,5 +1,6 @@
import xml.etree.ElementTree as ET
from dataclasses import dataclass
from typing import List, Dict
# Pedimento Completo
@dataclass
@@ -247,9 +248,51 @@ class XMLScraper: # Clase me extrae datos de Pedimento
return extract_xml_data(xml_content)
class XMLControllerRemesas:
pass
"""
Controlador para scrapear XML de consultar remesas.
Extrae todos los comprobantesVE, junto con remesaAgente y remesaSA.
"""
namespaces = {
"S": "http://schemas.xmlsoap.org/soap/envelope/",
"ns2": "http://www.ventanillaunica.gob.mx/common/ws/oxml/respuesta",
"ns3": "http://www.ventanillaunica.gob.mx/pedimentos/ws/oxml/consultarremesas",
}
def extract_remesas(self, xml_content: str) -> List[Dict[str, str]]:
"""
Extrae todos los comprobanteVE de un XML de remesas.
Args:
xml_content: Contenido del XML en string.
Returns:
Lista de diccionarios con comprobanteVE, remesaAgente y remesaSA.
"""
try:
root = ET.fromstring(xml_content)
remesas = []
for remesa in root.findall(".//ns3:remesas", self.namespaces):
comprobante = remesa.find("ns3:comprobanteVE", self.namespaces)
agente = remesa.find("ns3:remesaAgente", self.namespaces)
sa = remesa.find("ns3:remesaSA", self.namespaces)
remesas.append({
"comprobanteVE": comprobante.text if comprobante is not None else None,
"remesaAgente": agente.text if agente is not None else None,
"remesaSA": sa.text if sa is not None else None
})
return remesas
except ET.ParseError as e:
print(f"Error al parsear XML: {e}")
return []
except Exception as e:
print(f"Error inesperado: {e}")
return []
class XMLControllerPartidas:
pass

View File

@@ -38,7 +38,6 @@ def run_async_task(async_func, *args, **kwargs):
finally:
loop.close()
@celery_app.task(bind=True, name='tasks.pedimento_completo_task')
def pedimento_completo_task(self, request_data: Dict[str, Any]):
"""
@@ -159,7 +158,6 @@ def pedimento_completo_task(self, request_data: Dict[str, Any]):
return run_async_task(_execute_pedimento_completo)
@celery_app.task(bind=True)
def partidas_task(self, **kwargs):
"""Tarea asíncrona para obtener partidas"""
@@ -278,7 +276,6 @@ def partidas_task(self, **kwargs):
return run_async_task(_execute_partidas)
@celery_app.task(bind=True)
def remesas_task(self, **kwargs):
"""Tarea asíncrona para obtener remesas"""
@@ -365,7 +362,6 @@ def remesas_task(self, **kwargs):
return run_async_task(_execute_remesas)
@celery_app.task(bind=True)
def acuse_task(self, **kwargs):
"""Tarea asíncrona para obtener acuse"""
@@ -504,7 +500,6 @@ def acuse_task(self, **kwargs):
return run_async_task(_execute_acuse)
# Tarea asíncrona para consultar el estado de un pedimento
@celery_app.task(bind=True, name='tasks.estado_pedimento_task')
def estado_pedimento_task(self, request_data: Dict[str, Any]):
@@ -573,7 +568,6 @@ def estado_pedimento_task(self, request_data: Dict[str, Any]):
raise e
return run_async_task(_execute_estado_pedimento)
@celery_app.task(bind=True)
def edocument_task(self, **kwargs):
"""Tarea asíncrona para obtener edocument"""
@@ -734,7 +728,6 @@ def edocument_task(self, **kwargs):
return run_async_task(_execute_edocument)
@celery_app.task(bind=True)
def coves_task(self, **kwargs):
"""Tarea asíncrona para obtener coves"""
@@ -1006,4 +999,3 @@ def acuse_cove_task(self, **kwargs):
raise e
return run_async_task(_execute_acuse_cove)