HEX
Server: Apache
System: Linux scp1.abinfocom.com 5.4.0-216-generic #236-Ubuntu SMP Fri Apr 11 19:53:21 UTC 2025 x86_64
User: confeduphaar (1010)
PHP: 8.1.33
Disabled: exec,passthru,shell_exec,system
Upload Files
File: //proc/self/root/lib/python3/dist-packages/uaclient/__pycache__/event_logger.cpython-38.pyc
U

��JhA �@s�dZddlZddlZddlZddlmZmZmZmZm	Z	m
Z
ddlmZdZ
ee
eeeeffZdadd�ZejGdd	�d	ej��Zeeefeeefd
�dd�ZGd
d�d�ZdS)a$
This module is responsible for handling all events
that must be raised to the user somehow. The main idea
behind this module is to centralize all events that happens
during the execution of Pro commands and allows us to report
those events in real time or through a machine-readable format.
�N)�Any�Dict�List�Optional�Set�Union)�	safe_dumpz0.1cCstdkrt�atS�N)�
_event_logger�EventLogger�rr�7/usr/lib/python3/dist-packages/uaclient/event_logger.py�get_event_loggersrc@s"eZdZdZe�Ze�Ze�ZdS)�EventLoggerModea
    Defines event logger supported modes.
    Currently, we only support the cli and machine-readable mode. On cli mode,
    we will print to stdout/stderr any event that we receive. Otherwise, we
    will store those events and parse them for the specified format.
    N)�__name__�
__module__�__qualname__�__doc__�object�CLI�JSON�YAMLrrrr
rsr)�status�returncCshddlm}dd�t|����D�|d<|�dd�|�dg�|�dg�D]}d	|krL|�d	�qL|S)
Nr)�get_pro_environmentcSsg|]\}}||d��qS))�name�valuer)�.0rrrrr
�
<listcomp>/s�z2format_machine_readable_output.<locals>.<listcomp>Zenvironment_vars�origin��servicesZvariants)�
uaclient.utilr�sorted�items�pop�
setdefault�get)rr�servicerrr
�format_machine_readable_output,s�
r)c
@sBeZdZdd�Zdd�Zed�dd�Zed�d	d
�Ze	d�dd
�Z
d/eeed�dd�Zd0eeee
e	eefeeeeee	eefd�dd�Zd1eeeeeeeee	eefd�dd�Zd2eeed�dd�Zed�dd�Ze
ed�dd �Zed�d!d"�Zed#�d$d%�Zd&d'�Zd(d)�Zd*d+�Zdd,�d-d.�ZdS)3rcCs:g|_g|_t�|_t�|_d|_d|_i|_tj	|_
dS)NFr ��
_error_events�_warning_events�set�_processed_services�_failed_services�
_needs_reboot�_command�_output_contentrr�_event_logger_mode��selfrrr
�__init__FszEventLogger.__init__cCs:g|_g|_t�|_t�|_d|_d|_i|_tj	|_
dS)z/Reset the state of the event logger attributes.Fr Nr*r4rrr
�resetSszEventLogger.reset)�
event_modecCs
||_dS)z_Set the event logger mode.

        We currently support the CLI, JSON and YAML modes.
        N)r3)r5r8rrr
�set_event_mode^szEventLogger.set_event_mode)�commandcCs
||_dS)z�Set the event logger command.

        The command will tell the process_events method which output method
        to use.
        N)r1)r5r:rrr
�set_commandeszEventLogger.set_command)�output_contentcCs
||_dS)z�Set the event logger output content.

        The command will tell the process_events method which content
        to use.
        N)r2)r5r<rrr
�set_output_contentmszEventLogger.set_output_contentN)�info_msg�endcCs(|s
tj}|jtjkr$t|||d�dS)zL
        Print the info message if the event logger is on CLI mode.
        )�filer?N)�sys�stdoutr3rr�print)r5r>Z	file_typer?rrr
�infouszEventLogger.info��msgr(�
event_dict�code�
event_type�additional_infocCs<|dkr|rdnd}||||d�}|r.||d<|�|�dS)Nr(�system)�typer(�messageZmessage_coderJ)�append)r5rFr(rGrHrIrJZevent_entryrrr
�_record_dict_events	�zEventLogger._record_dict_event)�	error_msg�
error_coder(�
error_typerJcCs(|jtjkr$|j|||j|||d�dS)z�
        Store an error in the event logger.

        However, the error will only be stored if the event logger
        is not on CLI mode.
        rEN)r3rrrOr+)r5rPrQr(rRrJrrr
�error�s�zEventLogger.error)�warning_msgr(cCs"|jtjkr|j|||jd�dS)z�
        Store a warning in the event logger.

        However, the warning will only be stored if the event logger
        is not on CLI mode.
        )rFr(rGN)r3rrrOr,)r5rTr(rrr
�warning�s�zEventLogger.warning�r(cCs|j�|�dSr	)r.�add�r5r(rrr
�service_processed�szEventLogger.service_processed)r!cCs|j�|�dSr	)r/�update)r5r!rrr
�services_failed�szEventLogger.services_failedcCs|j�|�dSr	)r/rWrXrrr
�service_failed�szEventLogger.service_failed)�reboot_requiredcCs
||_dSr	)r0)r5r]rrr
�needs_reboot�szEventLogger.needs_rebootcCs"dd�|jD�}tt�|j|��S)NcSsh|]}|dr|d�qSrVr)rrSrrr
�	<setcomp>�s�z8EventLogger._generate_failed_services.<locals>.<setcomp>)r+�listr-�unionr/)r5Zservices_with_errorrrr
�_generate_failed_services�s�z%EventLogger._generate_failed_servicescCsVt|jsdndt|j�t|���|j|j|jd�}ddlm}t	t
j||dd��dS)N�success�failure)Z_schema_version�resultZprocessed_servicesZfailed_services�errors�warningsr^r��DatetimeAwareJSONEncoderT��clsZ	sort_keys)�JSON_SCHEMA_VERSIONr+r#r.rbr,r0r"rirC�json�dumps)r5Zresponserirrr
�_process_events_services�s
�
�z$EventLogger._process_events_servicescCs~t|j�}|jsdnd|d<|j|d<|j|d<|jtjkr^ddlm}t	t
j||dd	��n|jtjkrzt	t
|d
d��dS)NrcrdrerfrgrrhTrjF)Zdefault_flow_style)r)r2r+r,r3rrr"rirCrmrnrr)r5�outputrirrr
�_process_events_status�s


��z"EventLogger._process_events_status)rcCs,|jtjkr(|jdkr |��n|��dS)z�
        Creates a json response based on all of the
        events stored in the event logger.

        The json response will only be created if the event logger
        is not on CLI mode.
        rN)r3rrr1rqror4rrr
�process_events�s

zEventLogger.process_events)NN)NNN)NNNN)N)rrrr6r7rr9�strr;rr=rrDr�EventFieldErrorTyperOrSrUrYr[r\�boolr^rbrorqrrrrrr
rEsJ
����r)r�enumrmrA�typingrrrrrrZ
uaclient.yamlrrlrsrtr
r�unique�Enumrr)rrrrr
�<module>s