a
    ž"¾hè  ã                   @   sì   d dl mZmZmZmZ d dlmZ d dlmZ d dl	m
Z
mZmZ d dlmZ d dlmZ d dlmZ d dlZeƒ Zed	d
Zeeƒ ƒZe d¡edƒedƒedƒeeƒfeeeedœdd„ƒZe d¡deeƒfeeedœdd„ƒZdS )é    )Ú	APIRouterÚRequestÚDependsÚForm)ÚJinja2Templates)ÚRedirectResponse)Ú
open_mysqlÚget_mysql_credsÚget_pingconf_vars)Úget_current_user)Ú	xor_bytes)ÚHTTP_303_SEE_OTHERNz"/wd/v2025.freedom4um.com/templates)Ú	directoryz/mailcompose.Ú )Úto_listÚsubjectÚCommentÚcurrent_userc                 C   s8  |sddiS |d }dd„ |   d¡D ƒ}t| d¡ƒ}t| d¡ƒ}ttƒÊ}|jdd	}	|r¤d d
gt|ƒ ¡}
|	 d|
› d|¡ |	 	¡ }d dd„ |D ƒ¡}nd}d}|	 |||||f¡ | 
¡  |	j}d}|	 |||df¡ |D ]}|	 |||df¡ qè| 
¡  W d   ƒ n1 s0    Y  d}t|tdS )NÚerrorÚUnauthorizedÚHandleIDc                 S   s    g | ]}|  ¡  ¡ rt|ƒ‘qS © )ÚstripÚisdigitÚint)Ú.0Úxr   r   ú./wd/v2025.freedom4um.com/routes/mailcompose.pyÚ
<listcomp>   ó    z$mailcompose_post.<locals>.<listcomp>ú,úutf-8T©Ú
dictionaryú%sz.SELECT Handle FROM Handles WHERE HandleID IN (ú)c                 S   s   g | ]}|d  ‘qS )ÚHandler   )r   Úrr   r   r   r   %   r   r   z
            INSERT INTO PrivateMail (FromHandleID, ToLine, PostDate, Subject, MailBodyBlob)
            VALUES (%s, %s, NOW(), %s, %s)
        z
            INSERT INTO PrivateMailPing (PMailNum, ToHandleID, MailStatus, Folder)
            VALUES (%s, %s, 'N', %s)
        ÚSÚIz/maillist?folder=S)ÚurlÚstatus_code)Úsplitr   Úencoder   Úmysql_credsÚcursorÚjoinÚlenÚexecuteÚfetchallÚcommitÚ	lastrowidr   r   )r   r   r   r   Z	sender_idÚto_idsÚencoded_bodyZencoded_subjectÚconnr/   ÚplaceholdersÚ
recipientsZto_lineZsql_mailZnew_pmail_numZsql_pingÚto_idÚredirect_urlr   r   r   Úmailcompose_post   s2    
(r=   )ÚrequestÚPMNr   c              	   C   sÚ  |st dƒS d }g }|rÂttƒŒ}|jdd}| d|f¡ | ¡ }|r¢| d|f¡ dd„ | ¡ D ƒ}|d |vr |d |d	 kr t dƒW  d   ƒ S |rÞd
 dgt|ƒ ¡}	| d|	› d|¡ dd„ | ¡ D ƒ}t	|d pêdƒj
ddd}
tj|
g d¢dd|d< | d|d	 f¡ | ¡ }|r8|d nd|d< t	| d¡ƒpRd}|j
ddd}| d¡svd| }tj|g d¢dd|d< d|d< |}t|ƒ W d   ƒ n1 s¸0    Y  t d | ||||d!œ¡S )"Nz/signinTr"   z©
                SELECT PMailNum, FromHandleID, ToLine, PostDate, Subject, MailBodyBlob
                FROM PrivateMail
                WHERE PMailNum = %s
            zCSELECT DISTINCT ToHandleID FROM PrivateMailPing WHERE PMailNum = %sc                 S   s   g | ]}|d  ‘qS )Z
ToHandleIDr   ©r   Úrowr   r   r   r   [   r   z#mailcompose_get.<locals>.<listcomp>r   ZFromHandleIDr    r$   z8SELECT HandleID, Handle FROM Handles WHERE HandleID IN (r%   c                 S   s   g | ]}|d  |d dœ‘qS )r   r&   )r   ÚNamer   r@   r   r   r   r   d   r   ZMailBodyBlobr   r!   Úreplace)Úerrors)ÚbÚiÚuÚbrÚp)Útagsr   z6SELECT Handle AS Name FROM Handles WHERE HandleID = %srB   ÚUnknownÚFromNameÚSubjectzRe:zRe: )rE   rF   rG   Zprivate_mailÚtypezmailcompose.html)r>   r   Úcontext_itemZ	pmail_numÚto_users)r   r   r.   r/   r2   Úfetchoner3   r0   r1   r   ÚdecodeÚbleachÚcleanÚgetÚ
startswithÚprintÚ	templatesÚTemplateResponse)r>   r?   r   rO   rP   r8   r/   Úmailr6   r9   Z	body_textZfrom_rowZsubject_bytesZsubject_textr   r   r   Úmailcompose_getD   sT    ü(ûþr[   )Úfastapir   r   r   r   Úfastapi.templatingr   Úfastapi.responsesr   Úutils.pingdatar   r	   r
   Ú
utils.authr   Z	utils.xorr   Zstarlette.statusr   rS   ÚrouterrX   r.   ÚpostÚstrÚdictr=   rU   r   r[   r   r   r   r   Ú<module>   s.   

üü5