HEX
Server: Apache/2.4.52 (Ubuntu)
System: Linux spn-python 5.15.0-89-generic #99-Ubuntu SMP Mon Oct 30 20:42:41 UTC 2023 x86_64
User: arjun (1000)
PHP: 8.1.2-1ubuntu2.20
Disabled: NONE
Upload Files
File: //home/arjun/projects/env/lib/python3.10/site-packages/Crypto/IO/__pycache__/PKCS8.cpython-310.pyc
o

wen#�@s`ddlTddlmZmZmZmZddlmZmZm	Z	ddgZ
ddde�dfdd�Zd	dd�ZdS)
�)�*)�DerNull�DerSequence�DerObjectId�DerOctetString)�PBES1�PBES2�	PbesError�wrap�unwrapNc
Cs�|durtt|�g�}ntt|�|g�}td|t|�g�}|��}	|dur'|	S|s-td��t|�}|dur7d}t�|	||||�S)a/Wrap a private key into a PKCS#8 blob (clear or encrypted).

    Args:

      private_key (byte string):
        The private key encoded in binary form. The actual encoding is
        algorithm specific. In most cases, it is DER.

      key_oid (string):
        The object identifier (OID) of the private key to wrap.
        It is a dotted string, like ``1.2.840.113549.1.1.1`` (for RSA keys).

      passphrase (bytes string or string):
        The secret passphrase from which the wrapping key is derived.
        Set it only if encryption is required.

      protection (string):
        The identifier of the algorithm to use for securely wrapping the key.
        The default value is ``PBKDF2WithHMAC-SHA1AndDES-EDE3-CBC``.

      prot_params (dictionary):
        Parameters for the protection algorithm.

        +------------------+-----------------------------------------------+
        | Key              | Description                                   |
        +==================+===============================================+
        | iteration_count  | The KDF algorithm is repeated several times to|
        |                  | slow down brute force attacks on passwords    |
        |                  | (called *N* or CPU/memory cost in scrypt).    |
        |                  | The default value for PBKDF2 is 1000.         |
        |                  | The default value for scrypt is 16384.        |
        +------------------+-----------------------------------------------+
        | salt_size        | Salt is used to thwart dictionary and rainbow |
        |                  | attacks on passwords. The default value is 8  |
        |                  | bytes.                                        |
        +------------------+-----------------------------------------------+
        | block_size       | *(scrypt only)* Memory-cost (r). The default  |
        |                  | value is 8.                                   |
        +------------------+-----------------------------------------------+
        | parallelization  | *(scrypt only)* CPU-cost (p). The default     |
        |                  | value is 1.                                   |
        +------------------+-----------------------------------------------+

      key_params (DER object or None):
        The ``parameters`` field to use in the ``AlgorithmIdentifier``
        SEQUENCE. If ``None``, no ``parameters`` field will be added.
        By default, the ASN.1 type ``NULL`` is used.

      randfunc (callable):
        Random number generation function; it should accept a single integer
        N and return a string of random data, N bytes long.
        If not specified, a new RNG will be instantiated
        from :mod:`Crypto.Random`.

    Return:
      The PKCS#8-wrapped private key (possibly encrypted), as a byte string.
    NrzEmpty passphrasez"PBKDF2WithHMAC-SHA1AndDES-EDE3-CBC)rrr�encode�
ValueError�tobytesr�encrypt)
�private_key�key_oid�
passphrase�
protection�prot_params�
key_params�randfunc�	algorithm�pk_info�pk_info_der�r�H/home/arjun/projects/env/lib/python3.10/site-packages/Crypto/IO/PKCS8.pyr
2s&D��c

Cs�|rpt|�}d}z
t�||�}d}Wn"ty*}zdt|�}WYd}~nd}~wty4d}Ynw|shz
t�||�}d}Wn&ty[}z|dt|�7}WYd}~nd}~wtyg|d7}Ynw|sptd|��t�j|d	d
�}t	|�dkr�|s�td��|d
d
kr�t	|�dvr�td��n|d
dkr�t	|�dvr�td��ntd��t�j|ddd
�}t
��|d
�j}t	|�dkr�d}nzt��|d�d}Wn|d}Yt
��|d�j}	||	|fS)aHUnwrap a private key from a PKCS#8 blob (clear or encrypted).

    Args:
      p8_private_key (byte string):
        The private key wrapped into a PKCS#8 blob, DER encoded.
      passphrase (byte string or string):
        The passphrase to use to decrypt the blob (if it is encrypted).

    Return:
      A tuple containing

       #. the algorithm identifier of the wrapped key (OID, dotted string)
       #. the private key (byte string, DER encoded)
       #. the associated parameters (byte string, DER encoded) or ``None``

    Raises:
      ValueError : if decoding fails
    FTz	PBES1[%s]NzPBES1[Invalid]z
,PBES2[%s]z,PBES2[Invalid]zError decoding PKCS#8 (%s))����)�nr_elementsrz;Not a valid clear PKCS#8 structure (maybe it is encrypted?)r)rrz#Not a valid PrivateKeyInfo SEQUENCE�)rrr)r!r)rr�decryptr	�strr
rr�decode�lenr�valuerr�payload)
�p8_private_keyr�found�e�	error_strr�algo�algo_oid�algo_paramsrrrrr�s^������

)N)
�Crypto.Util.py3compat�Crypto.Util.asn1rrrr�Crypto.IO._PBESrrr	�__all__r
rrrrr�<module>s"
�^