
    ,hk                     <    d dl mZ ddlmZ ddlmZmZmZ d Zd Z	y)   )_Curve    )Integer)load_pycryptodome_raw_libVoidPointerSmartPointerc                      dd} t        dd       G fddt              }fd}t        t              d t        |       t        d      d d d	d
d dd ||      }|S )Nl   l   S9i@eM^w|o                zCrypto.PublicKey._curve25519a  
typedef void Point;

int curve25519_new_point(Point **out,
                         const uint8_t x[32],
                         size_t modsize,
                         const void* context);
int curve25519_clone(Point **P, const Point *Q);
void curve25519_free_point(Point *p);
int curve25519_get_x(uint8_t *xb, size_t modsize, Point *p);
int curve25519_scalar(Point *P, const uint8_t *scalar, size_t scalar_len, uint64_t seed);
int curve25519_cmp(const Point *ecp1, const Point *ecp2);
c                       e Zd ZW  j                  ZW  j
                  ZW  j                  ZW  j                  Z
W  j                  ZW  j                  Zy)curve25519_curve.<locals>.EcLibN)__name__
__module____qualname__curve25519_new_point	new_pointcurve25519_cloneclonecurve25519_free_point
free_pointcurve25519_get_xget_xcurve25519_scalarscalarcurve25519_cmpcmp)_curve25519_libs   ^/var/www/html/Resume-Scraper/venv/lib/python3.12/site-packages/Crypto/PublicKey/_montgomery.pyEcLibr      sE    #88	00$::
00 22,,    r   c                     dz  }d}d}dd||dz
  dz   |z   |z   |dz
  ||dz   f}	 | j                   |v}|st        d      y # t        $ r d}Y w xY w)N   l   kxujaj\~|ObjZs	oP,E$ l   _+yBb$:6gw[8cph[DS7OWr   r   FzInvalid Curve25519 public keyx
ValueError)pointp2x1x2	deny_listvalidps         r   _validate_x25519_pointz0curve25519_curve.<locals>._validate_x25519_point$   s    UXZ EEFFFF
		GG9,E <==   	E	s   A AA	      z1.3.101.110
Curve25519)r   objectr   r   )orderr   r+   
curve25519r   r*   s       @@r   curve25519_curver2   
   sw    JANE/0N Q O- ->< 

%$.J r   c                  p   dd} t        dd       G fddt              }t               }|j                  |j	                               }|rt        d|z        fd}t        t              d t        |       t        d	      d d d
dt        |j                         |j                        dd ||      }|S )Nl   ?l   DVJ
Ru8a6!m,&vD}D2_zCrypto.PublicKey._curve448a  
typedef void Curve448Context;
typedef void Curve448Point;

int curve448_new_context(Curve448Context **pec_ctx);
void curve448_free_context(Curve448Context *ec_ctx);
int curve448_new_point(Curve448Point **out,
                       const uint8_t *x,
                       size_t len,
                       const Curve448Context *ec_ctx);
void curve448_free_point(Curve448Point *p);
int curve448_clone(Curve448Point **P, const Curve448Point *Q);
int curve448_get_x(uint8_t *xb, size_t modsize, const Curve448Point *p);
int curve448_scalar(Curve448Point *P, const uint8_t *scalar, size_t scalar_len, uint64_t seed);
int curve448_cmp(const Curve448Point *ecp1, const Curve448Point *ecp2);
c                       e Zd ZW  j                  ZW  j
                  ZW  j                  ZW  j                  Z
W  j                  ZW  j                  ZW  j                  ZW  j"                  Zy)curve448_curve.<locals>.EcLibN)r   r   r   curve448_new_contextnew_contextcurve448_free_contextfree_contextcurve448_new_pointr   curve448_cloner   curve448_free_pointr   curve448_get_xr   curve448_scalarr   curve448_cmpr   )_curve448_libs   r   r   r5   i   s[    #88$::!44	,,"66
,,..((r   r   z&Error %d initializing Curve448 contextc                 z    dddz
  dz   f}	 | j                   |v}|st        d      y # t        $ r d}Y w xY w)Nr   r   FzInvalid Curve448 public keyr!   )r$   r(   r)   r*   s      r   _validate_x448_pointz,curve448_curve.<locals>._validate_x448_pointx   s`    EE
		GG9,E :;;   	E	s   , ::   i  z1.3.101.111Curve448)r   r/   r   r7   
address_ofImportErrorr   r   r   getr9   )r0   r   curve448_contextresultrB   curve448r@   r*   s         @@r   curve448_curverK   T   s    zA~E-.J M M") ) #}/::<=FBVKLL<" gajenaj#"#3#7#7#95;M;MN *H Or   N)
_curver   Crypto.Math.Numbersr   Crypto.Util._raw_apir   r   r   r2   rK    r   r   <module>rP      s$     '0 0GTDr   