forked from kimsk/chia-piggybank
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsimple_pay_to_delegated.py
101 lines (82 loc) · 2.82 KB
/
simple_pay_to_delegated.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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
import asyncio
import utils
from blspy import (PrivateKey, AugSchemeMPL, G2Element)
from cdv.test import Network, Wallet
from cdv.util.load_clvm import load_clvm
from chia.consensus.default_constants import DEFAULT_CONSTANTS
from chia.types.blockchain_format.program import Program
from chia.types.coin_spend import CoinSpend
from chia.types.condition_opcodes import ConditionOpcode
from chia.types.spend_bundle import SpendBundle
from chia.util.hash import std_hash
network: Network = asyncio.run(Network.create())
asyncio.run(network.farm_block())
alice: Wallet = network.make_wallet("alice")
bob: Wallet = network.make_wallet("bob")
asyncio.run(network.farm_block(farmer=alice))
print(f'alice balance:\t{alice.balance()}')
print(f'bob balance:\t{bob.balance()}')
alice_coins = alice.usable_coins
print(f'alice coins:')
for k, c in alice_coins.items():
print(k)
utils.print_json(c.to_json_dict())
# (mod (PUB_KEY delegated_puzzle solution)
# (include condition_codes.clib)
# (include sha256tree.clib)
# (c
# (list AGG_SIG_ME PUB_KEY (sha256tree delegated_puzzle))
# (a delegated_puzzle solution)
# )
# )
MOD = load_clvm("simple_pay_to_delegated.clsp",
package_or_requirement=__name__,
search_paths=["../include"]
)
# create a smart coin and curry in alice's pk
amt = 1_000_000
alice_mod = MOD.curry(alice.pk())
alice_coin = asyncio.run(
alice.launch_smart_coin(
alice_mod,
amt=amt
)
)
print(f'alice smart coin:\t{alice_coin}')
# (delegated_puzzle solution)
solution = Program.to([
1, # (mod conditions conditions)
[
[ConditionOpcode.CREATE_COIN, bob.puzzle_hash, amt],
[ConditionOpcode.ASSERT_MY_AMOUNT, alice_coin.amount]
]
])
# create a spend bundle with alice's signature
spend = CoinSpend(
alice_coin.as_coin(),
alice_mod,
solution
)
# message: bytes = std_hash(bytes("hello delegated puzzle", "utf-8"))
message: bytes = Program.to(1).get_tree_hash() # (mod conditions conditions)
alice_sk: PrivateKey = alice.pk_to_sk(alice.pk())
sig: G2Element = AugSchemeMPL.sign(
alice_sk,
message
+ alice_coin.name()
+ DEFAULT_CONSTANTS.AGG_SIG_ME_ADDITIONAL_DATA,
)
spend_bundle = SpendBundle([spend], sig)
print(f'\npush spend bundle:\n{spend_bundle}\n')
asyncio.run(network.push_tx(spend_bundle))
print(f'alice balance:\t{alice.balance()}')
print(f'bob balance:\t{bob.balance()}')
alice_coin_id = alice_coin.name()
alice_coin_record = asyncio.run(
network.sim_client.get_coin_record_by_name(alice_coin_id))
print(alice_coin_record)
coin_spend: CoinSpend = asyncio.run(
network.sim_client.get_puzzle_and_solution(alice_coin_id, alice_coin_record.spent_block_index))
print(coin_spend.puzzle_reveal)
asyncio.run(network.close())
# utils.print_json(spend_bundle.to_json_dict(include_legacy_keys = False, exclude_modern_keys = False))