Skip to content

Multi-backend: Specify intended chain ID(s) in channel Params/proposal, clarify architecture. #382

Open
@RmbRT

Description

@RmbRT
  1. It is unclear where the channel is deployed from the proposal and channel params alone. Do we use the same channel ID on multiple chains? If so:

    • Channels should have the chain IDs as an array in their parameters, so that when restoring a channel upon node restart, it is clear where the channel lives.
    • We then also need a scheme for coming up with a global blockchain identifier in the first place.
    • Optional: contracts should check whether the chain ID array in the params contains the contract's chain's ID. But we need to rework the contracts anyway to support the new encoding of the channel parameters.
  2. How are L2 addresses handled on cross-chain channels? If we use incompatible crypto for L2 addresses, we will be unable to construct a channel for both chains, as the chains are unable to verify the signatures or parse the L2 addresses. If we have incompatible L2 crypto, we would have to construct two channels with differing channel IDs (due to differing Params encoding), and those cannot be updated atomically anymore if they require two sets of signatures. This would make cross-chain swaps impossible.

    • The way I see it, we should finally enforce a single off-chain crypto implementation, at least for cross-chain channels. Otherwise, I see no way to have secure and atomic commitments to a new channel state, as the proposer has to sign for both chains, but the other party may just sign the state update for one chain and withhold the signature for the other chain, allowing him to break atomicity of asset updates.
    • We need to properly document the high level concept for multi-chain channels and also how they are realised.

Metadata

Metadata

Assignees

No one assigned

    Labels

    bugSomething isn't working

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions