Skip to content
This repository has been archived by the owner on Nov 8, 2023. It is now read-only.

Commit

Permalink
Merge pull request #140 from statechannels/future-work
Browse files Browse the repository at this point in the history
Update README. Add 'Future work' section
  • Loading branch information
bitwiseguy authored Oct 18, 2023
2 parents b87fc7e + bae52a2 commit 4c08574
Showing 1 changed file with 35 additions and 13 deletions.
48 changes: 35 additions & 13 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
SCBridge-Wallet
</h1>
<h3 align="center">
An L2 state channel bridge contract which is also an EIP-4337 compliant smart contract wallet.
An L2 state channel bridge contract which is also an ERC-4337 compliant smart contract wallet.
</h3>

# How to Run
Expand All @@ -14,30 +14,41 @@ An L2 state channel bridge contract which is also an EIP-4337 compliant smart co

### Ingredients

This repo contains Solidity source code for a novel type of state channel bridge smart contract. It offers the unique feature that deposited funds can not only be used to send offchain payments to other channel network participants with zero fees and instant finality, but also to send arbitrary transactions on the underlying L1 blockchain without having to withdraw them first in a separate transaction.
This repo contains Solidity source code for a state channel bridge smart contract. It uniquely offers the ability to use deposited funds not only to send offchain payments to other channel network participants with zero fees and instant finality, but also to send arbitrary transactions on the underlying L1 blockchain without having to withdraw them first in a separate transaction.

This functionality is achieved by inviting a channel network peer to be a co-signatory "guest" on your smart contract wallet. L1 transactions are first send to that "guest", who countersigns them and submits them to the mempool. The guest therefore plays a role similar to an EIP 4337 "bundler" (only simpler). Although the "guest" can be ejected at any time (and then either replaced with another guest, or not), they have the right to veto any L1 transaction. This allows them to ensure they retain any off chain payments promised to them by the wallet owner. If they are ejected, they get to take that money with them.
This functionality is achieved by inviting a channel network peer to be a co-signatory Intermediary on your smart contract wallet. L1 transactions are first send to that Intermediary, who countersigns them and submits them to the mempool. The Intermediary therefore plays a role similar to an ERC-4337 "bundler" (only simpler). The Intermediary has the right to veto any L1 transaction, although they can be ejected at any time (and then either replaced with another Intermediary, or not). This allows them to ensure they retain any off-chain payments promised to them by the wallet owner. If they are ejected, they get to take that money with them.

By having that guest perform the same role in several users' smart contract wallets, the off chain payments can be routed over arbitrary hops through a payment network (a la Bitcoin Lightning).
By having that Intermediary perform the same role in several users' smart contract wallets, the off-chain payments can be routed over arbitrary hops through a payment network (a la Bitcoin Lightning).

This repo also contains Typescript source code for off-chain clients that can be run by a user and by a guest, to enable to orchestrate the functionality described above.
This repo also contains Typescript source code for off-chain clients that can be run by a user and by a Intermediary, to enable to orchestrate the functionality described above.

### Method
### Quickstart

#### User
Run the following sequence of commands to spin up a local demo environment.

#### Guest
```
yarn
yarn chain:local
yarn deploy:local && yarn start
```

These commands do the following:

1. starts a local `hardhat` blockchain network
2. deploys the necessary smart contracts: `EntryPoint`, `SCBridge-Wallet` for Alice, `SCBridge-Wallet` for Bob
3. serves the UI on `http://localhost:5173/`

Open three browser tabs (all accessing `http://localhost:5173/`) and select a different user (Alice, Irene, Bob) for each tab to allow the cross-user messaging to work.

### Sequence Diagram

Alice wants to a) pay Bob offchain and b) execute a trade on uniswap. In a typical state channel bridge architecture (green) she must deposit funds into the ID of a "ledger channel" in a Singleton adjudicator contract. Her counterparty in that ledger channel (Irene) must have deposited into another ledger channel with Bob.
Scenario: Alice wants to (a) pay Bob offchain and (b) execute a trade on Uniswap. Irene is an Intermediary actor.

Executing a mulithop payment from Alice to Bob (white) is then as easy as executing the well known HTLC (Hash Timelocked Contract) protocol.
In a typical state channel bridge architecture (green) she must deposit funds into the ID of a "ledger channel" in a Singleton adjudicator contract. Her counterparty in that ledger channel (Irene) must have deposited into another ledger channel with Bob. If Alice wants to execute her Uniswap trade with those deposited funds, she needs to close the ledger channel, withdraw the funds (in one L1 tx), and submit the trade (in another L1 tx).

If Alice wants to execute her uniswap trade with those deposited funds, she needs to close the ledger channel, withdraw the funds (in one L1 tx), and submit the trade (in another L1 tx).
With the State Channel Bridge Wallet (SCBridge-Wallet) Architecture, she can instead propose the Uniswap trade to Irene, who checks that it doesn't compromise any HTLC payments, and then countersigns it and submits it to Alice's SCBridge-Wallet via en entrypoint contract. The SCBridge-Wallet validates the countersigned transaction and calls into Uniswap to execute the trade.

With the State Channel Bridge Wallet (SCBridge-Wallet) Architecture, she can instead propose the uniswap trade to Irene, who checks that it doesn not compromise any HTLC payments made so far
, and then countersigns it and submits it to Alice's SCBridge-Wallet via en entrypoint contract. The SCBridger-Wallet validates the countersigned transaction and calls into uniswap to execute the trade.
In either case, executing a multihop payment from Alice to Bob (white) is as easy as executing the well known HTLC (Hash Timelocked Contract) protocol, which is the same technology that powers the Bitcoin Lightning Network.

![Sequence Diagram](./SCBridge-Wallet-sequence.png)

Expand Down Expand Up @@ -94,3 +105,14 @@ Irene->Bob: countersigned updated state
Alice->Irene: countersigned updated state
end
-->

### Future work

This repo originated as an entry for the ETHGlobal 2023 hackathon. Therefore some shortcuts were taken to enable an end-to-end demo given the time constraints. The following list identifies future areas for improvement if this foundation was used to build a production-ready application.

1. `Messaging`: currently in-browser [BroadcastChannels](https://nodejs.org/api/worker_threads.html#class-broadcastchannel-extends-eventtarget) are used to communicate between the different users. A proper messaging service should allow users to exchange messages when they are on different machines with different IP addresses. Possible technologies include: WebSockets, WebRTC, HTTP requests, etc.
2. `Key management`: currently the private signing keys used by each user to sign blockchain txs and state channel messages are stored in a static [.env](./.env) file. These keys are read by the browser code and inserted in the the JavaScript running on the page. Since these keys control the movement of funds, they should be stored more securely, i.e. in Metamask or another crypto wallet.
3. `Intermediary funding`: a key requirement for this state channel system to work is that Intermediaries need to ear-mark some of their own funds for end users so that off-chain payments can occur by rebalancing the funds designated for each user. This requires Intermediaries to essentially "lock up" some of their own money. There should be incentives (e.g. payment processing fees) for the Intermediaries to provide this service. [Eigenlayer](https://docs.eigenlayer.xyz/overview/readme) re-staking could also be leveraged to unlock previously unused capital. Ethereum validator users who are already comfortable running reliable infrastructure are the type of actor who would likely be able to provide Intermediary services as well.
4. `Intermediary centralization`: the requirement of an Intermediary actor in this system is a centralizing force. A payment channel network is more performant if end users are connected to the same Intermediary. The ability of the end user to "Eject" and replace an Intermediary is a nice way to mitigate risk and multi-hop payments (i.e. traversing multiple Intermediaries) are possible, but more research should be done to determine if incentives can be designed to reduce the natural draw towards centralization.
5. `User onboarding`: currently there are hardcoded scripts to connect the Intermediary with users and ear-mark some of the Intermediary's funds for Alice and Bob. In a production environment there should be an easy way for end users to discover Intermediaries, and to negotiate how much of the Intermediary funds are ear-marked for their address.
6. `Eject Intermediary`: currently the implementation to "Eject" an Intermediary from a SCBridge-Wallet contract is stubbed out. This is an essential feature for the user to retain permissionless control of their funds.

0 comments on commit 4c08574

Please sign in to comment.