
    i!                         S SK JrJrJrJrJrJrJrJr  S SK	r	S SK
Jr  S SKrS SKJr  S SKrS SKJr  S SKJrJrJr  S SKJrJrJrJrJrJrJr  S SKrS SK	r	\" 5         SrS	r S
 r!S r"g)    )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)get_Catalogo_de_amortiguadores!insert_Catalogo_de_amortiguadores!update_Catalogo_de_amortiguadores!delete_Catalogo_de_amortiguadoresitem_existssearchitems0update_Catalogo_de_amortiguadores_TechnicalSheetzO/domains/sycelephant.com/public_html/file/Ventas/EUA/DMITEMS/ADDACCESORY_SPRINGz'/Ventas/EUA/DMITEMS/ADDACCESORY_SPRING/c                 N    [        U 5      nU(       a  [        US   5      nU$ SnU$ )Nr   )r   int)itemresultcounts      zC:\Users\victor.barrera\Documents\proyectos\elepV3\Elep\src\App\Ventas_Module\VentasEUA\DataMaster\DMAddAccesory_Spring.pyexisten_itemsr   "   s/    FF1I L L    c                    U R                  SS/S9S 5       nU R                  S5      S 5       nU R                  SS/S9S	 5       nU R                  S
S/S9S 5       nU R                  SS/S9S 5       nU R                  SS/S9S 5       ng)u\   
Registra las rutas para la gestión de departamentos directamente en la aplicación Flask.
zM/ventas/data_master/Catalogo_de_amortiguadores/listCatalogo_de_amortiguadoresGET)methodsc                        [        5       n [        U 5      S4$ ! [         a"  n[        S[        U5      05      S4s SnA$ SnAff = f)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es     r   list_Catalogo_de_amortiguadoresUregister_dmCatalogo_de_amortiguadores_routes.<locals>.list_Catalogo_de_amortiguadores5   sN     	B	3;=N>*C// 	3GSV,-s22	3s    
AAAAzH/ventas/pdf_viewerCatalogo_de_amortiguadores/view/<path:filename_or_url>c                     [        U 5      $ )u4   Endpoint para visualizar un archivo PDF específico.)r   )filename_or_urls    r   !ver_pdfCatalogo_de_amortiguadoresWregister_dmCatalogo_de_amortiguadores_routes.<locals>.ver_pdfCatalogo_de_amortiguadoresE   s     _--r   z9/ventas/data_master/brakers/addCatalogo_de_amortiguadoresPOSTc                     [         R                  " S5      n  [        R                  R                  S5      n[        R                  R                  S5      n[        R                  R                  S5      n[        R                  R                  S5      n[        XU/5      (       d  [        SS05      S4$ [        U5      S	:X  a  [        SS
05      S4$ S nU(       a7  [        XA[        [        5      nUS   (       a  US   nO[        SUS   05      S4$ [        XX55      n[        SS05      S4$ ! [         a"  n[        S[        U5      05      S4s S nA$ S nAff = f)Nuser_idr   descriptionpriceTechnicalSheetr%   "Todos los campos son obligatorios.     u"   El item ya existe en el catálogo.exitourl_webmensajemessageu2   Catálogo de amortiguadores agregado exitosamente.   r&   )r
   getr	   formfilesallr   r   r   ruta_pdfcarpetar   r'   r(   )	r3   r   r4   r5   technicalSheetfilename	resultador   r*   s	            r   add_Catalogo_de_amortiguadoresTregister_dmCatalogo_de_amortiguadores_routes.<locals>.add_Catalogo_de_amortiguadoresL   sG   ++i(!	3<<##F+D!,,**=9KLL$$W-E$]]../?@N5122)MNOQTTT T"a')MNOQTTTH <NRZ[bc	W%(3H"GYy-A#BCSHH 7t%ZFI'[\]_bbb 	3GSV,-s22	3s0   BD. 5D. ?D. D. .
E8EEEz4/ventas/data_master/updateCatalogo_de_amortiguadoresc                  j    [         R                  " 5       n U R                  S5      nU R                  S5      nU R                  S5      n[        XU/5      (       d  [	        SS05      S4$ [        XU5        [	        SS05      S	4$ ! [         a"  n[	        S[        U5      05      S
4s SnA$ SnAff = f)z)Actualiza un breaker en la base de datos.r   r4   r5   r%   r7   r8   r=   u5   Catálogo de amortiguadores actualizado exitosamente.r$   r&   N)r	   get_jsonr?   rB   r   r   r'   r(   )datar   r4   r5   r*   s        r   'update_Catalogo_de_amortiguadores_route]register_dmCatalogo_de_amortiguadores_routes.<locals>.update_Catalogo_de_amortiguadores_routet   s    	3##%D88F#D((=1KHHW%E5122)MNOQTTT-dGI'^_`beee 	3GSV,-s22	3s$   A(B +B 
B2B-'B2-B2zO/ventas/data_master/Catalogo_de_amortiguadores/deleteCatalogo_de_amortiguadoresc                      [         R                  " 5       n U R                  S5      nU(       d  [        SS05      S4$ [	        U5        [        SS05      S4$ ! [
         a"  n[        S[        U5      05      S4s S	nA$ S	nAff = f)
z'Elimina un control de la base de datos.r   r%   zEl campo Item es obligatorio.r8   r=   u3   Catálogo de amortiguadores eliminado exitosamente.r$   r&   N)r	   rK   r?   r   r   r'   r(   )rL   r   r*   s      r   'delete_Catalogo_de_amortiguadores_route]register_dmCatalogo_de_amortiguadores_routes.<locals>.delete_Catalogo_de_amortiguadores_route   s    	3##%D88F#D)HIJCOO-d3I'\]^`ccc 	3GSV,-s22	3s"   ;A A 
B"A?9B?BzS/ventas/data_master/Catalogo_de_amortiguadores/actualizarCatalogo_de_amortiguadoresc                      Sn Sn[        SSS[        [        U US[        S9	nUS   (       a  [	        S	US
   05      S4$ [        SUS
    35        [	        SUS
   05      S4$ ! [         aV  nSSKn[        S[        U5       35        [        UR                  5       5        [	        S[        U5      05      S4s SnA$ SnAff = f)uN   Actualiza todas las Fichas técnicas verificando su existencia en el servidor.zAConsultas_SQL.Ventas.VentasEUA.DataMaster.DMAddAccesory_SpringSQLr   CZE_AddAccesory_SpringItem_AddAccesory_Springr6   zhttps://file.sycelephant.com)	tablacampo_id	campo_urlupdate_functionruta_remotamodule_pathsearch_function_namebase_urlrD   r:   r=   r<   r$   u   Error en actualización: r%   r&   r   Nu   Error en la actualización: )
r   r   rC   rD   r   printr'   	tracebackr(   
format_exc)rZ   function_namerG   r*   r^   s        r   (updated_Catalogo_de_amortiguadores_route^register_dmCatalogo_de_amortiguadores_routes.<locals>.updated_Catalogo_de_amortiguadores_route   s    	3]K)M 6.2* P$'%27!
I !	9Y+?@A3FF1)I2F1GHI9)=>?DD 	30Q9:)&&()GSV,-s22		3s#   <A" "A" "
C,AB=7C=CN)route)appr+   r/   rH   rM   rP   ra   s          r   ,register_dmCatalogo_de_amortiguadores_routesre   .   s     	YY^inhoYp3 q3 	YYYZ. [. 	YYJU[T\Y]#3 ^#3N 	YYEPVxYX3 Y3& 	YY`kqjrYs
3 t
3 	YYdotnuYv3 w3r   )#flaskr   r   r   r   r   r   r	   r
   osdotenvr   ftplibwerkzeug.utilsr   tempfile App.Security_Module.UserPasswordr   App.Subir_Archivor   r   r   AConsultas_SQL.Ventas.VentasEUA.DataMaster.DMAddAccesory_SpringSQLr   r   r   r   r   r   r   requestsrC   rD   r   re    r   r   <module>rq      s]    ^ ] ] 	   *  < i i    	  ]
3J3r   