
    >wg#                         d Z ddlmZmZmZmZ ddlZddlmZm	Z	m
Z
 ddlmZmZ ej                  dk  ZdZd	Zd
 ZddZd ZddZd Zy)z
Functions for parsing and dumping using the ASN.1 DER encoding. Exports the
following items:

 - emit()
 - parse()
 - peek()

Other type classes are defined that help compose the types listed above.
    )unicode_literalsdivisionabsolute_importprint_functionN   )byte_clschr_cls	type_name)int_from_bytesint_to_bytes)   z<Insufficient data - %s bytes requested but only %s available
   c                    t        | t              st        dt        |       z        | dk  s| dkD  rt	        d| z        t        |t              st        dt        |      z        |dk  s|dkD  rt	        d|z        t        |t              st        dt        |      z        |dk  rt	        d	|z        t        |t
              st        d
t        |      z        t        | |||      |z   S )a  
    Constructs a byte string of an ASN.1 DER-encoded value

    This is typically not useful. Instead, use one of the standard classes from
    asn1crypto.core, or construct a new class with specific fields, and call the
    .dump() method.

    :param class_:
        An integer ASN.1 class value: 0 (universal), 1 (application),
        2 (context), 3 (private)

    :param method:
        An integer ASN.1 method value: 0 (primitive), 1 (constructed)

    :param tag:
        An integer ASN.1 tag value

    :param contents:
        A byte string of the encoded byte contents

    :return:
        A byte string of the ASN.1 DER value (header and contents)
    z!class_ must be an integer, not %sr   r   z*class_ must be one of 0, 1, 2 or 3, not %sz!method must be an integer, not %sr   zmethod must be 0 or 1, not %sztag must be an integer, not %sz%tag must be greater than zero, not %s&contents must be a byte string, not %s)
isinstanceint	TypeErrorr
   
ValueErrorr   _dump_header)class_methodtagcontentss       H/var/www/horilla/myenv/lib/python3.12/site-packages/asn1crypto/parser.pyemitr      s    2 fc";i>OOPPzVaZENOOfc";i>OOPPzVaZ86ABBc389S>IJJ
Qw@3FGGh)@9XCVVWWX6AA    c                     t        | t              st        dt        |       z        t	        |       }t        | |      \  }}|r||k7  rt        d||z
  z        |S )al  
    Parses a byte string of ASN.1 BER/DER-encoded data.

    This is typically not useful. Instead, use one of the standard classes from
    asn1crypto.core, or construct a new class with specific fields, and call the
    .load() class method.

    :param contents:
        A byte string of BER/DER-encoded data

    :param strict:
        A boolean indicating if trailing data should be forbidden - if so, a
        ValueError will be raised when trailing data exists

    :raises:
        ValueError - when the contents do not contain an ASN.1 header or are truncated in some way
        TypeError - when contents is not a byte string

    :return:
        A 6-element tuple:
         - 0: integer class (0 to 3)
         - 1: integer method
         - 2: integer tag
         - 3: byte string header
         - 4: byte string content
         - 5: byte string trailer
    r   z4Extra data - %d bytes of trailing data were provided)r   r   r   r
   len_parser   )r   strictcontents_leninfoconsumeds        r   parser$   K   sd    : h)@9XCVVWWx=LHl3ND((l*OS_bjSjkllKr   c                     t        | t              st        dt        |       z        t	        | t        |             \  }}|S )aW  
    Parses a byte string of ASN.1 BER/DER-encoded data to find the length

    This is typically used to look into an encoded value to see how long the
    next chunk of ASN.1-encoded data is. Primarily it is useful when a
    value is a concatenation of multiple values.

    :param contents:
        A byte string of BER/DER-encoded data

    :raises:
        ValueError - when the contents do not contain an ASN.1 header or are truncated in some way
        TypeError - when contents is not a byte string

    :return:
        An integer with the number of bytes occupied by the ASN.1 value
    r   )r   r   r   r
   r   r   )r   r"   r#   s      r   peekr&   r   s=    & h)@9XCVVWWHc(m4ND(Or   c           
         |t         kD  rt        d      |}||dz   k  rt        t        d||z
  fz        t        rt	        | |         n| |   }|dz  }|dz  }|dz	  dz  }|dk(  r|d}	 ||dz   k  rt        t        d||z
  fz        t        rt	        | |         n| |   }	|dz  }|	dk(  r|dk(  rt        d      |dz  }||	d	z  z  }|	d
z	  dk(  rni|dk  rt        d      ||dz   k  rt        t        d||z
  fz        t        rt	        | |         n| |   }
|dz  }d}|
d
z	  dk(  r	||
d	z  z   }n|
d	z  }|r;|||z   k  rt        t        |||z
  fz        ||z  }|t        | ||z
  | d      z   }nT|st        d      |}||dz   k  s| ||dz    dk7  r+t        | ||d|dz         \  }}||dz   k  r| ||dz    dk7  r+|dz  }d}||kD  rt        t        ||z
  ||z
  fz        |r||fS |dz	  ||| || | ||t        |      z
   |f|fS )a  
    Parses a byte string into component parts

    :param encoded_data:
        A byte string that contains BER-encoded data

    :param data_len:
        The integer length of the encoded data

    :param pointer:
        The index in the byte string to parse from

    :param lengths_only:
        A boolean to cause the call to return a 2-element tuple of the integer
        number of bytes in the header and the integer number of bytes in the
        contents. Internal use only.

    :param depth:
        The recursion depth when evaluating indefinite-length encoding.

    :return:
        A 2-element tuple:
         - 0: A tuple of (class_, method, tag, header, content, trailer)
         - 1: An integer indicating how many bytes were consumed
    z*Indefinite-length recursion limit exceededr         r   T   zNon-minimal tag encoding      r   F)signedz-Indefinite-length element must be constructed   s     )lengths_onlydepth   )
_MAX_DEPTHr   _INSUFFICIENT_DATA_MESSAGE_PY2ordr   r   r   )encoded_datadata_lenpointerr/   r0   startfirst_octetr   constructednumlength_octettrailercontents_endlength_octets_s                  r   r   r      s   6 zEFFE'A+3q(W:L6MMNN04#l7+,,w:OKqLG

C!#q(K
by'A+% !;q(WBT>U!UVV04#l7+,,w:OCqLGd{sax !;<<3JC39Cax1}  8788'A+3q(W:L6MMNN153|G,-<;PLqLGGqA,"45 %s*'M11 !;}hY`N`>a!abb}$G"^L=AXY`4ajo%ppL  !PQQ"L\A--l<XY>1Z^i1i"(x\`hmnoho"p< \A--l<XY>1Z^i1iAL!Gh3|g7MxZaOa6bbcc&& 1w'c'l!:;	
 	
 
r   c                 f   d}d}|| dz  z  }||dz  z  }|dk\  r<d}|dkD  r#t        ||dz  z        |z   }|sd}|dz	  }|dkD  r#t        |dz        |z   }n|t        ||z        z  }t        |      }|dk  r|t        |      z  }|S t        |      }|t        dt        |      z        z  }||z  }|S )	a  
    Constructs the header bytes for an ASN.1 object

    :param class_:
        An integer ASN.1 class value: 0 (universal), 1 (application),
        2 (context), 3 (private)

    :param method:
        An integer ASN.1 method value: 0 (primitive), 1 (constructed)

    :param tag:
        An integer ASN.1 tag value

    :param contents:
        A byte string of the encoded byte contents

    :return:
        A byte string of the ASN.1 DER header
    r   r   r1   r)   r(   r+   r*   r,   )r	   r   r   )	r   r   r   r   headerid_numcont_bitlengthlength_bytess	            r   r   r      s    * FF
fkF
fkF
byAgXt45>F(C	 Ag
 "%.'&3,'']F}'&/! M	 $F+'$\!2233,Mr   )F)r   Fr   )__doc__
__future__r   r   r   r   sys_typesr   r	   r
   utilr   r   version_infor4   r3   r2   r   r$   r&   r   r    r   r   <module>rO      sX   	 S R 
 0 0 .
4[ 
.Bb$N4gT.r   