U
    #æÃ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 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dd œddgdd!d œd"œd#d$d%d&œd#d$d'd&œd(œd$d)d*d+d,œid-œZd.d/„ ZG d0d1„ d1eƒZd2d3„ ZG d4d5„ d5ƒZdS )6é    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   ú5/tmp/pip-unpacked-wheel-229l629p/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ƒr6| 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                    sF   |  d¡r*| ¡ }|| kr&tƒ  |¡S dS || kr>tƒ  |¡S d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   sP  |   d¡rRd }|  dd¡}t|ƒdkr@|d } |d dkr@tj}||  d¡d fS |   d¡rr|  d¡d } tj}n(|   d¡r’|  d¡d } tj}ntd	ƒ‚d
| krÆd| krÆ|  d¡d dd …  ¡ }n2d| krâ|  d¡d  ¡ }n| dkrðd}n|  ¡ }|  d¡d } d| kr@|  dd¡d }| ¡ s6t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   sl  | j  |j ¡ tj¡| _| j | j¡ | j tj¡ | j	j
rž|jdkržtjtjfD ]}| ¡  qRt|jdƒ| _t | j ¡ tj ¡ ¡ t | j ¡ tj ¡ ¡ |  | j|jt | j| j¡¡ |jd k	ræ| 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 n8 t$t%t&t'fk
r~ } zt(t)|ƒƒ‚W 5 d }~X Y nX næ|j*rt  !¡ }tj+ ,|j*¡rhz&t- .t|j*ƒ¡}| "|¡ t#|ƒ W n< t-j/t$t%t&t'fk
r } zt(t)|ƒƒ‚W 5 d }~X Y nX n`|j0rhtj+ ,|j0¡rVt  !¡ }|j0|d< tj+ 1|j0¡|d< t2|j0|dd	 n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   s   | j j|f|ž|Ž d S ©N)rƒ   r~   ©rV   r¹   ÚargsÚkwargsrB   rB   rG   r~     s    zLogger.criticalc                 O   s   | j j|f|ž|Ž d S rº   )rƒ   r   r»   rB   rB   rG   r     s    zLogger.errorc                 O   s   | j j|f|ž|Ž d S rº   )rƒ   r€   r»   rB   rB   rG   r€     s    zLogger.warningc                 O   s   | j j|f|ž|Ž d S rº   )rƒ   r   r»   rB   rB   rG   r     s    zLogger.infoc                 O   s   | j j|f|ž|Ž d S rº   )rƒ   r‚   r»   rB   rB   rG   r‚     s    zLogger.debugc                 O   s   | j j|f|ž|Ž d S rº   )rƒ   Ú	exceptionr»   rB   rB   rG   r¾     s    zLogger.exceptionc                 O   s8   t |tƒr| j | ¡ tj¡}| jj||f|ž|Ž 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 }| dd¡d|  |¡p8d|  ¡ d|d |d |d	 f || d¡| d
¡| d¡| d	¡t|ddƒdk	r’t|jƒp”dt|ddƒ| dd¡| dd¡|j	|j	d |j
 |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ƒrR| ¡ }| dd„ |D ƒ¡ | ¡ }	| dd„ |	D ƒ¡ |S )z( Gets atoms for log formatting.
        Nr   r   ZREMOTE_ADDRr[   z%s %s %sÚREQUEST_METHODZRAW_URIZSERVER_PROTOCOLZ	PATH_INFOÚQUERY_STRINGÚsentZHTTP_REFERERZHTTP_USER_AGENTi@B iè  z%d.%06dz<%s>)ÚhÚlÚuÚtÚrÚsÚmÚUÚqÚHÚbÚBÚfÚaÚTÚDÚMÚLÚpÚheadersrR   c                 S   s   i | ]\}}d |  ¡  |“qS )z{%s}i©r]   ©rE   r`   ÚvrB   rB   rG   Ú
<dictcomp>I  s     
 z Logger.atoms.<locals>.<dictcomp>c                 S   s   i | ]\}}d |  ¡  |“qS )z{%s}or×   rØ   rB   rB   rG   rÚ   P  s     
 c                 S   s   i | ]\}}d |  ¡  |“qS )z{%s}er×   rØ   rB   rB   rG   rÚ   T  s     
 )Ú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   "  sN    

þ



ëzLogger.atomsc                 C   sˆ   | j js4| j js4| j js4| j js4| j jr0| j jr4dS |  |  ||||¡¡}z| j	 
| j j|¡ W n" tk
r‚   |  t ¡ ¡ Y nX dS )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r”| j jdkr”tjtjfD ]}| ¡  q | jZ | jd k	rJ| j 	¡  t
| j jdƒ| _t | j ¡ tj ¡ ¡ t | j ¡ tj ¡ ¡ W 5 Q R X tƒ D ]L}|jD ]@}t|tjƒr¤| ¡  z|jrÖ| 	¡  | ¡ |_W 5 | ¡  X q¤qšd S )Nr[   r‹   )r‰   r•   r–   r—   r˜   r™   rš   rˆ   r…   Úcloser›   rœ   r   rž   r@   r0   rS   rC   ÚFileHandlerÚacquireÚreleaser8   Ú_open)rV   r8   r¿   ÚhandlerrB   rB   rG   Úreopen_filesr  s$    


"

zLogger.reopen_filesc              
   C   sV   t ƒ D ]J}|jD ]>}t|tjƒr| ¡  z|jr@t 	|j 
¡ ¡ W 5 | ¡  X qqd S rº   )r@   r0   rS   rC   rî   rï   rð   r8   r   Úclose_on_execrž   )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 k	r–|dkr6t |¡}nFt |¡ t |¡}zt 	|j
| jj| jj¡ W n tk
rz   Y nX | |¡ d|_| |¡ 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k
r`   t	dƒ‚Y nX 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¡}|r¢| ¡  d¡r¢| dd¡}t|ƒdkr¢z2t |d  ¡  d¡¡}| dd¡d  	d	¡}W n6 t
tjtfk
r  } z|  d
|¡ W 5 d }~X Y nX |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_user)N)#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Š   
ë
üüøýýúýÿá).