
    ":h5'                        d dl mZ d dlZd dlZd dlZd dlmZ ddlmZ ddl	m
Z
 dZ ej                  e ZddZ G d	 d
      Zd Zd Zd ZefdZefdZd Zd Zd Zd Zd ZddZddZddZddZddZddZd Z d Z!d Z"y)    )divisionN)sha256   )der)orderlen)r      iH  i='  r   r   c                     |t         j                  }| dkD  sJ t        |       }d}|dkD  r(|dz  }t         ||            dz   }d|cxk  r| k  r|S  -t	        d| z        )a  Return a random integer k such that 1 <= k < order, uniformly
    distributed across that range. For simplicity, this only behaves well if
    'order' is fairly close (but below) a power of 256. The try-try-again
    algorithm we use takes longer and longer time (on average) to complete as
    'order' falls, rising to a maximum of avg=512 loops for the worst-case
    (256**k)+1 . All of the standard curves behave well. There is a cutoff at
    10k loops (which raises RuntimeError) to prevent an infinite loop when
    something is really broken like the entropy function not working.

    Note that this function is not declared to be forwards-compatible: we may
    change the behavior in future releases. The entropy= argument (which
    should get a callable that behaves like os.urandom) can be used to
    achieve stability within a given release (for repeatable unit tests), but
    should not be used as a long-term-compatible key generation algorithm.
    r   i'  r   zlrandrange() tried hard but gave up, either something is very wrong or you got realllly unlucky. Order was %x)osurandomr   string_to_numberRuntimeError)orderentropybytesdont_try_forever	candidates        ]/var/www/html/turnos/venv/lib/python3.12/site-packages/ccxt/static_dependencies/ecdsa/util.py	randranger      s    2 **199UOE
Q
A$WU^4q8		!E! "
 $% & &    c                       e Zd Zd Zd Zd Zy)PRNGc                 0    | j                  |      | _        y N)block_generator	generator)selfseeds     r   __init__zPRNG.__init__B   s    --d3r   c                 x    t        |      D cg c]  }t        | j                         }}t        |      S c c}w r   )rangenextr   r   )r   numbytesias       r   __call__zPRNG.__call__E   s0    +0?;aT$..!;;Qx <s   7c              #      K   d}	 t        d||fz  j                               j                         D ]  }|  |dz  };w)Nr   z
prng-%d-%sr   )r   encodedigest)r   r   counterbytes       r   r   zPRNG.block_generatorI   sP      >FFHIPPR 
qLG s   ?AN)__name__
__module____qualname__r   r%   r    r   r   r   r   <   s    4r   r   c                      t        |       dt        |      z        }t        t        j                  |      d      |dz
  z  dz   }d|cxk  r|k  sn J d||f       |S )Nr      r   )r   r   intbinasciihexlify)r   r   basenumbers       r   %randrange_from_seed__overshoot_modulor6   Q   sf     4:a(5/)*D(""4("-;q@F2FE 22Mr   c                     d| z  dz
  S )Nr   r.   )numbitss    r   lsb_of_onesr9   ^   s    LAr   c                 j    t        t        j                  | dz
  d      dz         }|dz  }|dz  }|||fS )Nr   r      )r1   mathlog)r   bitsr   	extrabitss       r   bits_and_bytesr@   b   s?    txx	1%)*DAIEqI	!!r   c                     t        |      \  }}}|r|dz  } ||       j                         d | }d|t        |      z
  z  |z   }dt        t	        j
                  |      d      z   }d|cxk  r|k  sJ  J |S )Nr    r0   )r@   r(   lenr1   r2   r3   )r   r   hashmodr>   _bytesr?   r4   r5   s           r   #randrange_from_seed__truncate_bytesrF   t   s     -U3D&)!4=!'6*DVc$i'(4/DX%%d+R00FMr   c                    t        t        j                  |dz
  d      dz         }|dz   dz  } ||       j                         d | }d|t	        |      z
  z  |z   }d|z  |z
  }|r5t         j                  t        |d         t        |      z  dd      |dd  z   }dt        t        j                  |      d      z   }d|cxk  r|k  sJ  J |S )	Nr   r      r;   rB   r   bigr0   )
r1   r<   r=   r(   rC   to_bytesordr9   r2   r3   )r   r   rD   r>   maxbytesr4   topbitsr5   s           r   "randrange_from_seed__truncate_bitsrN      s     txx	1%)*DqQH4=!)8,DXD	)*T1D(lT!G||CQL;w+??EJTRSRTXUX%%d+R00FMr   c                     |dkD  sJ t        |      \  }}}t        |       }	 d}|r2t        j                  t	         |d            t        |      z  dd      }t        | ||      z         dz   }d|cxk  r|k  r|S  \)Nr   r   rI   )r@   r   r1   rJ   rK   r9   r   )r   r   r>   r   r?   generate	extrabyteguesss           r    randrange_from_seed__trytryagainrS      s     199+E2D%DzH
	S!%5I8N%NPQSXYI Xe_!<=AL  r   c                     t        |      }dt        d|z        z   dz   }t        j                  || z  j	                               }t        |      |k(  sJ t        |      |f       |S Nz%0r   x)r   strr2   	unhexlifyr'   rC   numr   lfmt_strstrings        r   number_to_stringr^      sd    ASQZ#%G3 6 6 89Fv;!-c&k1--Mr   c                     t        |      }dt        d|z        z   dz   }t        j                  || z  j	                               }|d | S rU   )r   rW   r2   rX   r'   rY   s        r   number_to_string_cropr`      sK    ASQZ#%G3 6 6 89F"1:r   c                 @    t        t        j                  |       d      S Nr0   )r1   r2   r3   )r]   s    r   r   r      s    x',,r   c                     t        |      }t        |       |k(  sJ t        |       |f       t        t        j                  |       d      S rb   )r   rC   r1   r2   r3   )r]   r   r[   s      r   string_to_number_fixedlenrd      sC    Av;!-c&k1--x',,r   c                 <    t        | |      }t        ||      }|||fS r   )r^   rsr   vr_strs_strs         r   sigencode_stringsrl      s&    Q&EQ&E%?r   c                 .    t        | ||      \  }}}||z   S r   rl   rf   s         r   sigencode_stringro      s"     (1e4OE5!5=r   c                 z    t        j                  t        j                  |       t        j                  |            S r   )r   encode_sequenceencode_integerrg   rh   r   ri   s       r   sigencode_derrt      s+    s11!4c6H6H6KLLr   c                 F    ||dz  kD  r||z
  }||dz  }t        | |||      S Nr   r   rn   rs   s       r   sigencode_strings_canonizerw      s5    519}AI=FAQ5!,,r   c                 F    ||dz  kD  r||z
  }||dz  }t        | |||      S rv   )ro   rs   s       r   sigencode_string_canonizery      s5    519}AI=FAAq%++r   c                 F    ||dz  kD  r||z
  }||dz  }t        | |||      S rv   )rt   rs   s       r   sigencode_der_canonizer{      s5    519}AI=FAAua((r   c                     t        |      }t        |       d|z  k(  sJ t        |       d|z  f       t        | d | |      }t        | |d  |      }||fS )Nr   r   rC   rd   )	signaturer   r[   rg   rh   s        r   sigdecode_stringr      s`    Ay>QU";S^QU$;;"!)BQ-7A!)AB-7Aa4Kr   c                     | \  }}t        |      }t        |      |k(  sJ t        |      |f       t        |      |k(  sJ t        |      |f       t        ||      }t        ||      }||fS r   r}   )
rs_stringsr   rj   rk   r[   rg   rh   s          r   sigdecode_stringsr      so    NUEAu:?+SZO+?u:?+SZO+?!%/A!%/Aa4Kr   c                 Z   t        j                  |       \  }}|dk7  r+t        j                  dt        j                  |      z        t        j
                  |      \  }}t        j
                  |      \  }}|dk7  r+t        j                  dt        j                  |      z        ||fS )Nr   ztrailing junk after DER sig: %sz#trailing junk after DER numbers: %s)r   remove_sequenceUnexpectedDERr2   r3   remove_integer)sig_derr   r   emptyrg   restrh   s          r   sigdecode_derr      s    ++G4J| A ( 0 0 7!8 9 	9  ,GAt!!$'HAu| E ( 0 0 7!8 9 	9a4Kr   r   )#
__future__r   r
   r<   r2   hashlibr    r   curvesr   oid_ecPublicKey
encode_oidencoded_oid_ecPublicKeyr   r   r6   r9   r@   rF   rN   rS   r^   r`   r   rd   rl   ro   rt   rw   ry   r{   r   r   r   r.   r   r   <module>r      s     	      +(#../: &&R *
"$ >D  =C &--M-,)r   