Your IP : 216.73.217.13


Current Path : /lib/python3/dist-packages/cloudinit/reporting/__pycache__/
Upload File :
Current File : //lib/python3/dist-packages/cloudinit/reporting/__pycache__/events.cpython-38.pyc

U

�Ad�#�@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)�ReportingHandlerZfinish�startZ	cloudinitc@seZdZdd�ZdS)�_namesetcCs||kr|Std|��dS)Nz%s not a valid value)�AttributeError)�self�name�r�</usr/lib/python3/dist-packages/cloudinit/reporting/events.py�__getattr__sz_nameset.__getattr__N)�__name__�
__module__�__qualname__r
rrrrrsr)�SUCCESS�WARN�FAILc@s.eZdZdZedfdd�Zdd�Zdd�ZdS)	�ReportingEventz"Encapsulation of event formatting.NcCs2||_||_||_||_|dkr(t��}||_dS�N)�
event_typer
�description�origin�time�	timestamp)r	rr
rrrrrr�__init__)szReportingEvent.__init__cCsd�|j|j|j�S)z"The event represented as a string.z
{0}: {1}: {2})�formatrr
r�r	rrr�	as_string9s
�zReportingEvent.as_stringcCs|j|j|j|j|jd�S)z&The event represented as a dictionary.�r
rrrrrrrrr�as_dict?s�zReportingEvent.as_dict)rrr�__doc__�DEFAULT_EVENT_ORIGINrrr rrrrr&s�
rcs8eZdZejdf�fdd�	Zdd�Z�fdd�Z�ZS)�FinishReportingEventNcsDtt|��t||�||_|dkr&g}||_|tkr@td|��dS)NzInvalid result: %s)�superr#r�FINISH_EVENT_TYPE�result�
post_files�status�
ValueError)r	r
rr&r'��	__class__rrrKs
�zFinishReportingEvent.__init__cCsd�|j|j|j|j�S)Nz{0}: {1}: {2}: {3})rrr
r&rrrrrrXs�zFinishReportingEvent.as_stringcs0tt|���}|j|d<|jr,t|j�|d<|S)z'The event represented as json friendly.r&�files)r$r#r r&r'�_collect_file_info)r	�datar*rrr ]s

zFinishReportingEvent.as_dict)	rrrr(rrrr �
__classcell__rrr*rr#Js
�
r#csT�si��fdd�tj��D�}ttj���}|D]}t|�|krDq2|�|�q2dS)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|]\}}|�kr|�qSrr)�.0Z	hndl_typeZhndl_cls��excluded_handler_typesrr�	<setcomp>vs�zreport_event.<locals>.<setcomp>N)rZregistered_items�items�listr�values�typeZ
publish_event)�eventr2Zexcluded_handler_classesZhandlersZhandlerrr1r�report_eventfs
��r9cCst||||d�}t|�S)zVReport a "finish" event.

    See :py:func:`.report_event` for parameter details.
    �r')r#r9)�
event_name�event_descriptionr&r'r8rrr�report_finish_event�s�r=cCstt||�}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_TYPEr9)r;r<r8rrr�report_start_event�s
r?c@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|_|dkr2g}||_|dkrP|rL|j	}nd}||_	|rnd�
|j|f�|_n|j|_i|_dS)NT�/)
�parentr
r�message�result_on_exceptionr(rr&r'�reporting_enabled�join�fullname�children)r	r
rrCrBrErDr'rrrr�s,
��zReportEventStack.__init__cCsd|j|j|jfS)Nz.ReportEventStack(%s, %s, reporting_enabled=%s))r
rrErrrr�__repr__�s
�zReportEventStack.__repr__cCs4tj|_|jrt|j|j�|jr0d|jj|j	<|S)N)NN)
r(rr&rEr?rGrrBrHr
rrrr�	__enter__�szReportEventStack.__enter__cCsPtjtjfD]6}|j��D]&\}\}}||kr||jfSqq|j|jfSr)r(rrrHr4rCr&)r	Zcand_result�_name�valueZ_msgrrr�_childrens_finish_info�s
z'ReportEventStack._childrens_finish_infocCs|jSr)�_resultrrrrr&szReportEventStack.resultcCs|tkrtd|��||_dS)Nz'%s' not a valid result)r(r)rN�r	rLrrrr&scCs|jdk	r|jS|jSr)�_messagerrrrrrCs
zReportEventStack.messagecCs
||_dSr)rPrOrrrrCscCs|r|j|jfS|��Sr)rDrCrM)r	�excrrr�_finish_infoszReportEventStack._finish_infocCsD|�|�\}}|jr&||f|jj|j<|jr@t|j|||jd�dS)Nr:)rRrBrHr
rEr=rGr')r	�exc_type�	exc_value�	tracebackr&�msgrrr�__exit__s�zReportEventStack.__exit__)rrrr!r(rrrIrJrM�propertyr&�setterrCrRrWrrrrr@�s(*�
'



r@c
Csf|sdSg}|D]P}tj�|�s&d}n(t|d��}t�|�����}W5QRX|�||dd��q|S)N�rb�base64)�path�content�encoding)	�osr\�isfile�openr[Z	b64encode�read�decode�append)r,Zret�fnamer]�fprrrr-(sr-)N)r!r[�os.pathr_r�typingrZcloudinit.reportingrrZcloudinit.reporting.handlersrr%r>r"�setrr(rr#r9rr=r?r@r-rrrr�<module>s*$
 �