Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: icon cosmos integration #146

Merged
merged 30 commits into from
Aug 28, 2023
Merged
Show file tree
Hide file tree
Changes from 26 commits
Commits
Show all changes
30 commits
Select commit Hold shift + click to select a range
fdd3c9e
feat: update icon and wasm contracts for ibc setup
shreyasbhat0 Aug 20, 2023
35693ac
feat: implement methods to deploy wasm contracts
shreyasbhat0 Aug 20, 2023
272d711
feat: implement contract mehtods for icon ibc
shreyasbhat0 Aug 20, 2023
1e6e9b8
feat: update contract deployment for ibc setup
shreyasbhat0 Aug 21, 2023
a540e47
chore: update code
Prathiksha-Nataraja Aug 21, 2023
bdbbeee
feat: update main.star file
shreyasbhat0 Aug 21, 2023
570beaa
chore:update code
Prathiksha-Nataraja Aug 21, 2023
8a9b868
feat: update contract deployment
shreyasbhat0 Aug 21, 2023
6bce84b
chore: add relay service for icon to cosmos
Prathiksha-Nataraja Aug 21, 2023
e9279c1
feat: update comos constants
shreyasbhat0 Aug 21, 2023
2354b21
feat: update cosmos relayer for icon to cosmos
shreyasbhat0 Aug 21, 2023
196baf8
fix: remove typos from code
shreyasbhat0 Aug 21, 2023
2f6162b
feat; update keystore for relay setup
shreyasbhat0 Aug 22, 2023
9854210
chore: update main
Prathiksha-Nataraja Aug 22, 2023
d486303
feat: update relay setup for icon comsos
shreyasbhat0 Aug 22, 2023
d904594
feat: add relay start command
shreyasbhat0 Aug 22, 2023
0bfe028
fix: rly start command
shreyasbhat0 Aug 22, 2023
d38a6e8
chore: update icon-ibc-relay image version
shanithkk Aug 23, 2023
595b200
fix: contract setup archway
shreyasbhat0 Aug 23, 2023
7099527
fix: remove debug print statements
shreyasbhat0 Aug 23, 2023
630d2a7
feat: update relay start command
shreyasbhat0 Aug 25, 2023
00a77ae
Merge branch 'main' into feat/icon-cosmos-integration
shreyasbhat0 Aug 28, 2023
eda3097
fix: error when node already running
shreyasbhat0 Aug 28, 2023
0df55e8
fix: help falg for archway chain command
shreyasbhat0 Aug 28, 2023
9789f52
feat: update bridge
shreyasbhat0 Aug 28, 2023
5fb7950
feat: update cosmos package for icon archway
shreyasbhat0 Aug 28, 2023
b2a45f2
chore: bump versions of dive and kurtosis sdk
shreyasbhat0 Aug 28, 2023
1652cc0
fix: typo in user output
shreyasbhat0 Aug 28, 2023
5eaa7b2
feat: update service file writes
shreyasbhat0 Aug 28, 2023
160e5c0
chore: remove print statemet
shreyasbhat0 Aug 28, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 6 additions & 4 deletions cli/commands/chain/types/archway.go
Original file line number Diff line number Diff line change
Expand Up @@ -69,10 +69,10 @@ func NewArchwayCmd(diveContext *common.DiveContext) *cobra.Command {

common.WriteToServiceFile(runResponse.ServiceName, *runResponse)

diveContext.StopSpinner("Archyway Node Started. Please find service details in current working directory(services.json)")
diveContext.StopSpinner("Archdiveway Node Started. Please find service details in current working directory(services.json)")
},
}
archwayCmd.Flags().StringVarP(&config, "config", "c", "", "provide config to start archway node ")
archwayCmd.Flags().StringVarP(&config, "config", "c", "", "path to custom config json file to start archway node ")

return archwayCmd
}
Expand Down Expand Up @@ -170,12 +170,14 @@ func runArchwayWithDefaultServiceConfig(diveContext *common.DiveContext, enclave

}

nodeServiceResponseData, _, _, err := diveContext.GetSerializedData(nodeServiceResponse)
nodeServiceResponseData, services, skippedInstructions, err := diveContext.GetSerializedData(nodeServiceResponse)
if err != nil {

return "", err
diveContext.StopServices(services)
diveContext.FatalError("Starlark Run Failed", err.Error())

}
diveContext.CheckInstructionSkipped(skippedInstructions, "Archway Node Already Running")

return nodeServiceResponseData, nil
}
92 changes: 91 additions & 1 deletion main.star
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ btp_bridge = import_module("github.com/hugobyte/dive/services/bridges/btp/src/br
input_parser = import_module("github.com/hugobyte/dive/package_io/input_parser.star")
cosmvm_node = import_module("github.com/hugobyte/dive/services/cosmvm/cosmvm.star")
cosmvm_relay = import_module("github.com/hugobyte/dive/services/bridges/ibc/src/bridge.star")
cosmvm_relay_setup = import_module("github.com/hugobyte/dive/services/cosmvm/archway/src/relay-setup/contract-configuration.star")

def run(plan, args):
return parse_input(plan, args)
Expand Down Expand Up @@ -48,13 +49,17 @@ def parse_input(plan, args):

return data

elif args["relay"]["name"] == "cosmos":
elif args["relay"]["name"] == "ibc":
data = run_cosmos_ibc_setup(plan, args["relay"])

return data

else:
fail("More Relay Support will be added soon")
if args["action"] == "start_relay":
if args["relay"]["name"] == "ibc":
service_name = args["relay"]["service"]
cosmvm_relay.start_relay(plan,service_name)

def run_node(plan, node_name, args):
if node_name == "icon":
Expand Down Expand Up @@ -245,6 +250,90 @@ def run_cosmos_ibc_setup(plan, args):
config_data = run_cosmos_ibc_relay_for_already_running_chains(plan,links,data.src_config,data.dst_config)
return config_data

if destination_chain == "archway":

src_chain_config = icon_service.start_node_service(plan)
data = {"data":{}}
dst_chain_config = cosmvm_node.start_cosmvm_chains(plan, destination_chain,data)

src_chain_service_name = src_chain_config["service_name"]
dst_chain_service_name = dst_chain_config.service_name

config_data = input_parser.generate_new_config_data(links, src_chain_service_name, dst_chain_service_name,"")

config_data["chains"][src_chain_service_name] = src_chain_config
config_data["chains"][dst_chain_service_name] = dst_chain_config

deploy_icon_contracts = icon_relay_setup.setup_contracts_for_ibc_java(plan,src_chain_config)
icon_register_client = icon_relay_setup.registerClient(plan,src_chain_service_name,deploy_icon_contracts["light_client"],src_chain_config["keystore_path"],src_chain_config["keypassword"],src_chain_config["nid"],src_chain_config["endpoint"],deploy_icon_contracts["ibc_core"])

icon_setup_node.configure_node(plan,src_chain_config)

src_chain_last_block_height = icon_setup_node.get_last_block(plan,src_chain_service_name)

plan.print("source block height %s" % src_chain_last_block_height)

network_name = "{0}-{1}".format("dst_chain_network_name",src_chain_last_block_height)

src_data = {
"name" : network_name,
"owner" : deploy_icon_contracts["ibc_core"]
}

icon_setup_node.open_btp_network(plan,src_chain_service_name,src_data,src_chain_config["endpoint"],src_chain_config["keystore_path"], src_chain_config["keypassword"],src_chain_config["nid"])

icon_bind_port = icon_relay_setup.bindPort(plan,src_chain_service_name,deploy_icon_contracts["xcall_connection"],src_chain_config["keystore_path"],src_chain_config["keypassword"],src_chain_config["nid"],src_chain_config["endpoint"],deploy_icon_contracts["ibc_core"],"xcall")

deploy_archway_contracts = cosmvm_relay_setup.setup_contracts_for_ibc_wasm(plan,dst_chain_service_name,dst_chain_config.chain_id,dst_chain_config.chain_key,dst_chain_config.chain_id,"stake","xcall")

cosmvm_relay_setup.registerClient(plan,dst_chain_service_name,dst_chain_config.chain_id,dst_chain_config.chain_key,deploy_archway_contracts["ibc_core"],deploy_archway_contracts["light_client"])

plan.wait(service_name=dst_chain_service_name,recipe=ExecRecipe(command=["/bin/sh","-c","sleep 10s && echo 'success'"]),field="code",assertion="==",target_value=0,timeout="200s")

cosmvm_relay_setup.bindPort(plan,dst_chain_service_name,dst_chain_config.chain_id,dst_chain_config.chain_key,deploy_archway_contracts["ibc_core"],deploy_archway_contracts["xcall_connection"])


config_data["contracts"][src_chain_service_name] = deploy_icon_contracts
config_data["contracts"][dst_chain_service_name] = deploy_archway_contracts

src_chain_data = {
"chain_id": "0xacbc4e",
"rpc_address": src_chain_config["endpoint"],
"ibc_address": deploy_icon_contracts["ibc_core"],
"password" : src_chain_config["keypassword"]
}
dst_chain_data = {
"chain_id": dst_chain_config.chain_id,
"key": dst_chain_config.chain_key,
"rpc_address": dst_chain_config.endpoint,
"ibc_address": deploy_archway_contracts["ibc_core"],
"service_name": dst_chain_config.service_name
}
relay_service_response = cosmvm_relay.start_cosmos_relay_for_icon_to_cosmos(plan,src_chain_data,dst_chain_data)
path_name = cosmvm_relay.setup_relay(plan,src_chain_data,dst_chain_data)

relay_data = cosmvm_relay.get_relay_path_data(plan,relay_service_response.service_name,path_name)

dapp_result_java = icon_relay_setup.deploy_and_configure_dapp_java(plan,src_chain_config,deploy_icon_contracts["xcall"],dst_chain_config.chain_id,deploy_icon_contracts["xcall_connection"],deploy_archway_contracts["xcall_connection"],src_chain_service_name,src_chain_config["endpoint"],src_chain_config["keystore_path"],src_chain_config["keypassword"],src_chain_config["nid"])

dapp_result_wasm = cosmvm_relay_setup.deploy_and_configure_xcall_dapp(plan,dst_chain_service_name,dst_chain_config.chain_id,dst_chain_config.chain_key,deploy_archway_contracts["xcall"],deploy_archway_contracts["xcall_connection"],deploy_icon_contracts["xcall_connection"],src_chain_config["network"])


cosmvm_relay_setup.configure_connection_for_wasm(plan,dst_chain_service_name,dst_chain_config.chain_id,dst_chain_config.chain_key,deploy_archway_contracts["xcall_connection"],relay_data.dst_connection_id,"xcall",src_chain_config["network"],relay_data.dst_client_id,deploy_archway_contracts["xcall"])

icon_relay_setup.configure_connection_for_java(plan,deploy_icon_contracts["xcall"],deploy_icon_contracts["xcall_connection"],dst_chain_config.chain_id,relay_data.src_connection_id,"xcall",dst_chain_config.chain_id,relay_data.src_client_id,src_chain_service_name,src_chain_config["endpoint"],src_chain_config["keystore_path"],src_chain_config["keypassword"],src_chain_config["nid"])


config_data["contracts"][src_chain_service_name]["dapp"] = dapp_result_java["xcall_dapp"]
config_data["contracts"][dst_chain_service_name]["dapp"] = dapp_result_wasm["xcall_dapp"]

cosmvm_relay.start_channel(plan,relay_service_response.service_name,path_name,"xcall","xcall")


return config_data



def run_cosmos_ibc_relay_for_already_running_chains(plan,links,src_config,dst_config):

src_chain_service_name = src_config["service_name"]
Expand All @@ -260,3 +349,4 @@ def run_cosmos_ibc_relay_for_already_running_chains(plan,links,src_config,dst_co
cosmvm_relay.start_cosmos_relay(plan, src_chain_key, src_chain_id, dst_chain_key, dst_chain_id, src_config, dst_config)

return config_data

15 changes: 11 additions & 4 deletions package_io/constants.star
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
ICON_NODE_CLIENT = struct(
node_image = "iconloop/goloop-icon:v1.3.8",
node_image = "iconloop/goloop-icon:v1.3.9",
config_files_directory = "/goloop/config/",
contracts_directory = "/goloop/contracts/",
keystore_directory = "/goloop/keystores/",
Expand Down Expand Up @@ -44,7 +44,7 @@ ARCHWAY_SERVICE_CONFIG = struct(
start_script = "github.com/hugobyte/dive/services/cosmvm/archway/static_files/start.sh",
default_contract_path = "github.com/hugobyte/dive/services/cosmvm/archway/static_files/contracts",
service_name = "node-service",
image = "archwaynetwork/archwayd:constantine",
image = "archwaynetwork/archwayd:v2.0.0",
path = "/start-scripts/",
contract_path = "/root/contracts/",
config_files = "github.com/hugobyte/dive/services/cosmvm/archway/static_files/config/",
Expand All @@ -58,6 +58,13 @@ IBC_RELAYER_SERVICE = struct(
relay_service_image = "hugobyte/ibc-relay:v0.1",
relay_config_files_path = "/script/",
run_file_path = "github.com/hugobyte/dive/services/bridges/ibc/static-files/run.sh",
relay_service_image_icon_to_cosmos = "hugobyte/icon-ibc-relay:v0.1",
relay_service_name_icon_to_cosmos = "ibc-relayer",
config_file_path = "github.com/hugobyte/dive/services/bridges/ibc/static-files/config",
ibc_relay_wasm_file_template = "github.com/hugobyte/dive/services/bridges/ibc/static-files/config/archwayibc.json.tpl",
ibc_relay_java_file_template = "github.com/hugobyte/dive/services/bridges/ibc/static-files/config/icon.json.tpl",
icon_keystore_file = "github.com/hugobyte/dive/services/bridges/btp/static-files/keystores/keystore.json",
relay_keystore_path = "/root/.relayer/keys/"
)

NETWORK_PORT_KEYS_AND_IP_ADDRESS = struct(
Expand All @@ -69,12 +76,12 @@ NETWORK_PORT_KEYS_AND_IP_ADDRESS = struct(
)

ARCHAY_NODE0_CONFIG = struct(
chain_id = "archway-node-0",
chain_id = "constantine-3",
grpc = 9090,
http = 9091,
tcp = 26656,
rpc = 4564,
key = "archway-node-0-key",
key = "constantine-3-key",

)

Expand Down
19 changes: 17 additions & 2 deletions package_io/input_parser.star
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,9 @@ def get_args_data(args):
)

def generate_new_config_data(links, srcchain_service_name, dst_chain_service_name, bridge):
config_data = {
config_data = ""
if bridge == "":
config_data = {
"links": links,
"chains": {
"%s" % srcchain_service_name: {},
Expand All @@ -48,8 +50,21 @@ def generate_new_config_data(links, srcchain_service_name, dst_chain_service_nam
"%s" % srcchain_service_name: {},
"%s" % dst_chain_service_name: {},
},
}
else:

config_data = {
"links": links,
"chains": {
"%s" % srcchain_service_name: {},
"%s" % dst_chain_service_name: {},
},
"contracts": {
"%s" % srcchain_service_name: {},
"%s" % dst_chain_service_name: {},
},
"bridge": bridge,
}
}

return config_data

Expand Down
158 changes: 158 additions & 0 deletions services/bridges/ibc/src/bridge.star
Original file line number Diff line number Diff line change
Expand Up @@ -59,3 +59,161 @@ def start_cosmos_relay(plan, src_key, src_chain_id, dst_key, dst_chain_id, src_c
return struct(
service_name = ibc_relay_config.relay_service_name,
)

def start_cosmos_relay_for_icon_to_cosmos(plan,src_chain_config,dst_chain_config):

plan.print("starting the cosmos relay for icon to cosmos")

plan.upload_files(src=ibc_relay_config.config_file_path, name="archway_config")
plan.upload_files(src=ibc_relay_config.icon_keystore_file,name="icon-keystore")

wasm_config = read_file(ibc_relay_config.ibc_relay_wasm_file_template)
java_config = read_file(ibc_relay_config.ibc_relay_java_file_template)

cfg_template_data_wasm = {
"KEY": dst_chain_config["key"],
"CHAINID": dst_chain_config["chain_id"],
"RPCADDRESS":dst_chain_config["rpc_address"],
"IBCADDRESS":dst_chain_config["ibc_address"],
}

cfg_template_data_java = {
"CHAINID": src_chain_config["chain_id"],
"RPCADDRESS":src_chain_config["rpc_address"],
"IBCADDRESS":src_chain_config["ibc_address"],
}

plan.render_templates(
config = {
"%s.json" % src_chain_config["chain_id"] : struct(
template = java_config,
data = cfg_template_data_java,
),
},
name = "config-%s" % src_chain_config["chain_id"],
)

plan.render_templates(
config = {
"%s.json" % dst_chain_config["chain_id"]: struct(
template = wasm_config,
data = cfg_template_data_wasm,
),
},
name = "config-%s" % dst_chain_config["chain_id"],
)



relay_service = ServiceConfig(
image= ibc_relay_config.relay_service_image_icon_to_cosmos,
files= {
ibc_relay_config.relay_config_files_path + "java": "config-%s" % src_chain_config["chain_id"],
ibc_relay_config.relay_config_files_path + "wasm": "config-%s" % dst_chain_config["chain_id"],
ibc_relay_config.relay_keystore_path + src_chain_config["chain_id"] : "icon-keystore"
},
entrypoint=["/bin/sh"]
)



plan.add_service(name = ibc_relay_config.relay_service_name_icon_to_cosmos, config = relay_service)



return struct(
service_name = ibc_relay_config.relay_service_name_icon_to_cosmos,
)

def setup_relay(plan,src_chain_config,dst_chain_config):

src_chain_id = src_chain_config["chain_id"]
src_password = src_chain_config["password"]

dst_chain_id = dst_chain_config["chain_id"]
dst_chain_key = dst_chain_config["key"]
dst_chain_service_name = dst_chain_config["service_name"]

plan.exec(service_name= ibc_relay_config.relay_service_name_icon_to_cosmos, recipe=ExecRecipe(command=["/bin/sh", "-c", "apk add yq"]))

seed = plan.exec(service_name=dst_chain_service_name, recipe=ExecRecipe(command=["/bin/sh", "-c", "jq -r '.mnemonic' ../../start-scripts/key_seed.json | tr -d '\n\r'"]))
plan.print("starting the relay")

plan.exec(service_name= ibc_relay_config.relay_service_name_icon_to_cosmos, recipe=ExecRecipe(command=["/bin/sh", "-c", "rly config init"]))

plan.print("Adding the chain1")

plan.exec(service_name=ibc_relay_config.relay_service_name_icon_to_cosmos, recipe=ExecRecipe(command=["/bin/sh", "-c", "rly chains add --file ../script/wasm/%s.json %s" % (dst_chain_id,dst_chain_id)]))

plan.print("Adding the chain2")

plan.exec(service_name=ibc_relay_config.relay_service_name_icon_to_cosmos, recipe=ExecRecipe(command=["/bin/sh", "-c", "rly chains add --file ../script/java/%s.json %s" % (src_chain_id,src_chain_id)]))


plan.print("Adding the keys")

plan.exec(service_name=ibc_relay_config.relay_service_name_icon_to_cosmos, recipe=ExecRecipe(command=["/bin/sh", "-c", "rly keys restore %s %s '%s' " % (dst_chain_id,dst_chain_key,seed["output"])]))


plan.print("Adding the paths")

path_name = "{0}-{1}".format(src_chain_id,dst_chain_id)

plan.exec(service_name=ibc_relay_config.relay_service_name_icon_to_cosmos, recipe=ExecRecipe(command=["/bin/sh", "-c", "rly paths new %s %s %s" % (src_chain_id,dst_chain_id,path_name)]))

plan.exec(service_name=ibc_relay_config.relay_service_name_icon_to_cosmos, recipe=ExecRecipe(command=["/bin/sh", "-c", "rly tx clients %s --client-tp 2000000m -d" % path_name]))

plan.exec(service_name=ibc_relay_config.relay_service_name_icon_to_cosmos, recipe=ExecRecipe(command=["/bin/sh", "-c", "rly tx connection %s" % path_name]))

return path_name


def get_relay_path_data(plan,service_name,path_name):

src_chain_id_response = plan.exec(service_name=service_name,recipe=ExecRecipe(command=["/bin/sh","-c","cat /root/.relayer/config/config.yaml | yq '.paths.%s.src.chain-id'" % path_name]))
execute_cmd = ExecRecipe(command=["/bin/sh", "-c","echo \"%s\" | tr -d '\n\r'" % src_chain_id_response["output"] ])
src_chain_id = plan.exec(service_name=service_name,recipe=execute_cmd)

src_client_id_response = plan.exec(service_name=service_name,recipe=ExecRecipe(command=["/bin/sh","-c","cat /root/.relayer/config/config.yaml | yq '.paths.%s.src.client-id'" % path_name]))
execute_cmd = ExecRecipe(command=["/bin/sh", "-c","echo \"%s\" | tr -d '\n\r'" % src_client_id_response["output"] ])
src_client_id = plan.exec(service_name=service_name,recipe=execute_cmd)

src_connection_id_response = plan.exec(service_name=service_name,recipe=ExecRecipe(command=["/bin/sh","-c","cat /root/.relayer/config/config.yaml | yq '.paths.%s.src.connection-id'" % path_name]))
execute_cmd = ExecRecipe(command=["/bin/sh", "-c","echo \"%s\" | tr -d '\n\r'" % src_connection_id_response["output"] ])
src_connection_id = plan.exec(service_name=service_name,recipe=execute_cmd)


dst_chain_id_response = plan.exec(service_name=service_name,recipe=ExecRecipe(command=["/bin/sh","-c","cat /root/.relayer/config/config.yaml | yq '.paths.%s.dst.chain-id'" % path_name]))
execute_cmd = ExecRecipe(command=["/bin/sh", "-c","echo \"%s\" | tr -d '\n\r'" % dst_chain_id_response["output"] ])
dst_chain_id = plan.exec(service_name=service_name,recipe=execute_cmd)

dst_client_id_response = plan.exec(service_name=service_name,recipe=ExecRecipe(command=["/bin/sh","-c","cat /root/.relayer/config/config.yaml | yq '.paths.%s.dst.client-id'" % path_name]))
execute_cmd = ExecRecipe(command=["/bin/sh", "-c","echo \"%s\" | tr -d '\n\r'" % dst_client_id_response["output"] ])
dst_client_id = plan.exec(service_name=service_name,recipe=execute_cmd)

dst_connection_id_response = plan.exec(service_name=service_name,recipe=ExecRecipe(command=["/bin/sh","-c","cat /root/.relayer/config/config.yaml | yq '.paths.%s.dst.connection-id'" % path_name]))
execute_cmd = ExecRecipe(command=["/bin/sh", "-c","echo \"%s\" | tr -d '\n\r'" % dst_connection_id_response["output"] ])
dst_connection_id = plan.exec(service_name=service_name,recipe=execute_cmd)

config = struct(
src_chain_id = src_chain_id["output"],
src_client_id = src_client_id["output"],
src_connection_id = src_connection_id["output"],
dst_chain_id = dst_chain_id["output"],
dst_client_id = dst_client_id["output"],
dst_connection_id = dst_connection_id["output"]
)

return config

def start_channel(plan,service_name,path_name,src_port,dst_port):
plan.print("Starting Channel")

exec_cmd = ["/bin/sh","-c","rly tx chan %s --src-port=%s --dst-port=%s" % (path_name,src_port,dst_port)]

plan.exec(service_name=service_name,recipe=ExecRecipe(command=exec_cmd))

def start_relay(plan,service_name):

plan.print("Starting Relay")
plan.exec(service_name=service_name,recipe=ExecRecipe(command=["/bin/sh","-c","ln -sf /proc/1/fd/1 /root/.relayer/relay.log && rly start 1>&2"]))
Loading