-
Notifications
You must be signed in to change notification settings - Fork 16
/
tezos.py
46 lines (37 loc) · 1.3 KB
/
tezos.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
import unicodedata
import sys
import bitcoin
import pysodium
from pyblake2 import blake2b
from hashlib import sha256
import binascii
def bitcoin_address(digest):
bitcoin_keys = [
'\x02\xc0T!\xaa\x00\x13\xee\xd38T#\xb6<\xd2\x89' +
'\xc3BR\x118\xaa\xffj\x91U\xb3\xc7\xc8t\xc3\x1e\xa9',
'\x03\xb3\xb1|\xe2\x13\xe4\xed\xb9\xf1\x7f\x0e\x11' +
'\xf5h\x80\xa8\x96r\xd2 4\x83\xbb\x7fu\xb1\x1a%_\x08\xdc\x96'
]
script = bitcoin.serialize_script([digest, 117, 2] + bitcoin_keys + [2, 174])
return bitcoin.p2sh_scriptaddr(script)
def ethereum_data(digest):
hexdigest = binascii.hexlify(digest)
checksum = sha256(sha256(digest).digest()).hexdigest()[:8]
return "0x946941ec" + hexdigest + checksum
def tezos_pkh(digest):
return bitcoin.bin_to_b58check(digest, magicbyte=434591)
def ethdata_to_tz1(ethdata):
return ethdata[10:-8]
def check(address, mnemonic, email, password):
salt = unicodedata.normalize("NFKD", (email + password)).encode("utf8")
try:
seed = bitcoin.mnemonic_to_seed(mnemonic, salt)
except:
return -1
pk, sk = pysodium.crypto_sign_seed_keypair(seed[0:32])
pkh = blake2b(pk,20).digest()
decrypted_address = tezos_pkh(pkh)
if address == decrypted_address:
return 1
else:
return 0