forked from opengsn/gsn
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
OG-899: Rewrite README for the GSN (opengsn#891)
* OG-899: Rewrite README for the GSN * Remove dead links * Add tech stack icons and version, tests shields * Add link to CTF live demo
- Loading branch information
Showing
3 changed files
with
247 additions
and
23 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,24 +1,167 @@ | ||
# GSN, the Ethereum Gas Stations Network | ||
<img src="./logo.svg"> | ||
|
||
[GSN, the Ethereum Gas Station Network](https://opengsn.org/) abstracts away gas to minimize onboarding & UX friction for dapps. With GSN, gasless clients can interact with Ethereum contracts without users needing ETH for transaction fees. The GSN is a decentralized system that improves dapp usability without sacrificing security. | ||
<div> | ||
<img src="https://raw.githubusercontent.com/devicons/devicon/master/icons/typescript/typescript-original.svg" width="40" height="40"/> | ||
<img src="https://raw.githubusercontent.com/devicons/devicon/master/icons/solidity/solidity-original.svg" width="40" height="40"/> | ||
<img src="https://raw.githubusercontent.com/devicons/devicon/master/icons/docker/docker-original-wordmark.svg" width="40" height="40"/> | ||
<img src="https://raw.githubusercontent.com/devicons/devicon/master/icons/nodejs/nodejs-plain-wordmark.svg" width="40" height="40"/> | ||
<img src="https://raw.githubusercontent.com/devicons/devicon/master/icons/webpack/webpack-original-wordmark.svg" width="40" height="40"/> | ||
</div> | ||
|
||
[![<ORG_NAME>](https://circleci.com/gh/opengsn/gsn.svg?style=shield)](<LINK>) | ||
![GitHub package.json version (subfolder of monorepo)](https://img.shields.io/github/package-json/v/opengsn/gsn?filename=packages%2Fprovider%2Fpackage.json) | ||
|
||
|
||
# The Ethereum Gas Stations Network | ||
|
||
[![Join our Discord server!](https://invidget.switchblade.xyz/b5Jk9kWcPG)](http://discord.gg/b5Jk9kWcPG) | ||
|
||
## What is GSN? | ||
[GSN](https://opengsn.org/) is a distributed network of transaction relayers that allows decentralized | ||
applications (daps) to abstract away the process of paying the transaction gas fees to minimize friction during | ||
new user onboarding and to improve the user experience. With GSN, gasless clients can interact with Ethereum contracts | ||
without users needing to own or spend ETH for transaction fees. | ||
|
||
<div id="header" align="center"> | ||
<img src="https://media.giphy.com/media/SreAp5WMZHfhK/giphy.gif" width="450"/> | ||
</div> | ||
|
||
## Architecture Overview | ||
The GSN has a reasonably simple architecture. You should have a basic understanding of what components the GSN project | ||
consists of before you can integrate it into your Dapp. | ||
|
||
The GSN consists of three major components working together: Relay Server, Relay Provider, and GSN Smart Contracts. | ||
The Dapp that wants to integrate the GSN has two smart contracts to support the alternative gas payment logic: | ||
Paymaster and Relay Recipient. | ||
|
||
#### Relay Server | ||
The Relay Server is a Node.js server that accepts Relay Requests and broadcasts them as transactions to the blockchain. | ||
It controls a Relay Worker account key and pays for transaction gas out-of-pocket. It is the GSN Smart Contract's job | ||
to make sure the Relay Server is getting its money back at the end of the transaction. | ||
|
||
#### Relay Provider | ||
The Relay Provider is a Node Module written in TypeScript that can wrap your Ethereum provider (Web3.js, Ethers.js, | ||
MetaMask, WalletConnect, etc.) and route all outgoing transactions through the GSN. | ||
|
||
#### GSN Smart Contracts | ||
All contracts that form the core of the GSN are supposed to be singletons on each network. | ||
Note: Deploying your own GSN contracts is possible, but that creates a separate GSN network. | ||
|
||
##### RelayHub | ||
The RelayHub is the main contract in the GSN. It connects users running clients, relay servers, and paymasters so that | ||
participants don't need to know or trust each other. | ||
|
||
##### Forwarder | ||
The Forwarder contract verifies the sender's signature and nonce. | ||
The Recipient contracts only rely on a small trusted forwarder contract for their security. | ||
|
||
#### Paymaster and Recipient | ||
As sending a transaction on the Ethereum network costs the Relay Server some real money, it has to be compensated. | ||
In the most basic scenario, it is the Dapp developers who will have to subsidize their users' transactions. | ||
In such a case, a decentralized application using GSN has to implement a contract called Paymaster. | ||
This contract keeps an amount of Ether as its own balance in the RelayHub and is charged for the transaction afterward. | ||
|
||
The target contract to which the original transaction was made is called Recipient. | ||
It has to inherit from the `ERC2771Recipient` base contract in order to support being called through the GSN. | ||
|
||
## Installation and Usage | ||
|
||
In order to install the GSN client library | ||
```bash | ||
yarn add @opengsn/provider | ||
``` | ||
|
||
Using it within your application: | ||
```JavaScript | ||
const { RelayProvider } = require('@opengsn/provider') | ||
|
||
// Create a new RelayProvider instance in the place where you normally initialize your Web3.js/Ethers.js provider: | ||
async function getProvider() { | ||
const config = { | ||
paymasterAddress, | ||
loggerConfiguration: { | ||
logLevel: 'debug' | ||
} | ||
} | ||
const provider = await RelayProvider.newProvider({ provider: window.ethereum, config }).init() | ||
} | ||
``` | ||
|
||
Adding `ERC2771Recipient` to your target smart contract: | ||
```solidity | ||
import "@opengsn/contracts/src/ERC2771Recipient"; | ||
contract MyContract is ERC2771Recipient { | ||
constructor(address forwarder) { | ||
_setTrustedForwarder(forwarder); | ||
} | ||
/* the rest of your contract code */ | ||
} | ||
``` | ||
## Developing a Paymaster contract | ||
The GSN cannot predict the exact logic your project needs to implement to decide whether you want to pay for | ||
the transaction or not. We provide some sample Paymaster, but the Paymaster is a part of your application and | ||
the samples provided by the GSN team may or may not fit your use case. | ||
|
||
Here are some of our sample Paymasters: | ||
|
||
### [AcceptEverythingPaymaster](https://github.com/opengsn/gsn/blob/master/packages/paymasters/contracts/AcceptEverythingPaymaster.sol) | ||
This is only a viable approach for testing and will be immediately drained on a real network. | ||
|
||
### [WhitelistPaymaster](https://github.com/opengsn/gsn/blob/master/packages/paymasters/contracts/WhitelistPaymaster.sol) | ||
This Paymaster allows you to specify an array of senders, targets, and methods that will be subsidized by it. | ||
|
||
### [Token + Permit + Uniswap Paymaster](https://github.com/opengsn/gsn/blob/fix-permitTokenPaymaster/packages/paymasters/contracts/PermitERC20UniswapV3Paymaster.sol) | ||
There is no single approach to making transactions be paid for in ERC-20 tokens. | ||
This Paymaster uses a combination of the ERC-2612 `permit` method and a Uniswap v3 to charge users with tokens.<br> | ||
|
||
## Running a Relay Server | ||
Everyone is allowed to join the GSN and act as a Relay Server and it is a fairly simple process. | ||
We provide a `docker-compose` script to do so and the tutorial explaining how to join with a simple cloud | ||
virtual machine instance can be found here:<br> | ||
https://docs.opengsn.org/relay-server/tutorial.html | ||
|
||
## Active deployments | ||
A full list of the networks with active GSN deployments can be found on the dashboard pages. | ||
|
||
For GSN v2:<br> | ||
https://relays-v2.opengsn.org/ | ||
|
||
For GSN v3-beta:<br> | ||
https://relays.opengsn.org/ | ||
|
||
## FAQ | ||
A full list of FAQs can be found here:<br> | ||
https://docs.opengsn.org/faq/general.html | ||
|
||
#### Should dapp developers run their own relay server? | ||
Running a relay server is highly recommended for most use cases. | ||
It will usually save money for dapps to run their own relays. | ||
This way they can avoid having to pay an extra transaction fee to a third party. | ||
Only if the dapp's preferred relay server is unavailable, the clients will seamlessly fall back to another | ||
relayer in the network. This protects against network failures and denial of service attacks. | ||
If a preferred relayer is not configured, all transactions will be routed through third-party relay servers. | ||
|
||
#### We already have our smart contracts deployed. Can we add support for the GSN without redeploying? | ||
Generally speaking, integration with the GSN requires a small modification to the target smart contract to become a | ||
functional Relay Recipient. However, if your smart contracts support a different meta-transactions mechanism, they might | ||
be able to piggyback on the GSN without a need to modify your code. | ||
|
||
#### Can users who have no Ether transfer ERC-20 tokens with GSN? | ||
Only ERC-20 tokens that also support the ERC-2612 `permit` method can be used gaslessly. The basic ERC-20 standard does not | ||
include any support for meta-transactions and requires at least a single call to `approve` method to be paid by the sender. | ||
|
||
## Resources | ||
|
||
* [GSN documentation](https://docs.opengsn.org/) | ||
* [GSN support forum](https://forum.opengsn.org/) | ||
* [GSN protocol specification](https://github.com/opengsn/gsn-protocol/blob/master/gsn-protocol.md) | ||
|
||
### On GitHub | ||
|
||
* [GSN example integration](https://github.com/opengsn/workshop) | ||
* [GSN example react dapp](https://github.com/opengsn/ctf-react) | ||
* [GSN example paymasters](https://github.com/opengsn/gsn-paymasters) | ||
|
||
## Live demo | ||
|
||
Mint and send tokens without requiring ETH for gas. Works on Ropsten and Kovan testnets. | ||
|
||
Try it: https://metacoin.opengsn.org/ | ||
|
||
Source: https://github.com/opengsn/metacoin | ||
|
||
Make a transaction and capture the flag on-chain without paying for gas. [Try it now!](https://ctf-react.opengsn.org/) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -9,16 +9,6 @@ | |
"**ts-node**" | ||
] | ||
}, | ||
"version": "2.2.2", | ||
"description": "Open Gas Stations Network", | ||
"name": "@opengsn/gsn", | ||
"engines": { | ||
"node": ">=11.0.0" | ||
}, | ||
"repository": { | ||
"url": "https://github.com/opengsn/gsn", | ||
"type": "git" | ||
}, | ||
"contributors": [ | ||
{ | ||
"name": "Dror Tirosh", | ||
|
@@ -37,9 +27,6 @@ | |
"email": "[email protected]" | ||
} | ||
], | ||
"bin": { | ||
"gsn": "dist/src/cli/commands/gsn.js" | ||
}, | ||
"scripts": { | ||
"test": "yarn preprocess && yarn lerna-run-test-with-hardhat", | ||
"hardhat-fork-mainnet": "CHAINID=1 hardhat node --port 8544 --fork https://mainnet.infura.io/v3/f40be2b1a3914db682491dc62a19ad43 --fork-block-number 15404620", | ||
|