U
    iF#                     @   s   d dl mZmZmZmZmZmZmZmZ d dl	Z	d dl
mZ d dlZd dlmZ d dlZd dlmZ d dlmZmZmZ d dlmZmZmZmZmZmZmZ d dlZd dl	Z	e  dZd	Z d
d Z!dd Z"dS )    )Flaskrender_template	send_fileaborturl_forjsonifyrequestsessionN)load_dotenv)secure_filename)user_has_access)subir_archivo_ftp_desde_requestview_pdf_fileverificar_actualizar_archivos)4get_Catalogo_de_calentadores_de_espacio_para_casetas7insert_Catalogo_de_calentadores_de_espacio_para_casetas7update_Catalogo_de_calentadores_de_espacio_para_casetas7delete_Catalogo_de_calentadores_de_espacio_para_casetasitem_existssearchitemsFupdate_Catalogo_de_calentadores_de_espacio_para_casetas_TechnicalSheetzS/domains/sycelephant.com/public_html/file/Ventas/EUA/DMITEMS/ENCLOSURE_SPACE_HEATERz+/Ventas/EUA/DMITEMS/ENCLOSURE_SPACE_HEATER/c                 C   s"   t | }|rt|d }nd}|S )Nr   )r   int)itemresultcount r   |C:\Users\victor.barrera\Documents\proyectos\elepV3\Elep\src\App\Ventas_Module\VentasEUA\DataMaster\DMEnclosureSpaceHeater.pyexisten_items"   s
    r   c                 C   s   | j ddgddd }|  ddd }| j d	d
gddd }| j dd
gddd }| j dd
gddd }| j ddgddd }dS )ud   
    Registra las rutas para la gestión de departamentos directamente en la aplicación Flask.
    zy/ventas/data_master/Catalogo_de_calentadores_de_espacio_para_casetas/listCatalogo_de_calentadores_de_espacio_para_casetasGET)methodsc               
   S   sT   zt  } t| dfW S  tk
rN } ztdt|idf W Y S d}~X Y nX dS )z
        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)
           error  N)r   r   	Exceptionstr)TIPOSCONTROLESer   r   r   5list_Catalogo_de_calentadores_de_espacio_para_casetas6   s
    	zregister_dmCatalogo_de_calentadores_de_espacio_para_casetas_routes.<locals>.list_Catalogo_de_calentadores_de_espacio_para_casetasz^/ventas/pdf_viewerCatalogo_de_calentadores_de_espacio_para_casetas/view/<path:filename_or_url>c                 S   s   t | S )u4   Endpoint para visualizar un archivo PDF específico.)r   )filename_or_urlr   r   r   7ver_pdfCatalogo_de_calentadores_de_espacio_para_casetasF   s    zregister_dmCatalogo_de_calentadores_de_espacio_para_casetas_routes.<locals>.ver_pdfCatalogo_de_calentadores_de_espacio_para_casetaszO/ventas/data_master/brakers/addCatalogo_de_calentadores_de_espacio_para_casetasPOSTc            	   
   S   s  t d} ztjd}tjd}tjd}tjd}t|||gs\tddidfW S t|d	krztdd
idfW S d }|rt||t	t
}|d r|d }ntd|d idfW S t||||}tddidfW S  tk
r } ztdt|idf W Y S d }~X Y nX d S )Nuser_idr   descriptionpriceTechnicalSheetr!   "Todos los campos son obligatorios.     u"   El item ya existe en el catálogo.exitourl_webmensajemessageuH   Catálogo de calentadores de espacio para casetas agregado exitosamente.   r"   )r	   getr   formfilesallr   r   r   ruta_pdfcarpetar   r#   r$   )	r+   r   r,   r-   technicalSheetfilename	resultador   r&   r   r   r   4add_Catalogo_de_calentadores_de_espacio_para_casetasM   s(    

zregister_dmCatalogo_de_calentadores_de_espacio_para_casetas_routes.<locals>.add_Catalogo_de_calentadores_de_espacio_para_casetaszJ/ventas/data_master/updateCatalogo_de_calentadores_de_espacio_para_casetasc               
   S   s   zdt  } | d}| d}| d}t|||gsHtddidfW S t||| tddid	fW S  tk
r } ztdt|id
f W Y S d}~X Y nX dS )z)Actualiza un breaker en la base de datos.r   r,   r-   r!   r/   r0   r5   uK   Catálogo de calentadores de espacio para casetas actualizado exitosamente.r    r"   N)r   get_jsonr7   r:   r   r   r#   r$   )datar   r,   r-   r&   r   r   r   =update_Catalogo_de_calentadores_de_espacio_para_casetas_routep   s    


zregister_dmCatalogo_de_calentadores_de_espacio_para_casetas_routes.<locals>.update_Catalogo_de_calentadores_de_espacio_para_casetas_routez{/ventas/data_master/Catalogo_de_calentadores_de_espacio_para_casetas/deleteCatalogo_de_calentadores_de_espacio_para_casetasc               
   S   s   zBt  } | d}|s*tddidfW S t| tddidfW S  tk
r| } ztdt|idf W Y S d	}~X Y nX d	S )
z'Elimina un control de la base de datos.r   r!   zEl campo Item es obligatorio.r0   r5   uI   Catálogo de calentadores de espacio para casetas eliminado exitosamente.r    r"   N)r   rA   r7   r   r   r#   r$   )rB   r   r&   r   r   r   =delete_Catalogo_de_calentadores_de_espacio_para_casetas_route   s    
zregister_dmCatalogo_de_calentadores_de_espacio_para_casetas_routes.<locals>.delete_Catalogo_de_calentadores_de_espacio_para_casetas_routez/ventas/data_master/Catalogo_de_calentadores_de_espacio_para_casetas/actualizarCatalogo_de_calentadores_de_espacio_para_casetasc                  S   s   zld} d}t dddtt| |dtd	}|d rBtd	|d
 idfW S td|d
   td|d
 idfW S W n` tk
r } zBddl}tdt|  t|	  tdt|idf W Y S d}~X Y nX dS )uN   Actualiza todas las Fichas técnicas verificando su existencia en el servidor.zCConsultas_SQL.Ventas.VentasEUA.DataMaster.DMEnclosureSpaceHeaterSQLr   ZCZE_EnclosureSpaceHeaterItem_Enclosure_SHeaterr.   zhttps://file.sycelephant.com)	tablacampo_id	campo_urlupdate_functionruta_remotamodule_pathsearch_function_namebase_urlr<   r2   r5   r4   r    u   Error en actualización: r!   r"   r   Nu   Error en la actualización: )
r   r   r;   r<   r   printr#   	tracebackr$   
format_exc)rK   function_namer?   r&   rO   r   r   r   >updated_Catalogo_de_calentadores_de_espacio_para_casetas_route   s.    zregister_dmCatalogo_de_calentadores_de_espacio_para_casetas_routes.<locals>.updated_Catalogo_de_calentadores_de_espacio_para_casetas_routeN)route)appr'   r)   r@   rC   rD   rR   r   r   r   Bregister_dmCatalogo_de_calentadores_de_espacio_para_casetas_routes/   s    


"

rU   )#flaskr   r   r   r   r   r   r   r	   osdotenvr
   ftplibZwerkzeug.utilsr   tempfile App.Security_Module.UserPasswordr   App.Subir_Archivor   r   r   ZCConsultas_SQL.Ventas.VentasEUA.DataMaster.DMEnclosureSpaceHeaterSQLr   r   r   r   r   r   r   requestsr;   r<   r   rU   r   r   r   r   <module>   s   ($	