Skip to content

Commit

Permalink
better handle multiple bridge situation
Browse files Browse the repository at this point in the history
  • Loading branch information
mvadari committed Oct 25, 2023
1 parent 4b5088b commit 2ae95f0
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 8 deletions.
2 changes: 0 additions & 2 deletions tests/bridge/test_register.py
Original file line number Diff line number Diff line change
Expand Up @@ -75,7 +75,6 @@ def test_register(self):
send_wallet.seed,
"--to",
wallet_to_create.classic_address,
"--verbose",
],
)
assert runner_result.exit_code == 0, runner_result.output
Expand Down Expand Up @@ -155,7 +154,6 @@ def test_register_bootstrap(self):
send_wallet.seed,
"--to",
wallet_to_create.classic_address,
"--verbose",
],
)
assert runner_result.exit_code == 0, runner_result.output
Expand Down
29 changes: 23 additions & 6 deletions xbridge_cli/bridge/register.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,10 +20,16 @@ def _get_account_objects(


# TODO: add support for door accounts that have multiple bridges
def _get_bridge(client: JsonRpcClient, door_account: str) -> Dict[str, Any]:
# TODO: filter by bridge when that's implemented
objects = _get_account_objects(client, door_account)
bridge_objects = [obj for obj in objects if obj["LedgerEntryType"] == "Bridge"]
def _get_bridge(
client: JsonRpcClient, door_account: str, currency: str
) -> Dict[str, Any]:
objects = _get_account_objects(client, door_account, AccountObjectType.BRIDGE)
bridge_objects = [
obj
for obj in objects
if obj["XChainBridge"]["LockingChainIssue"]["currency"] == currency
]
assert len(bridge_objects) == 1
return bridge_objects[0]


Expand Down Expand Up @@ -86,6 +92,14 @@ def _get_bootstrap_chain_and_door(chain_json: Dict[str, Any]) -> Tuple[str, str]
"issuing_chain_door)."
),
)
@click.option(
"--currency",
type=str,
default="XRP",
help=(
"The currency that is being transferred across the bridge. The default is XRP."
),
)
@click.option(
"-v",
"--verbose",
Expand All @@ -97,6 +111,7 @@ def register_bridge(
chains: Optional[Tuple[str, str]],
doors: Optional[Tuple[str, str]],
bootstrap: Optional[str],
currency: str = "XRP",
verbose: int = 0,
) -> None:
"""
Expand All @@ -107,6 +122,8 @@ def register_bridge(
name: The name of the bridge (only used locally).
chains: The locking chain and issuing chain.
doors: The locking chain door and issuing chain door.
currency: The currency that is being transferred across the bridge. The default
is XRP.
bootstrap: The bootstrap file.
verbose: Whether or not to print more verbose information.
Expand Down Expand Up @@ -153,8 +170,8 @@ def register_bridge(
quorum = signer_list1["SignerQuorum"]

# TODO: determine whether the bridge was set up properly.
bridge1 = _get_bridge(locking_client, doors[0])
bridge2 = _get_bridge(issuing_client, doors[1])
bridge1 = _get_bridge(locking_client, doors[0], currency)
bridge2 = _get_bridge(issuing_client, doors[1], currency)
assert bridge1["XChainBridge"] == bridge2["XChainBridge"]
assert bridge1["XChainAccountCreateCount"] == bridge2["XChainAccountClaimCount"]
assert bridge2["XChainAccountCreateCount"] == bridge1["XChainAccountClaimCount"]
Expand Down

0 comments on commit 2ae95f0

Please sign in to comment.