forked from justinmoon/digital-cash
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathidentities.py
45 lines (36 loc) · 1.26 KB
/
identities.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
from ecdsa import SigningKey, SECP256k1
alice_private_key = SigningKey.from_secret_exponent(1, curve=SECP256k1)
alice_public_key = alice_private_key.get_verifying_key()
bob_private_key = SigningKey.from_secret_exponent(2, curve=SECP256k1)
bob_public_key = bob_private_key.get_verifying_key()
def user_private_key(name):
name_to_key = {
"alice": alice_private_key,
"bob": bob_private_key,
}
return name_to_key[name]
def user_public_key(name):
private_key = user_private_key(name)
return private_key.get_verifying_key()
def bank_private_key(id):
assert isinstance(id, int)
assert id >= 0
base = 1000 # So bank keys don't collide with user keys ...
return SigningKey.from_secret_exponent(base + id, curve=SECP256k1)
def bank_public_key(id):
"""Returns public key of a block producer given their ID"""
private_key = bank_private_key(id)
return private_key.get_verifying_key()
def airdrop_tx():
import uuid
from blockcoin import TxOut, Tx
id = "1"
tx = Tx(
id=id,
tx_ins=[],
tx_outs=[
TxOut(tx_id=id, index=0, amount=500_000, public_key=bob_public_key),
TxOut(tx_id=id, index=1, amount=500_000, public_key=alice_public_key),
],
)
return tx