auditor
This commit is contained in:
@@ -39,6 +39,70 @@ def auditar_procesamiento_remesas(organizacion_id):
|
||||
organizacion=organizacion_id
|
||||
)
|
||||
|
||||
@shared_task
|
||||
def auditar_procesamiento_remesa_por_pedimento(pedimento_id):
|
||||
"""
|
||||
Audita el procesamiento de remesa para un pedimento específico.
|
||||
Args:
|
||||
pedimento_id: UUID del pedimento a auditar
|
||||
Returns:
|
||||
dict: Resultado de la auditoría con detalles del procesamiento
|
||||
"""
|
||||
try:
|
||||
pedimento = Pedimento.objects.get(id=pedimento_id)
|
||||
resultado = {
|
||||
'pedimento_id': str(pedimento_id),
|
||||
'pedimento_numero': pedimento.pedimento,
|
||||
'tiene_remesas': pedimento.remesas,
|
||||
'procesamiento_creado': False,
|
||||
'coves_creados': []
|
||||
}
|
||||
|
||||
if not pedimento.remesas:
|
||||
resultado['mensaje'] = 'El pedimento no tiene remesas para procesar'
|
||||
return resultado
|
||||
|
||||
# Verificar documento tipo remesa
|
||||
if not pedimento.documents.filter(document_type=3).exists():
|
||||
# Crear procesamiento si no existe documento de remesa
|
||||
procesamiento, creado = ProcesamientoPedimento.objects.get_or_create(
|
||||
pedimento=pedimento,
|
||||
servicio_id=5, # ID del servicio de remesas
|
||||
organizacion=pedimento.organizacion_id
|
||||
)
|
||||
resultado['procesamiento_creado'] = creado
|
||||
resultado['mensaje'] = 'Procesamiento de remesa creado - documento no encontrado'
|
||||
else:
|
||||
# Procesar XML de remesas
|
||||
xml_data = extraer_coves(pedimento)
|
||||
if xml_data:
|
||||
for remesa in xml_data:
|
||||
numero_cove = remesa.get('remesaSA')
|
||||
cove, creado = Cove.objects.get_or_create(
|
||||
pedimento=pedimento,
|
||||
numero_cove=numero_cove,
|
||||
organizacion=pedimento.organizacion_id
|
||||
)
|
||||
if creado:
|
||||
resultado['coves_creados'].append(numero_cove)
|
||||
|
||||
resultado['mensaje'] = f"Procesados {len(xml_data)} remesas, creados {len(resultado['coves_creados'])} COVEs nuevos"
|
||||
else:
|
||||
resultado['mensaje'] = 'No se encontraron datos de remesas en el XML'
|
||||
|
||||
return resultado
|
||||
|
||||
except Pedimento.DoesNotExist:
|
||||
return {
|
||||
'error': f'Pedimento con ID {pedimento_id} no encontrado',
|
||||
'pedimento_id': str(pedimento_id)
|
||||
}
|
||||
except Exception as e:
|
||||
return {
|
||||
'error': f'Error procesando pedimento {pedimento_id}: {str(e)}',
|
||||
'pedimento_id': str(pedimento_id)
|
||||
}
|
||||
|
||||
|
||||
@shared_task
|
||||
def auditar_partidas(organizacion_id):
|
||||
|
||||
@@ -167,7 +167,7 @@ def crear_servicios(organizacion_id):
|
||||
crear_procesamiento_edocument.apply_async(args=[str(pedimento.id)])
|
||||
|
||||
@shared_task
|
||||
def auditar_pedimento(organizacion_id):
|
||||
def auditar_pedimentos(organizacion_id):
|
||||
|
||||
pedimentos = Pedimento.objects.filter(organizacion_id=organizacion_id)
|
||||
for pedimento in pedimentos:
|
||||
|
||||
Reference in New Issue
Block a user