ó â\e[c@sÓddlZddlZy)eeZd„Zd„Zd„ZWn,ek roe Ze Ze Zd„ZnXdZ d.Z d0Z d „Zd „Zd„ZdedƒZede dde ƒZd„ZdedƒZeeƒZee ee gZd„Zd„Zd„Zd„Zd„Zd„Zd„Zd„Zd„Zd„Z d„Z!d „Z"d!„Z#d"„Z$d#„Z%e Z&d$Z'd%„Z(d&„Z)d'd(„Z*d)d*„Z+d+„Z,d,„Z-dS(1i˙˙˙˙NcCsdjd„|DƒƒS(s(Convert array of integers to byte stringtcss|]}t|ƒVqdS(N(tchr(t.0tx((s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pys s(tjoin(tb((s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pytasbytesscCs dj|ƒS(s%Convert array of bytes to byte stringR(R(R((s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pyt joinbytesscCst||dƒ|d?d@S(sReturn i'th bit of bytestring hii(tord(thti((s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pytbitscCs||d|d?d@S(Nii((R R ((s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pyR siii˙iiül íSë9i “@eMó^¨w|ocCstj|ƒjƒS(N(thashlibtsha512tdigest(tm((s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pytH(scCsM|dkrdSt||d|ƒd|}|d@rI|||}n|S(Niii(texpmod(RteRtt((s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pyR,s   cCst|tdtƒS(Ni(Rtq(R((s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pytinv9siż$ţ˙iBŰiicCsˆ||dtt||dƒ}t|tddtƒ}|||tdkrg|tt}n|ddkr„t|}n|S(Niiiii(RtdRRtI(tytxxR((s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pytxrecoverAs$ icCsô|\}}}}|\}}}} ||||t} ||||t} |d| t} |d|t} | | t}| | t}| | t}| | t}||t}||t}||t}||t}||||fS(Ni(R(tpt1tpt2tX1tY1tZ1tT1tX2tY2tZ2tT2tAtBtCtDtEtFtGRtX3tY3tZ3tT3((s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pytxpt_addescCsŐ|\}}}}||}||}d||}| t}||t} | | ||t} ||t} | |t} ||t} | | t}| | t}| | t}| | t}||||fS(Ni(R(tptRRRt_R%R&R'R(tJR)R+R*RR,R-R.R/((s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pyt xpt_doublews   cCs$|\}}||d||tfS(Ni(R(R1RR((s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pytpt_xform‰s cCs8|\}}}}|t|ƒt|t|ƒtfS(N(RR(R1RRtzR2((s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pyt pt_unxformŽscCsJ|dkrtdƒStt||d?ƒƒ}|d@rFt||ƒS|S(Nii(ii(R5R4txpt_multR0(R1tnR2((s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pyR8“s  cCsttt|ƒ|ƒƒS(N(R7R8R5(R1R((s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pyt scalarmult›scCsƒgttƒD]}||?d@^q }gttdƒD];}tgtdƒD]}||d||>^qNƒ^q8}t|ƒS(Nii(trangeRtsumR(RR tbitstjR((s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pyt encodeintŸs'OcCsŚ|d}|d}gttdƒD]}||?d@^q%|d@g}gttdƒD];}tgtdƒD]}||d||>^qqƒ^q[}t|ƒS(Niii(R;RR<R(tPRRR R=R>R((s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pyt encodepointŚs   6OcsZt|ƒ‰dtdt‡fd†tdtdƒDƒƒ}tt|ƒ}t|ƒS(Nic3s&|]}d|tˆ|ƒVqdS(iN(R (RR (R (s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pys ąsi(RRR<R;R:R&RA(tsktaR%((R s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pyt publickeyŻs 5cs0t|ƒ‰t‡fd†tdtƒDƒƒS(Nc3s&|]}d|tˆ|ƒVqdS(iN(R (RR (R (s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pys ¸si(RR<R;R(R((R s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pytHintśs c sÎt|ƒ‰dtdt‡fd†tdtdƒDƒƒ}tgttdtdƒD]}ˆ|^q\ƒ}t||ƒ}tt|ƒ}|tt|ƒ||ƒ|t }t|ƒt |ƒS(Nic3s&|]}d|tˆ|ƒVqdS(iN(R (RR (R (s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pys ˝siii( RRR<R;RRER:R&RAtlR?( RRBtpkRCR tintertrtRtS((R s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pyt signatureťs 54&cCsG|d}|d}| |||dt||||tdkS(Nii(RR(R@RR((s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pyt isoncurveĹs  cs#t‡fd†tdtƒDƒƒS(Nc3s&|]}d|tˆ|ƒVqdS(iN(R (RR (ts(s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pys Ěsi(R<R;R(RN((RNs7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pyt decodeintËscsŠt‡fd†tdtdƒDƒƒ}t|ƒ}|d@tˆtdƒkr_t|}n||g}t|ƒs†tdƒ‚n|S(Nc3s&|]}d|tˆ|ƒVqdS(iN(R (RR (RN(s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pys Đsiis#decoding point that is not on curve(R<R;RRR RRMt Exception(RNRRR@((RNs7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pyt decodepointĎs)    c Csĺt|ƒtdkr%tdƒ‚nt|ƒtdkrJtdƒ‚nt|dtd!ƒ}t|ƒ}t|tdtd!ƒ}tt|ƒ||ƒ}tt|ƒ}t t t |ƒt t||ƒƒƒƒ}||kS(Nissignature length is wrongispublic-key length is wrongi( tlenRRPRQRORERAR:R&R7R0R5( RNRRGRJR%RKR tv1tv2((s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pyt checkvalidÜs *imc Csr|\}}|\}}|\}}d||||d|} d||||d|} | t| tfS(Nii(R@( R9RRtxntzntxmtzmtxdtzdRR6((s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pytadd˙s    cCs^|\}}|d|dd}d|||dt|||d}|t|tfS(Nii(R%R@(R9RVRWRR6((s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pytdoubles *i csW|df‰tˆƒ‰‡‡‡fd†‰ˆ|ƒ\\}}}|t|ƒtS(Nicsn|dkrˆˆfSˆ|dƒ\}}|d@rRt||ˆƒt|ƒfSt|ƒt||ˆƒfS(Nii(R\R](Rtpmtpm1(tftonettwo(s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pyR`s    (R]RR@(R9tbaseRR6R2((R`RaRbs7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pyt curve25519s    icCsC|ptjdtƒ}|dM}|dd>M}|dd >O}|S( Niii€iii@iř˙˙˙iřiř(trandomtrandintR@(R9((s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pytgenkey$s  cCsnddl}ttjtttƒƒjdƒ}|jdƒ}t|ƒ}t|||ƒ}t |||ƒS(Ni˙˙˙˙sutf-8i ( toststrReRfRtencodeturandomRDRLRU(RhtmsgRBRGtsig((s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pytdsa_test7s  % cCs:tƒ}tƒ}t|t|ƒƒt|t|ƒƒkS(N(RgRd(tsk1tsk2((s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pytdh_test@s  llí˙˙˙˙˙˙˙˙˙˙˙˙˙˙˙˙llíSë9i “@eMó^¨w|o(.R RetunicodetFalsetPY3RRR t NameErrortTruetbytesRRRFRRRRRRtBytBxR&R0R4R5R7R8R:R?RARDRERLRMRORQRUR@R%R\R]RdRgRnRq(((s7/tmp/pip-install-0xiv62/wheel/wheel/signatures/djbec.pyt s^