404

[ Avaa Bypassed ]




Upload:

Command:

elspacio@13.59.50.105: ~ $
3

گa�:�@s�dZddlZddlZddlZddlZddlZddlZddlZddlm	Z	ddl
mZddl
mZddl
m
Z
ddl
mZddl
mZdd	lmZdd
lmZddlmZddlmZdd
lmZddlmZdZdZeje�Zdd�dd�Zej dd�dd�Z!ej e"e"eej#e"fd�dd�Z$Gdd�dej%�Z&Gdd�dej'j(�Z(Gdd�dej%�Z)e(eedd �d!d"�Z*ee+e+e	e,e,e"dd#�d$d%�Z-e"dd&�d'd(�Z.dS))a�Logging utilities for Certbot.

The best way to use this module is through `pre_arg_parse_setup` and
`post_arg_parse_setup`. `pre_arg_parse_setup` configures a minimal
terminal logger and ensures a detailed log is written to a secure
temporary file if Certbot exits before `post_arg_parse_setup` is called.
`post_arg_parse_setup` relies on the parsed command line arguments and
does the full logging setup with terminal and rotating file handling as
configured by the user. Any logged messages before
`post_arg_parse_setup` is called are sent to the rotating file handler.
Special care is taken by both methods to ensure all errors are logged
and properly flushed before program exit.

The `logging` module is useful for recording messages about about what
Certbot is doing under the hood, but do not necessarily need to be shown
to the user on the terminal. The default verbosity is WARNING.

The preferred method to display important information to the user is to
use `certbot.display.util` and `certbot.display.ops`.

�N)�
TracebackType)�Any)�IO)�Optional)�Tuple)�Type)�messages)�
configuration)�errors)�util)�	constants)�osz%(message)sz.%(asctime)s:%(levelname)s:%(name)s:%(message)s)�returncCs�t�}|jtjt��|jtj�t|�}t�}|jtjt	��|jt
j�tj�}|jtj�|j
|�|j
|�tjtj�tjt|dtjkdtjkp�dtjk|jd�t_dS)a�Setup logging before command line arguments are parsed.

    Terminal logging is setup using
    `certbot._internal.constants.QUIET_LOGGING_LEVEL` so Certbot is as quiet as
    possible. File logging is setup so that logging messages are
    buffered in memory. If Certbot exits before `post_arg_parse_setup`
    is called, these buffered messages are written to a temporary file.
    If Certbot doesn't exit, `post_arg_parse_setup` writes the messages
    to the normal log files.

    This function also sets `logging.shutdown` to be called on program
    exit which automatically flushes logging handlers and
    `sys.excepthook` to properly log/display fatal exceptions.

    z--debugz--quietz-q)�debug�quiet�log_pathN)�TempHandler�setFormatter�logging�	Formatter�FILE_FMT�setLevel�DEBUG�
MemoryHandler�ColoredStreamHandler�CLI_FMTr�QUIET_LOGGING_LEVEL�	getLogger�
addHandlerrZatexit_registerZshutdown�	functools�partial�pre_arg_parse_except_hook�sys�argv�path�
excepthook)�temp_handler�memory_handlerZstream_handler�root_logger�r)�/usr/lib/python3.6/log.py�pre_arg_parse_setup5s"

r+)�configrc
Cs@t|dt�\}}tj�}d}}x,|jD]"}t|t�r<|}q(t|t�r(|}q(Wd}|dk	rb|dk	sjt|��|j	|�|j
|�t|dd�}|j|�|j
dd�|j�|r�|j�|jr�tj}	n0|jdk	r�tjt|j�d}	ntj|jd}	|j|	�tjd|	�|j�s$td	|��tjd
�tjt|j|j|d�t_dS)a�Setup logging after command line arguments are parsed.

    This function assumes `pre_arg_parse_setup` was called earlier and
    the root logging configuration has not been modified. A rotating
    file logging handler is created and the buffered log messages are
    sent to that handler. Terminal logging output is set to the level
    requested by the user.

    :param certbot.configuration.NamespaceConfig config: Configuration object

    zletsencrypt.logNz9Previously configured logging handlers have been removed!�targetT)�force�
zRoot logging level set at %dzSaving debug log to )�file)rrr) �setup_log_file_handlerrrr�handlers�
isinstancerr�AssertionErrorrZ
removeHandler�getattrZ	setTarget�flush�closerrrZ
verbose_levelZDEFAULT_LOGGING_LEVEL�intZ
verbose_countr�loggerr�printr"�stderrrr �post_arg_parse_except_hookr%)
r,Zfile_handlerZ	file_pathr(r'Zstderr_handler�handler�msgr&�levelr)r)r*�post_arg_parse_setup]s>






r@)r,�logfile�fmtrcCs�tj|jd|j�tjj|j|�}ytjj	|d|j
d�}Wn4tk
rn}ztj
tjj|���WYdd}~XnX|j�|jtj�tj|d�}|j|�||fS)aSetup file debug logging.

    :param certbot.configuration.NamespaceConfig config: Configuration object
    :param str logfile: basename for the log file
    :param str fmt: logging format string

    :returns: file handler and absolute path to the log file
    :rtype: tuple

    i���)ZmaxBytesZbackupCountN)rBi)rZset_up_core_dirZlogs_dirZstrict_permissionsr
r$�joinrr2ZRotatingFileHandlerZmax_log_backups�IOErrorr
�ErrorZPERM_ERR_FMT�formatZ
doRolloverrrrr)r,rArBZ
log_file_pathr=�errorZhandler_formatterr)r)r*r1�s$
r1csDeZdZdZd	eedd��fdd�
Zeje	d��fdd�Z
�ZS)
ra6Sends colored logging output to a stream.

    If the specified stream is not a tty, the class works like the
    standard `logging.StreamHandler`. Default red_level is
    `logging.WARNING`.

    :ivar bool colored: True if output should be colored
    :ivar bool red_level: The level at which to output

    N)�streamrcs4t�j|�|dkrtjj�n|j�|_tj|_dS)N)	�super�__init__r"r;�isatty�coloredrZWARNING�	red_level)�selfrJ)�	__class__r)r*rL�s
zColoredStreamHandler.__init__)�recordrcs6t�j|�}|jr2|j|jkr2djtj|tjf�S|S)z�Formats the string representation of record.

        :param logging.LogRecord record: Record to be formatted

        :returns: Formatted, string representation of record
        :rtype: str

        �)	rKrHrNZlevelnorOrErZANSI_SGR_REDZANSI_SGR_RESET)rPrR�out)rQr)r*rH�s	zColoredStreamHandler.format)N)�__name__�
__module__�__qualname__�__doc__rrrLr�	LogRecord�strrH�
__classcell__r)r))rQr*r�s
rcsleZdZdZdeejedd��fdd�
Zdd��fdd	�Z	de
dd��fdd
�
Zeje
d�dd�Z
�ZS)rz�Buffers logging messages in memory until the buffer is flushed.

    This differs from `logging.handlers.MemoryHandler` in that flushing
    only happens when flush(force=True) is called.

    N�')r-�capacityrcst�j||d�dS)N)r-)rKrL)rPr-r])rQr)r*rL�szMemoryHandler.__init__)rcst|d�}t�j�||_dS)z;Close the memory handler, but don't set the target to None.r-N)r5rKr7r-)rPr-)rQr)r*r7�s

zMemoryHandler.closeF)r.rcs|rt�j�dS)z�Flush the buffer if force=True.

        If force=False, this call is a noop.

        :param bool force: True if the buffer should be flushed.

        N)rKr6)rPr.)rQr)r*r6�s
zMemoryHandler.flush)rRrcCsdS)z�Should the buffer be automatically flushed?

        :param logging.LogRecord record: log record to be considered

        :returns: False because the buffer should never be auto-flushed
        :rtype: bool

        Fr))rPrRr)r)r*�shouldFlush�s	zMemoryHandler.shouldFlush)Nr\)F)rUrVrWrXrr�Handlerr8rLr7�boolr6rYr^r[r)r))rQr*r�s
rcsNeZdZdZdd��fdd�Zejdd��fdd�Zdd��fd	d
�Z�Z	S)raSafely logs messages to a temporary file.

    The file is created with permissions 600. If no log records are sent
    to this handler, the temporary file is deleted when the handler is
    closed.

    :ivar str path: file system path to the temporary log file

    N)rcsHtj�|_tjj|jd�|_tj|jddd�}t�j	|�|d|_
dS)N�log�wi�)�mode�chmodT)�tempfileZmkdtemp�_workdirr
r$rErZ	safe_openrKrL�_delete)rPrJ)rQr)r*rLs
zTempHandler.__init__)rRrcsd|_t�j|�dS)zlLog the specified logging record.

        :param logging.LogRecord record: Record to be formatted

        FN)rgrK�emit)rPrR)rQr)r*rhszTempHandler.emitc
sH|j�z0|jj�|jr&tj|j�d|_t�j�Wd|j�XdS)zuClose the handler and the temporary log file.

        The temporary log file is deleted if it wasn't used.

        FN)	�acquirerJr7rg�shutilZrmtreerfrK�release)rP)rQr)r*r7s
zTempHandler.close)
rUrVrWrXrLrrYrhr7r[r)r))rQr*r�s	
	r)r'�args�kwargsrcOs"zt||�Wd|jdd�XdS)aA simple wrapper around post_arg_parse_except_hook.

    The additional functionality provided by this wrapper is the memory
    handler will be flushed before Certbot exits. This allows us to
    write logging messages to a temporary file if we crashed before
    logging was fully configured.

    Since sys.excepthook isn't called on SystemExit exceptions, the
    memory handler will not be flushed in this case which prevents us
    from creating temporary log files when argparse exits because a
    command line argument was invalid or -h, --help, or --version was
    provided on the command line.

    :param MemoryHandler memory_handler: memory handler to flush
    :param tuple args: args for post_arg_parse_except_hook
    :param dict kwargs: kwargs for post_arg_parse_except_hook

    NT)r.)r<r6)r'rlrmr)r)r*r!.sr!)�exc_type�	exc_value�tracerrrrcs�|||f}��fdd�}|s(t|t�rdtjtjks8t�|tkrTtj	d�t
jd�tj	d|d�n�tjd|d�t|t
j�r�tj	t|��|�tj	d�tj|�r�t|�jd�\}}}	tj	|	�n tj||�}
tj	d	j|
�j��|�d
S)aaLogs fatal exceptions and reports them to the user.

    If debug is True, the full exception and traceback is shown to the
    user, otherwise, it is suppressed. sys.exit is always called with a
    nonzero status.

    :param type exc_type: type of the raised exception
    :param BaseException exc_value: raised exception
    :param traceback trace: traceback of where the exception was raised
    :param bool debug: True if the traceback should be shown to the user
    :param bool quiet: True if Certbot is running in quiet mode
    :param str log_path: path to file or directory containing the log

    cs�rtjd�St��S)N�)r"�exit�exit_with_advicer))rrr)r*�<lambda>]sz,post_arg_parse_except_hook.<locals>.<lambda>zExiting due to user request.rqzExiting abnormally:)�exc_infozAn unexpected error occurred:z:: rSN)�
issubclass�	ExceptionrrrZERRORr4�KeyboardInterruptr9rIr"rrrr
rGrZrZ
is_acme_error�	partition�	traceback�format_exception_onlyrE�rstrip)rnrorprrrruZ	exit_func�_Zexc_str�outputr))rrr*r<Js&




r<)rrcCsHd}tjj|�r"|d|�d�7}n|d|�d�7}|d7}tj|�dS)z�Print a link to the community forums, the debug log path, and exit

    The message is printed to stderr and the program will exit with a
    nonzero status.

    :param str log_path: path to file or directory containing the log

    zSAsk for help or search for solutions at https://community.letsencrypt.org. See the zlogfiles in � zlogfile z+or re-run Certbot with -v for more details.N)r
r$�isdirr"rr)rr>r)r)r*rs}s	rs)/rXrrZlogging.handlersrjr"rerz�typesrZtypingrrrrrZacmerZcertbotr	r
rZcertbot._internalrZcertbot.compatr
rrrrUr9r+ZNamespaceConfigr@rZr_r1Z
StreamHandlerrr2rrr!�
BaseExceptionr`r<rsr)r)r)r*�<module>sF
(4 -01

Filemanager

Name Type Size Permission Actions
__init__.cpython-36.opt-1.pyc File 302 B 0644
__init__.cpython-36.pyc File 302 B 0644
account.cpython-36.opt-1.pyc File 13.29 KB 0644
account.cpython-36.pyc File 13.29 KB 0644
auth_handler.cpython-36.opt-1.pyc File 16.2 KB 0644
auth_handler.cpython-36.pyc File 16.29 KB 0644
cert_manager.cpython-36.opt-1.pyc File 14.98 KB 0644
cert_manager.cpython-36.pyc File 14.98 KB 0644
client.cpython-36.opt-1.pyc File 25.25 KB 0644
client.cpython-36.pyc File 25.25 KB 0644
constants.cpython-36.opt-1.pyc File 3.98 KB 0644
constants.cpython-36.pyc File 3.98 KB 0644
eff.cpython-36.opt-1.pyc File 4.45 KB 0644
eff.cpython-36.pyc File 4.45 KB 0644
error_handler.cpython-36.opt-1.pyc File 5.8 KB 0644
error_handler.cpython-36.pyc File 5.8 KB 0644
hooks.cpython-36.opt-1.pyc File 8.34 KB 0644
hooks.cpython-36.pyc File 8.34 KB 0644
lock.cpython-36.opt-1.pyc File 8.77 KB 0644
lock.cpython-36.pyc File 8.77 KB 0644
log.cpython-36.opt-1.pyc File 12.77 KB 0644
log.cpython-36.pyc File 12.85 KB 0644
main.cpython-36.opt-1.pyc File 43.5 KB 0644
main.cpython-36.pyc File 43.69 KB 0644
renewal.cpython-36.opt-1.pyc File 15.53 KB 0644
renewal.cpython-36.pyc File 15.53 KB 0644
reporter.cpython-36.opt-1.pyc File 2.85 KB 0644
reporter.cpython-36.pyc File 2.91 KB 0644
snap_config.cpython-36.opt-1.pyc File 4.04 KB 0644
snap_config.cpython-36.pyc File 4.04 KB 0644
storage.cpython-36.opt-1.pyc File 38.5 KB 0644
storage.cpython-36.pyc File 38.5 KB 0644
updater.cpython-36.opt-1.pyc File 4.18 KB 0644
updater.cpython-36.pyc File 4.18 KB 0644