Skip to content

Conversation

@sophia1ch
Copy link
Contributor

Description

This PR introduces the functionality of using multiple backends that implement the go-perun backend. This functionality includes:

  • using maps of addresses for each user (one address per backend)
  • using maps of channel IDs
  • backendID to differentiate the backends being used
  • adjustments in the state and params

These changes allow for EVM to non-EVM payment-channels.

feat(Asset, Adjudicator): Add AssetID struct to identify assets with LedgerID and BackendID
feat(persistence, wire): Use map[int]Address to identify clients

Signed-off-by: Sophia Koehler <sophia@perun.network>
…and adjudicators.

fix(randomizer): Lookup backend opts to correctly initialize address maps.
fix(test): Generalize tests to be used in other backends.

Signed-off-by: Sophia Koehler <sophia@perun.network>
Signed-off-by: Sophia Koehler <sophia@perun.network>
Signed-off-by: Sophia Koehler <sophia@perun.network>
fix(wallet/wallet, wallet/account): Revert changed definition.
feat(client): Add wallet map to client for each backend.

Signed-off-by: Sophia Koehler <sophia@perun.network>
Signed-off-by: Sophia Koehler <sophia@perun.network>
Signed-off-by: Sophia Koehler <sophia@perun.network>
feat(client/test, wire): Add backendID arguments.

Signed-off-by: Sophia Koehler <sophia@perun.network>
Signed-off-by: Sophia Koehler <sophia@perun.network>
Signed-off-by: Sophia Koehler <sophia@perun.network>
…t, ): Specify backend for randomizers

feat(channel/multi): Change AssetID to interface
feat(channel/persistence, client/test): Generalize test for backends

Signed-off-by: Sophia Koehler <sophia@perun.network>
…ad of string.

fix(params.go): Change IDKey to encode map entries sorted by keys.
fix(backend.go): Use BackendID in argument to sign depending on backend.
fix(address.go): Sort Addresses by keys before adding them to Keys.

Signed-off-by: Sophia Koehler <sophia@perun.network>
Signed-off-by: Sophia Koehler <sophia@perun.network>
Signed-off-by: Sophia Koehler <sophia@perun.network>
@sophia1ch sophia1ch marked this pull request as ready for review December 18, 2024 07:18
@sophia1ch sophia1ch marked this pull request as draft December 18, 2024 07:36
@sophia1ch sophia1ch marked this pull request as ready for review December 18, 2024 09:21
Signed-off-by: Sophia Koehler <sophia@perun.network>
Signed-off-by: Sophia Koehler <sophia@perun.network>
…n of errors

chore(All): Run gofmt and sort imports

Signed-off-by: Sophia Koehler <sophia@perun.network>
chore: Refactor for linter

Signed-off-by: Sophia Koehler <sophia@perun.network>
fix(golangci): Fix structure

Signed-off-by: Sophia Koehler <sophia@perun.network>
Signed-off-by: Sophia Koehler <sophia@perun.network>
Signed-off-by: Sophia Koehler <sophia@perun.network>
Signed-off-by: Sophia Koehler <sophia@perun.network>
Signed-off-by: Sophia Koehler <sophia@perun.network>
Signed-off-by: Sophia Koehler <sophia@perun.network>
Signed-off-by: Sophia Koehler <sophia@perun.network>
Signed-off-by: Sophia Koehler <sophia@perun.network>
Signed-off-by: Sophia Koehler <sophia@perun.network>
Signed-off-by: Sophia Koehler <sophia@perun.network>
Signed-off-by: Sophia Koehler <sophia@perun.network>
Signed-off-by: Sophia Koehler <sophia@perun.network>
@sophia1ch
Copy link
Contributor Author

Description

This PR introduces the functionality of using multiple backends that implement the go-perun backend. This functionality includes:

  • using maps of addresses for each user (one address per backend)
  • using maps of channel IDs
  • backendID to differentiate the backends being used
  • adjustments in the state and params

These changes allow for EVM to non-EVM payment-channels.

Additionally, I updated the CI configuration to use Go 1.18 due to compatibility issues with the auto-generated proto file. Updating directly to Go 1.22 introduced several additional errors, primarily related to the linter. A separate issue has been created to address the Go 1.22 update.

Signed-off-by: Sophia Koehler <sophia@perun.network>
@iljabvh iljabvh self-requested a review January 7, 2025 15:59
This was referenced Jan 14, 2025
…e): Name test backend ID in tests

refactor(/multi, /client/test): Rename AssetID to MultiLedgerID

Signed-off-by: Sophia Koehler <sophia@perun.network>
Signed-off-by: Sophia Koehler <sophia@perun.network>
Signed-off-by: Sophia Koehler <sophia@perun.network>
Signed-off-by: Sophia Koehler <sophia@perun.network>
Signed-off-by: Sophia Koehler <sophia@perun.network>
fix: revert increased timeouts

Signed-off-by: Sophia Koehler <sophia@perun.network>
@sophia1ch sophia1ch merged commit b53c36b into hyperledger-labs:main Jan 29, 2025
7 checks passed
@sophia1ch sophia1ch deleted the feat-mult-backends branch January 29, 2025 09:35
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants