-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmain.star
173 lines (144 loc) · 9.59 KB
/
main.star
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
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
# Import the required modules
icon_setup_node = import_module("./services/jvm/icon/src/node-setup/setup_icon_node.star")
eth_node = import_module("./services/evm/eth/eth.star")
icon_service = import_module("./services/jvm/icon/icon.star")
cosmvm_node = import_module("./services/cosmvm/cosmvm.star")
btp_relay_setup = import_module("./services/bridges/btp/src/bridge.star")
ibc_relay_setup = import_module("./services/bridges/ibc/src/bridge.star")
def run(plan, command, node_name= None, custom_config = None, icon_service_config = None, decentralize = False, bridge_type = None, chain_a = None, chain_b = None, service_config_a = None, service_config_b = None, bridge = False):
"""
Parse the input and execute the specified action.
Args:
command (string): The action to perform.
- 'chain': Start a node.
- 'bridge': Start a relay.
- 'decentralize': decentralize already running icon node.
node_name (string): Name of the node to start.
- Currently supported options: 'eth', 'hardhat', 'icon', 'neutron', 'archway'.
custom_config (json): Custom configuration for node or relay. If empty, the node will start with default settings.
For ICON node with custom configuration, the following fields should be provided in custom_config_dict:
- private_port (int): The private port for the node.
- public_port (int): The public port for the node.
- p2p_listen_address (string): The p2p listen address.
- p2p_address (string): The p2p address.
- cid (string): The CID (Chain ID) of the node.
- genesis_file_path (string): The file path to the genesis file.
- genesis_file_name (string): The name of the genesis file.
For Cosmos (json) node with custom configuration, the following fields should be provided in the custom config dict:
- chain_id (string): The chain ID.
- key (string): The key.
- password (string): The password.
- public_grpc (string): The public gRPC address.
- public_http (string): The public HTTP address.
- public_tcp (string): The public TCP address.
- public_rpc (string): The public RPC address.
icon_service_config (json): ServiceConfig, this field should be provided when an already running icon node is to be decentralized
decentralize (bool): Flag indicating whether to decentralize the ICON node.
bridge_type (string): The type of relay.
- 'ibc': Start an IBC relay.
- 'btp': Start a BTP bridge.
chain_a (string): The source chain for relaying.
chain_b (string): The destination chain for relaying.
service_config_a (json): Service configuration for chain A (source chain for relaying, Note: fields in dictionary should be same as output return after running node).
service_config_b (json): Service configuration for chain B (destination chain for relaying, Note: fields in dictionary should be same as output return after running node).
bridge (bool): Flag indicating whether to use a BMV bridge.
Returns:
json: Details about the service started.
"""
return parse_input(plan, command, node_name, custom_config, icon_service_config ,decentralize, bridge_type ,chain_a, chain_b, service_config_a, service_config_b, bridge)
def parse_input(plan, action, node_name= None, custom_config = None, icon_service_config = None, decentralize = False, relay_type = None, chain_a = None, chain_b = None, service_config_a = None, service_config_b = None, bridge = False):
"""
Parse the input and execute the specified action.
Args:
plan (Plan): The Kurtosis plan.
action (str): The action to perform.
node_name (str, optional): Name of the node to start.
custom_config (dict, optional): Custom configuration for node or relay. If empty, the node will start with default settings.
icon_service_config (dict, optional): ServiceConfig, this field should be provided when an already running icon node is to be decentralized
decentralize (bool, optional): Flag indicating whether to decentralize the ICON node.
relay_type (str, optional): The type of relay.
chain_a (str): The source chain for relaying.
chain_b (str): The destination chain for relaying.
service_config_a (dict): Service configuration for chain A (source chain for relaying, Note: fields in dictonary should be same as output return after running node).
service_config_b (dict): Service configuration for chain B (destination chain for relaying, Note: fields in dictonary should be same as output return after running node).
bridge (bool): Flag indicating whether to use a BMV bridge.
Returns:
dict: Details about the service started.
"""
# Start the single node
if action == "chain":
if node_name != None:
run_node(plan, node_name, decentralize, custom_config)
else:
fail("node_name parameter is missing, node_name require to start node.")
# Start a bridge between two nodes
elif action == "bridge":
# Start btp relay between two nodes
if relay_type == "btp":
if chain_a != None and chain_b != None:
if service_config_a == None and service_config_b == None:
data = btp_relay_setup.run_btp_setup(plan, chain_a, chain_b, bridge)
elif service_config_a != None and service_config_b != None:
if chain_a == "icon" and chain_b == "icon":
data = btp_relay_setup.start_btp_for_already_running_icon_nodes(plan, chain_a, chain_b, service_config_a, service_config_b, bridge)
elif chain_a == "icon" and chain_b in ["eth", "hardhat"]:
data = btp_relay_setup.start_btp_icon_to_eth_for_already_running_nodes(plan, chain_a, chain_b, service_config_a, service_config_b, bridge)
else:
fail("unsupported chain {0} - {1}".format(chain_a, chain_b))
else:
fail("Add Service configs for both chain_a and chain_b")
return data
else:
fail("chain_a and chain_b paramter are missing, Add chain_a and chain_b to start relay between them.")
# Start ibc relay between two nodes
elif relay_type == "ibc":
if chain_a != None and chain_b != None:
if service_config_a == None and service_config_b == None:
data = ibc_relay_setup.run_cosmos_ibc_setup(plan, chain_a, chain_b)
elif service_config_a != None and service_config_b != None:
data = ibc_relay_setup.run_cosmos_ibc_relay_for_already_running_chains(plan, chain_a, chain_b, service_config_a, service_config_b)
else:
fail("Add Service configs for both chain_a and chain_b")
return data
else:
fail("chain_a and chain_b paramter are missing, Add chain_a and chain_b to start relay between them.")
else:
fail("More Relay Support will be added soon")
# Decentralize the icon node
elif action == "decentralize":
if icon_service_config != None:
icon_setup_node.configure_node(icon_service_config["service_name"], icon_service_config["enpoint"], icon_service_config["keystore_path"], icon_service_config["keypassword"], icon_service_config["nid"])
else: fail("icon_service_config paramter is missing, Add icon_service_config to decentralise the already running icon node")
else:
fail("commands only support 'chain', 'bridge' and 'decentralize'")
def run_node(plan, node_name, decentralize, custom_config = None):
"""
Start a single node.
Args:
plan (Plan): The Kurtosis plan.
node_name (str): Name of the node to start.
decentralize (bool): Flag indicating whether to decentralize the ICON node.
custom_config (dict, optional): Custom configuration for node or relay. Defaults to None.
Returns:
dict: Details about the service started.
"""
# Start the icon node
if node_name == "icon":
if custom_config == None:
service_config = icon_service.start_node_service(plan)
else:
service_config = icon_service.start_node_service(plan, custom_config["private_port"], custom_config["public_port"], custom_config["p2p_listen_address"], custom_config["p2p_address"], custom_config["cid"], custom_config["uploaded_genesis"], custom_config["genesis_file_path"], custom_config["genesis_file_name"])
if decentralize == True:
icon_setup_node.configure_node(service_config["service_name"], service_config["enpoint"], service_config["keystore_path"], service_config["keypassword"], service_config["nid"])
return service_config
# Start EVM based nodes (eth and hardhat)
elif node_name == "eth" or node_name == "hardhat":
return eth_node.start_eth_node_service(plan, node_name)
# Start cosmos based nodes (archway and neutron)
elif node_name == "archway" or node_name == "neutron":
if custom_config == None:
return cosmvm_node.start_cosmvm_chains(plan, node_name)
else:
return cosmvm_node.start_cosmvm_chains(plan, node_name, custom_config["chain_id"], custom_config["key"], custom_config["password"], custom_config["public_grpc"], custom_config["public_http"], custom_config["public_tcp"], custom_config["public_rpc"])
else:
fail("Unknown Chain Type. Expected ['icon','eth','hardhat','cosmwasm']")