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 multiple backends #410

Open
wants to merge 31 commits into
base: main
Choose a base branch
from

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 <[email protected]>
…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 <[email protected]>
Signed-off-by: Sophia Koehler <[email protected]>
fix(wallet/wallet, wallet/account): Revert changed definition.
feat(client): Add wallet map to client for each backend.

Signed-off-by: Sophia Koehler <[email protected]>
feat(client/test, wire): Add backendID arguments.

Signed-off-by: Sophia Koehler <[email protected]>
…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 <[email protected]>
…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 <[email protected]>
Signed-off-by: Sophia Koehler <[email protected]>
@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
…n of errors

chore(All): Run gofmt and sort imports

Signed-off-by: Sophia Koehler <[email protected]>
chore: Refactor for linter

Signed-off-by: Sophia Koehler <[email protected]>
fix(golangci): Fix structure

Signed-off-by: Sophia Koehler <[email protected]>
@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.

@iljabvh iljabvh self-requested a review January 7, 2025 15:59
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.

1 participant