File: //opt/imunify360/venv/lib/python3.11/site-packages/Crypto/Cipher/__pycache__/DES3.cpython-311.pyc
�
   h�8�l�/b�                   �   � d Z ddlZddlmZ ddlmZmZmZmZ ddl	m
Z
mZmZm
Z
  e
dd�  �        Zd� Zd	� Zd
� ZdZdZd
ZdZdZdZdZdZdZdS )a�  
Module's constants for the modes of operation supported with Triple DES:
:var MODE_ECB: :ref:`Electronic Code Book (ECB) <ecb_mode>`
:var MODE_CBC: :ref:`Cipher-Block Chaining (CBC) <cbc_mode>`
:var MODE_CFB: :ref:`Cipher FeedBack (CFB) <cfb_mode>`
:var MODE_OFB: :ref:`Output FeedBack (OFB) <ofb_mode>`
:var MODE_CTR: :ref:`CounTer Mode (CTR) <ctr_mode>`
:var MODE_OPENPGP:  :ref:`OpenPGP Mode <openpgp_mode>`
:var MODE_EAX: :ref:`EAX Mode <eax_mode>`
�    N)�_create_cipher)�byte_string�bchr�bord�bstr)�load_pycryptodome_raw_lib�VoidPointer�SmartPointer�c_size_tzCrypto.Cipher._raw_des3a�  
                    int DES3_start_operation(const uint8_t key[],
                                             size_t key_len,
                                             void **pResult);
                    int DES3_encrypt(const void *state,
                                     const uint8_t *in,
                                     uint8_t *out,
                                     size_t data_len);
                    int DES3_decrypt(const void *state,
                                     const uint8_t *in,
                                     uint8_t *out,
                                     size_t data_len);
                    int DES3_stop_operation(void *state);
                    c                 �  �� d� �t          | �  �        t          vrt          d�  �        �d�                    �fd�| D �   �         �  �        }|dd�         |dd�         k    s|dd	�         |d	d�         k    rt          d
�  �        �|S )am  Set the parity bits in a TDES key.
    :param key_in: the TDES key whose bits need to be adjusted
    :type key_in: byte string
    :returns: a copy of ``key_in``, with the parity bits correctly set
    :rtype: byte string
    :raises ValueError: if the TDES key is not 16 or 24 bytes long
    :raises ValueError: if the TDES key degenerates into Single DES
    c                 �R   � d}t          dd�  �        D ]
}|| |z	  dz  z  }�| dz  |z  S )N�   �   �   )�range)�key_byte�parity�is      ��/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/Cipher/DES3.py�parity_bytez&adjust_key_parity.<locals>.parity_byteI   sB   � ����q�!��� 	*� 	*�A��x�1�}��)�)�F�F��4��6�)�)�    zNot a valid TDES keyr   c           	      �Z   �� g | ]'}t           �t          |�  �        �  �        �  �        ��(S � )r   r   )�.0�xr   s     �r   �
<listcomp>z%adjust_key_parity.<locals>.<listcomp>R   s1   �� �E�E�E���k�k�$�q�'�'�2�2�3�3�E�E�Er   Nr   �   i�i����z(Triple DES key degenerates to single DES)�len�key_size�
ValueError�join)�key_in�key_outr   s     @r   �adjust_key_parityr$   <