File: //opt/imunify360/venv/lib64/python3.11/site-packages/Crypto/Hash/__pycache__/SHA224.cpython-311.pyc
�
   ��L;C�W�                   �   � d dl mZ d dlmZmZmZmZmZmZm	Z	  edd�  �        Z
 G d� de�  �        Zd
d�Z
ej        Zej        Zd	� ZdS )�    ��bord)�load_pycryptodome_raw_lib�VoidPointer�SmartPointer�create_string_buffer�get_raw_buffer�c_size_t�c_uint8_ptrzCrypto.Hash._SHA224a�  
                        int SHA224_init(void **shaState);
                        int SHA224_destroy(void *shaState);
                        int SHA224_update(void *hs,
                                          const uint8_t *buf,
                                          size_t len);
                        int SHA224_digest(const void *shaState,
                                          uint8_t *digest,
                                          size_t digest_size);
                        int SHA224_copy(const void *src, void *dst);
                        int SHA224_pbkdf2_hmac_assist(const void *inner,
                                            const void *outer,
                                            const uint8_t *first_digest,
                                            uint8_t *final_digest,
                                            size_t iterations,
                                            size_t digest_size);
                        c                   �F   � e Zd ZdZdZdZdZdd�Zd� Zd� Z	d	� Z
d
� Zdd�ZdS )
�
SHA224Hasha�  A SHA-224 hash object.
    Do not instantiate directly.
    Use the :func:`new` function.
    :ivar oid: ASN.1 Object ID
    :vartype oid: string
    :ivar block_size: the size in bytes of the internal message block,
                      input to the compression function
    :vartype block_size: integer
    :ivar digest_size: the size in bytes of the resulting hash
    :vartype digest_size: integer
    �   �@   z2.16.840.1.101.3.4.2.4Nc                 �6  � t          �   �         }t          �                    |�                    �   �         �  �        }|rt	          d|z  �  �        �t          |�                    �   �         t          j        �  �        | _        |r| �	                    |�  �         d S d S )Nz#Error %d while instantiating SHA224)
r   �_raw_sha224_lib�SHA224_init�
address_of�
ValueErrorr   �get�SHA224_destroy�_state�update)�self�data�state�results       ��/srv/buildsys-work-dir/castor/build_node/builder-0/TMJYY/unpkd_srcs/imunify360-venv-2.6.0/opt/imunify360/venv/lib/python3.11/site-packages/Crypto/Hash/SHA224.py�__init__zSHA224Hash.__init__H   s�   � ��
�
�� �,�,�U�-=�-=�-?�-?�@�@��� 	'��B�%�&� '� '� 
'�"�5�9�9�;�;�#2�#A�C� C���� 	��K�K�������	� 	�    c           	      ��   � t           �                    | j        �                    �   �         t	          |�  �        t          t
          |�  �        �  �        �  �        }|rt          d|z  �  �        �dS )z�Continue hashing of a message by consuming the next chunk of data.
        Args:
            data (byte string/byte array/memoryview): The next chunk of the message being hashed.
        z'Error %d while hashing data with SHA224N)r   �
SHA224_updater   r   r   r
   �lenr   )r   r   r   s      r   r   zSHA224Hash.updateS   sv   � � !�.�.�t�{���/@�/@�/:�4�/@�/@�/7��D�	�	�/B�/B�D� D�� � 	'��F�%�&� '� '� 
'�	'� 	'r   c                 �   � t          | j        �  �        }t          �                    | j        �                    �   �         |t
          | j        �  �        �  �        }|rt          d|z  �  �        �t          |�  �        S )z�Return the **binary** (non-printable) digest of the message that has been hashed so far.
        :return: The hash digest, computed over the data processed so far.
                 Binary form.
        :rtype: byte string
        z#Error %d while making SHA224 digest)	r   �digest_sizer   �
SHA224_digestr   r   r
   r   r	   )r   �bfrr   s      r   �digestzSHA224Hash.digesta   s�   � � #�4�#3�4�4�� �.�.�t�{���/@�/@�/2�/7��8H�/I�/I�K� K�� � 	'��B�%�&� '� '� 
'� �c�"�"�"r   c                 �d   � d�                     d� | �                    �   �         D �   �         �  �        S )z�Return the **printable** digest of the message that has been hashed so far.
        :return: The hash digest, computed over the data processed so far.
                 Hexadecimal encoded.
        :rtype: string
        � c                 �2   � g | ]}d t          |�  �        z  ��S )z%02xr   )�.0�xs     r   �
<listcomp>z(SHA224Hash.hexdigest.<locals>.<listcomp>{   s#   � �@�@�@�Q���a���(�@�@�@r   )�joinr'