# Optimized Python Code
# Archivo: DMCatalogo_de_controles.py
# Ruta: src\App\Ventas_Module\VentasEUA\DataMaster\DMCatalogo_de_controles.py
# Lenguaje: Python con Flask

from flask import Flask, render_template, send_file, abort, url_for, jsonify, request,session
import os
from dotenv import load_dotenv
import ftplib
from werkzeug.utils import secure_filename
import tempfile
from App.Security_Module.UserPassword import user_has_access
from App.Subir_Archivo import subir_archivo_ftp_desde_request,view_pdf_file,verificar_actualizar_archivos
from Consultas_SQL.Ventas.VentasEUA.DataMaster.DMControllerCatalogSQL import (
    get_Catalogo_de_controles, insert_Catalogo_de_controles,update_Catalogo_de_controles,delete_Catalogo_de_controles,item_exists,searchitems,update_Catalogo_de_controles_TechnicalSheet
    )
import requests
import os
# Cargar las variables de entorno desde el archivo .env
load_dotenv()
# /////////////////////////////////
#   Variables Generales
# ////////////////////////////////

ruta_pdf = "/domains/sycelephant.com/public_html/file/Ventas/EUA/DMITEMS/CONTROLLER_CATALOG"
carpeta = "/Ventas/EUA/DMITEMS/CONTROLLER_CATALOG/"
# /////////////////////////////////
#   Funciones Genericas
# ////////////////////////////////


# /////////////////////////////////
#   Varifica items Repetidos
# ////////////////////////////////
def existen_items(item):
    result = item_exists(item)
    if result:  # Verifica si result no es None (puede ser None si la consulta no encuentra nada)
        count = int(result[0]) # Accede al primer elemento de la tupla (índice 0) y lo convierte a entero.
    else:
        count = 0
    return count

# /////////////////////////////////
#   Eliminar Archivos
# ////////////////////////////////

def eliminar_archivo(url):
    """
    user_id = session.get('user_id')
    if not user_has_access(user_id, "Ventas", "delete"):
        message = "No tiene permisos para eliminar"
        return render_template("Security/AccessDened.html",message)
    """
    response = requests.delete(url)
    if response.status_code == 200:
        print(f"El archivo en {url} ha sido eliminado exitosamente.")
    else:
        print(f"No se pudo eliminar el archivo en {url}. Código de estado: {response.status_code}")

# /////////////////////////////////
#   Funciones dedicadas
# ////////////////////////////////

def register_dmCatalogo_de_controles_routes(app):
    """
    Registra las rutas para la gestión de departamentos directamente en la aplicación Flask.
    """
    # /////////////////////////////////
    #   Consultar Breakers
    # ////////////////////////////////
    @app.route("/ventas/data_master/Catalogo_de_controles/listCatalogo_de_controles", methods=["GET"])
    def list_Catalogo_de_controles_catalog():
        """
        user_id = session.get('user_id')
        if not user_has_access(user_id, "Ventas","read"):
            message = "No tiene permisos para visualizar este archivo"
            return render_template("Security/AccessDened.html",message)
        """
        """Retorna la lista de get_Catalogo_de_controles."""
        try:
            TIPOSCONTROLES = get_Catalogo_de_controles()
            return jsonify(TIPOSCONTROLES), 200
        except Exception as e:
            return jsonify({"error": str(e)}), 500
    # Función para verificar si un item ya existe en la base de datos
    
    @app.route("/ventas/pdf_viewerCatalogo_de_controles/view/<path:filename_or_url>")
    def ver_pdfCatalogo_de_controles_catalog(filename_or_url):
        """Endpoint para visualizar un archivo PDF específico."""
        return view_pdf_file(filename_or_url)
   
        """Actualiza todas las Fichas técnicas verificando su existencia en el servidor."""
        try:
            # Configuramos la ruta al módulo y el nombre de la función
            module_path = "Consultas_SQL.Ventas.VentasEUA.DataMaster.DMControllerCatalogSQL"
            function_name = "searchitems"
            
            # Llamamos a verificar_actualizar_archivos con la configuración dinámica
            resultado = verificar_actualizar_archivos(
                tabla="CZE_ControllerCatalog",
                campo_id="Item_controller",
                campo_url="TechnicalSheet",
                update_function=update_Catalogo_de_controles_TechnicalSheet,
                ruta_remota=ruta_pdf,
                module_path=module_path,             # Pasamos la ruta al módulo
                search_function_name=function_name,  # Pasamos el nombre de la función
                base_url="https://file.sycelephant.com",
                carpeta = carpeta
            )
            
            if resultado["exito"]:
                return jsonify({"message": resultado["mensaje"]}), 200
            else:
                print(f"Error en actualización: {resultado['mensaje']}")
                return jsonify({"error": resultado["mensaje"]}), 500
                
        except Exception as e:
            import traceback
            print(f"Error en la actualización: {str(e)}")
            print(traceback.format_exc())
            return jsonify({"error": str(e)}), 500