o
    sZŽh©;  ã                
   @   s‚  d dl Z d dlZd dlZd dlZd dlZdejj_d dlm	Z	 d dlm
Z
 d dlZd dlZd dlZd dlZd dlZd dlmZ i dd“dd	“d
d“dd“dd“dd “dd“dd“dd“dd“dd“dd“dd“dd“dd “d!d"“d#d$“d%d&d'd(d)œ¥Zdd*d+d,gd-œd+d.gd/d0d1œd+d,gd/d2d1œd3œd4d5d6d7œd4d5d8d7œd9œd5d:d;d<d=œid>œZd?d@„ ZG dAdB„ dBeƒZdCdD„ ZG dEdF„ dFƒZdS )Gé    Né   )Ú
dictConfig)Ú
fileConfig)ÚutilÚauthé   Úauthprivé
   Úcroné	   Údaemoné   Úftpé   ÚkernÚlpré   Úmailé   Únewsé   ÚsecurityÚsyslogé   ÚuserÚuucpé   Úlocal0é   Úlocal1é   Úlocal2é   Úlocal3é   é   é   é   é   )Úlocal4Úlocal5Úlocal6Úlocal7FÚINFOÚconsole)ÚlevelÚhandlersÚerror_consoleTúgunicorn.error)r/   r0   Ú	propagateÚqualnameúgunicorn.access)r2   r5   zlogging.StreamHandlerZgenericzext://sys.stdout)ÚclassÚ	formatterÚstreamzext://sys.stderr)r.   r1   ú5%(asctime)s [%(process)d] [%(levelname)s] %(message)sú[%Y-%m-%d %H:%M:%S %z]zlogging.Formatter)ÚformatÚdatefmtr6   )ÚversionÚdisable_existing_loggersÚrootÚloggersr0   Ú
formattersc                  C   s$   t j} t| jj ¡ ƒ}dd„ |D ƒS )z get list of all loggers c                 S   s   g | ]}t  |¡‘qS © )ÚloggingÚ	getLogger)Ú.0ÚnamerB   rB   ú@/var/www/auris/lib/python3.10/site-packages/gunicorn/glogging.pyÚ
<listcomp>\   s    zloggers.<locals>.<listcomp>)rC   r?   ÚlistÚmanagerÚ
loggerDictÚkeys)r?   ÚexistingrB   rB   rG   r@   X   s   r@   c                       s$   e Zd Zdd„ Z‡ fdd„Z‡  ZS )Ú	SafeAtomsc                 C   sD   t  | ¡ | ¡ D ]\}}t|tƒr| dd¡| |< q	|| |< q	d S )Nú"z\")ÚdictÚ__init__ÚitemsÚ
isinstanceÚstrÚreplace)ÚselfÚatomsÚkeyÚvaluerB   rB   rG   rQ   a   s   


üzSafeAtoms.__init__c                    sB   |  d¡r| ¡ }|| v rtƒ  |¡S dS || v rtƒ  |¡S dS )NÚ{ú-)Ú
startswithÚlowerÚsuperÚ__getitem__)rV   ÚkÚkl©Ú	__class__rB   rG   r_   i   s   
zSafeAtoms.__getitem__)Ú__name__Ú
__module__Ú__qualname__rQ   r_   Ú__classcell__rB   rB   rb   rG   rN   _   s    rN   c                 C   sL  |   d¡r)d }|  dd¡}t|ƒdkr |d } |d dkr tj}||  d¡d fS |   d¡r9|  d¡d } tj}n|   d¡rI|  d¡d } tj}ntd	ƒ‚d
| v rcd| v rc|  d¡d dd …  ¡ }nd| v rq|  d¡d  ¡ }n| dkrxd}n|  ¡ }|  d¡d } d| v rž|  dd¡d }| ¡ s™td| ƒ‚t	|ƒ}nd}|||ffS )Nzunix://ú#r   r   r   Zdgramzudp://ztcp://zinvalid syslog addressú[ú]ú:Ú Ú	localhostéÿÿÿÿz%r is not a valid port number.i  )
r\   ÚsplitÚlenÚsocketÚ
SOCK_DGRAMÚSOCK_STREAMÚRuntimeErrorr]   ÚisdigitÚint)ÚaddrZ	sock_typeÚpartsÚsocktypeÚhostÚportrB   rB   rG   Úparse_syslog_addressv   s<   



r|   c                   @   sÒ   e Zd ZejejejejejdœZ	ejZ
dZdZdZdZeZdd„ Zdd	„ Zd
d„ Zdd„ Zdd„ Zdd„ Zdd„ Zdd„ Zdd„ Zdd„ Zdd„ Zdd„ Zdd„ Zd d!„ Zd"d#„ Zd+d%d&„Z d'd(„ Z!d)d*„ Z"d$S ),ÚLogger)ÚcriticalÚerrorÚwarningÚinfoÚdebugr9   r:   z%(message)sz[%(process)d] %(message)sc                 C   sX   t  d¡| _d| j_t  d¡| _d| j_g | _g | _d | _t 	¡ | _
|| _|  |¡ d S )Nr2   Fr5   )rC   rD   Ú	error_logr3   Ú
access_logZerror_handlersZaccess_handlersÚlogfileÚ	threadingÚLockÚlockÚcfgÚsetup)rV   r‰   rB   rB   rG   rQ   ·   s   
zLogger.__init__c                 C   sP  | j  |j ¡ tj¡| _| j | j¡ | j tj¡ | j	j
rO|jdkrOtjtjfD ]}| ¡  q)t|jdƒ| _t | j ¡ tj ¡ ¡ t | j ¡ tj ¡ ¡ |  | j|jt | j| j¡¡ |jd urs| j| j|jt | j¡tjd |jr|  | j|| jd¡ |js|  | j|| jd¡ |jr¸t  !¡ }| "|j¡ zt#|ƒ W d S  t$t%t&t'fy· } zt(t)|ƒƒ‚d }~ww |j*rõt  !¡ }tj+ ,|j*¡rózt- .t|j*ƒ¡}| "|¡ t#|ƒ W d S  t-j/t$t%t&t'fyò } zt(t)|ƒƒ‚d }~ww d S |j0r&tj+ ,|j0¡rt  !¡ }|j0|d< tj+ 1|j0¡|d< t2|j0|dd	 d S d
}t(||j0 ƒ‚d S )Nr[   úa+)Úfmtr8   r   ÚaccessÚ__file__ÚhereF)Údefaultsr>   z Error: log config '%s' not found)3Ú
LOG_LEVELSÚgetÚloglevelr]   rC   r-   rƒ   ÚsetLevelr„   r‰   Úcapture_outputÚerrorlogÚsysÚstdoutÚstderrÚflushÚopenr…   ÚosÚdup2ÚfilenoÚ_set_handlerÚ	FormatterÚ	error_fmtr<   Ú	accesslogÚ
access_fmtr   Ú_set_syslog_handlerÚ
syslog_fmtÚ!disable_redirect_access_to_syslogÚlogconfig_dictÚCONFIG_DEFAULTSÚcopyÚupdater   ÚAttributeErrorÚImportErrorÚ
ValueErrorÚ	TypeErrorrt   rT   Úlogconfig_jsonÚpathÚexistsÚjsonÚloadÚJSONDecodeErrorÚ	logconfigÚdirnamer   )rV   r‰   r8   ÚconfigÚexcZconfig_jsonr   ÚmsgrB   rB   rG   rŠ   Ã   sˆ   
ÿ
þÿÿü€ú
û€ùû

ÿ÷zLogger.setupc                 O   ó   | j j|g|¢R i |¤Ž d S ©N)rƒ   r~   ©rV   r¹   ÚargsÚkwargsrB   rB   rG   r~     ó   zLogger.criticalc                 O   rº   r»   )rƒ   r   r¼   rB   rB   rG   r     r¿   zLogger.errorc                 O   rº   r»   )rƒ   r€   r¼   rB   rB   rG   r€     r¿   zLogger.warningc                 O   rº   r»   )rƒ   r   r¼   rB   rB   rG   r     r¿   zLogger.infoc                 O   rº   r»   )rƒ   r‚   r¼   rB   rB   rG   r‚     r¿   zLogger.debugc                 O   rº   r»   )rƒ   Ú	exceptionr¼   rB   rB   rG   rÀ     r¿   zLogger.exceptionc                 O   s>   t |tƒr| j | ¡ tj¡}| jj||g|¢R i |¤Ž d S r»   )	rS   rT   r‘   r’   r]   rC   r-   rƒ   Úlog)rV   Zlvlr¹   r½   r¾   rB   rB   rG   rÁ     s   
 z
Logger.logc           
      C   sÈ  |j }t|tƒr| dd¡d }i d| dd¡“dd“d|  |¡p"d“d	|  ¡ “d
d|d |d |d f “d|“d| d¡“d| d¡“d| d¡“d| d¡“dt|ddƒdur_t|jƒp`d“dt|ddƒ“d| dd¡“d| dd¡“d|j	“d|j	d |j
 “d |j	d! t|j
d! ƒ “d"|j	|j
f d#t ¡  d$œ¥}t|d%ƒr©|j}n|}t|d&ƒr´| ¡ }| d'd(„ |D ƒ¡ |j}t|d&ƒrÊ| ¡ }| d)d(„ |D ƒ¡ | ¡ }	| d*d(„ |	D ƒ¡ |S )+z( Gets atoms for log formatting.
        Nr   r   ÚhZREMOTE_ADDRr[   ÚlÚuÚtÚrz%s %s %sÚREQUEST_METHODZRAW_URIZSERVER_PROTOCOLÚsÚmÚUZ	PATH_INFOÚqZQUERY_STRINGÚHÚbÚsentÚBÚfZHTTP_REFERERÚaZHTTP_USER_AGENTÚTÚDi@B ÚMiè  z%d.%06dz<%s>)ÚLÚpÚheadersrR   c                 S   ó   i | ]\}}d |  ¡  |“qS )z{%s}i©r]   ©rE   r`   ÚvrB   rB   rG   Ú
<dictcomp>I  ó    z Logger.atoms.<locals>.<dictcomp>c                 S   rØ   )z{%s}orÙ   rÚ   rB   rB   rG   rÜ   P  rÝ   c                 S   rØ   )z{%s}erÙ   rÚ   rB   rB   rG   rÜ   T  rÝ   )ÚstatusrS   rT   ro   r’   Ú	_get_userÚnowÚgetattrrÎ   ÚsecondsÚmicrosecondsrv   rœ   ÚgetpidÚhasattrr×   rR   rª   )
rV   ÚrespÚreqÚenvironÚrequest_timerÞ   rW   Zreq_headersZresp_headersZenviron_variablesrB   rB   rG   rW   "  sr   
ÿþýü
þûø
	÷

ö
õ
ôóòñðïîí
ë


zLogger.atomsc                 C   s†   | j js| j js| j js| j js| j jr| j jrdS |  |  ||||¡¡}z| j	 
| j j|¡ W dS  tyB   |  t ¡ ¡ Y dS w )z\ See http://httpd.apache.org/docs/2.0/logs.html#combined
        for format details
        N)r‰   r¢   rµ   r§   r¯   r   r¦   Úatoms_wrapper_classrW   r„   r   Zaccess_log_formatÚ	Exceptionr   Ú	tracebackÚ
format_exc)rV   ræ   rç   rè   ré   Z
safe_atomsrB   rB   rG   r   X  s$   ÿÿþþÿÿzLogger.accessc                 C   s
   t  d¡S )z) return date in Apache Common Log Format z[%d/%b/%Y:%H:%M:%S %z])ÚtimeÚstrftime)rV   rB   rB   rG   rà   n  s   
z
Logger.nowc              
   C   s  | j jrT| j jdkrTtjtjfD ]}| ¡  q| j2 | jd ur%| j 	¡  t
| j jdƒ| _t | j ¡ tj ¡ ¡ t | j ¡ tj ¡ ¡ W d   ƒ n1 sOw   Y  tƒ D ]*}|jD ]$}t|tjƒr€| ¡  z|jru| 	¡  | ¡ |_W | ¡  q\| ¡  w q\qWd S )Nr[   r‹   )r‰   r•   r–   r—   r˜   r™   rš   rˆ   r…   Úcloser›   rœ   r   rž   r@   r0   rS   rC   ÚFileHandlerÚacquirer8   Ú_openÚrelease)rV   r8   rÁ   ÚhandlerrB   rB   rG   Úreopen_filesr  s.   


û


€ùÿÿzLogger.reopen_filesc              
   C   s^   t ƒ D ])}|jD ]#}t|tjƒr+| ¡  z|jr t |j 	¡ ¡ W | 
¡  q| 
¡  w qqd S r»   )r@   r0   rS   rC   rñ   rò   r8   r   Úclose_on_execrž   rô   )rV   rÁ   rõ   rB   rB   rG   r÷   ‰  s   

€úÿÿzLogger.close_on_execc                 C   s$   |j D ]}t|ddƒr|  S qd S )NÚ	_gunicornF)r0   rá   )rV   rÁ   rÂ   rB   rB   rG   Ú_get_gunicorn_handler”  s
   
ÿÿzLogger._get_gunicorn_handlerNc                 C   sœ   |   |¡}|r|j |¡ |d urL|dkrt |¡}n"t |¡ t |¡}zt 	|j
| jj| jj¡ W n	 ty<   Y nw | |¡ d|_| |¡ d S d S )Nr[   T)rù   r0   ÚremoverC   ÚStreamHandlerr   Zcheck_is_writablerñ   rœ   ÚchownÚbaseFilenamer‰   r   ÚgroupÚOSErrorÚsetFormatterrø   Ú
addHandler)rV   rÁ   ÚoutputrŒ   r8   rÂ   rB   rB   rG   rŸ   ™  s"   


ý
ðzLogger._set_handlerc           
      C   sš   |j p	|j dd¡}d||f }t d||f ¡}z	t|j ¡  }W n ty-   t	dƒ‚w t
|jƒ\}}tjj|||d}	|	 |¡ d|	_| |	¡ d S )Nrk   Ú.zgunicorn.%s.%sz%s: %szunknown facility name)ÚaddressÚfacilityry   T)Zsyslog_prefixZ	proc_namerU   rC   r    ÚSYSLOG_FACILITIESZsyslog_facilityr]   ÚKeyErrorrt   r|   Zsyslog_addrr0   ÚSysLogHandlerr   rø   r  )
rV   rÁ   r‰   rŒ   rF   Úprefixr  ry   rw   rÂ   rB   rB   rG   r¤   ±  s   ÿÿ
zLogger._set_syslog_handlerc              
   C   s¬   d }|  d¡}|rT| ¡  d¡rT| dd¡}t|ƒdkrTzt |d  ¡  d¡¡}| dd¡d  	d	¡}W |S  t
tjtfyS } z|  d
|¡ W Y d }~|S d }~ww |S )NZHTTP_AUTHORIZATIONÚbasicú r   r   zutf-8ó   :r   zUTF-8zCouldn't get username: %s)r’   r]   r\   ro   rp   Úbase64Ú	b64decodeÚstripÚencodeÚdecoder®   ÚbinasciiÚErrorÚUnicodeDecodeErrorr‚   )rV   rè   r   Z	http_authr   r¸   rB   rB   rG   rß   Ë  s   
þ€þzLogger._get_userr»   )#rd   re   rf   rC   ÚCRITICALÚERRORÚWARNINGr-   ÚDEBUGr‘   r“   r¡   r<   r£   r¥   rN   rê   rQ   rŠ   r~   r   r€   r   r‚   rÀ   rÁ   rW   r   rà   rö   r÷   rù   rŸ   r¤   rß   rB   rB   rB   rG   r}   ¤   s>    ûH6
r}   )r  r  r²   rî   rC   r}   rJ   ÚemittedNoHandlerWarningÚlogging.configr   r   rœ   rq   r—   r†   rì   Zgunicornr   r  r¨   r@   rP   rN   r|   rB   rB   rB   rG   Ú<module>   s°   
ÿþýüûúùø	÷
öõôóòñðïë
üüøýýúýÿá).