forked from duckpools/off-chain-bot
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathsetup.py
More file actions
143 lines (128 loc) · 4.07 KB
/
setup.py
File metadata and controls
143 lines (128 loc) · 4.07 KB
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
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
import json
import requests
import time
from consts import MIN_BOX_VALUE, TX_FEE
from client_consts import node_url, headers, node_address
from helpers.node_calls import sign_tx, box_id_to_binary, generate_dummy_script
from logger import set_logger
logger = set_logger(__name__)
def split_utxos():
logger.info("Setup stage 0/2")
transaction_to_sign = \
{
"requests": [
{
"address": node_address,
"value": 2 * MIN_BOX_VALUE,
"assets": [
],
"registers": {
}
},
{
"address": node_address,
"value": 2 * MIN_BOX_VALUE,
"assets": [
],
"registers": {
}
}
],
"fee": TX_FEE,
"inputsRaw":
[],
"dataInputsRaw":
[]
}
logger.debug("Signing Transaction: %s", json.dumps(transaction_to_sign))
tx_id = sign_tx(transaction_to_sign)
if tx_id != -1:
logger.info("Successfully submitted transaction with ID: %s", tx_id)
else:
logger.error("Failed to submit transaction")
def get_input_boxes():
time.sleep(10)
current_boxes = json.loads(requests.get(f"{node_url}/wallet/boxes/unspent", params={"minConfirmations": -1}, headers=headers).text)
boxes = []
for box in current_boxes:
if int(box["box"]["value"]) >= 2 * MIN_BOX_VALUE:
boxes.append(box)
if len(boxes) == 2:
return boxes
return None
def create_mint_tx(input_boxes, index):
transaction_to_sign = \
{
"requests": [
{
"address": node_address,
"ergValue": MIN_BOX_VALUE,
"amount": 70,
"name": "Dummy",
"description": "Dummy token",
"decimals": 0,
"registers": {
}
}
],
"fee": TX_FEE,
"inputsRaw":
[box_id_to_binary(input_boxes[index]["box"]["boxId"])],
"dataInputsRaw":
[]
}
logger.debug("Signing Transaction: %s", json.dumps(transaction_to_sign))
tx_id = sign_tx(transaction_to_sign)
if tx_id != -1:
logger.info("Successfully submitted transaction with ID: %s", tx_id)
else:
logger.error("Failed to submit transaction")
def mint_dummy_tokens():
logger.info("Setup stage 1/2")
input_boxes = get_input_boxes()
if not input_boxes:
logger.info("Could not find input boxes with sufficient ERGs")
return
create_mint_tx(input_boxes, 0)
create_mint_tx(input_boxes, 1)
return input_boxes
def create_dummy_boxes(input_boxes, dummy_script):
logger.info("Setup stage 2/2")
transaction_to_sign = \
{
"requests": [
],
"fee": TX_FEE,
"inputsRaw":
[],
"dataInputsRaw":
[]
}
for _ in range(70):
transaction_to_sign["requests"].append({
"address": dummy_script,
"value": MIN_BOX_VALUE,
"assets": [
{
"tokenId": input_boxes[0]["box"]["boxId"],
"amount": 1
},
{
"tokenId": input_boxes[1]["box"]["boxId"],
"amount": 1
}
],
"registers": {
}
})
logger.debug("Signing Transaction: %s", json.dumps(transaction_to_sign))
tx_id = sign_tx(transaction_to_sign)
if tx_id != -1:
logger.info("Successfully submitted transaction with ID: %s", tx_id)
else:
logger.error("Failed to submit transaction")
dummy_script = generate_dummy_script(node_address)
split_utxos()
input_boxes = mint_dummy_tokens()
if input_boxes:
create_dummy_boxes(input_boxes, dummy_script)