swarms/ideas/150-gas-abstraction.md

116 lines
4.6 KiB
Markdown
Raw Normal View History

---
id: 150-gas-abstraction
title: Gas Abstraction
status: Draft
created: 2018-02-01
category: core
lead-contributor: 3esmit
contributors:
- 3esmit
- richard-ramos
- iurimatias
- alexvandesande
exit-criteria: no
success-metrics: yes
clear-roles: yes
future-iterations: no
---
2018-04-07 02:24:34 -03:00
# Gas Abstraction
2018-04-06 23:13:16 -03:00
## Preamble
2018-04-07 03:22:00 -03:00
Idea: 150-gas-abstraction
2018-04-06 23:13:16 -03:00
Title: Gas Abstraction
2018-04-12 00:57:02 -03:00
Status: Draft
2018-04-06 23:13:16 -03:00
Created: 2018-02-01
2018-04-07 02:24:34 -03:00
Requires: 145-identity
2018-04-10 23:41:32 -03:00
Replaces: 073-economic-abstraction
2018-04-06 23:13:16 -03:00
## Summary
Enable Status users to pay gas fee with any token that is valueable to society.
2018-04-07 04:11:44 -03:00
Users would sign a message request to contracts which will use user's Identity balance of selected token to refund proportional used gas to a incentivezed ETH owner to include that message in a transction.
2018-04-06 23:13:16 -03:00
## Swarm Participants
2018-04-07 03:57:28 -03:00
- Lead Contributor: Ricardo Guilherme Schmidt
- Contributor: Richard Ramos
- Contributor: Iuri Matias
- UX (Mist): Alexandre Van de Sande
2018-04-10 23:41:32 -03:00
- UX (Status): (help needed)
2018-04-07 03:57:28 -03:00
2018-04-06 23:31:37 -03:00
2018-04-06 23:13:16 -03:00
## Product Overview
A barrier for user adoption to blockchain through Status would be the need of holding two tokens for paying fees, ether gas for moving the [SNT](https://etherscan.io/address/0x744d70fdbe2ba4cf95131626614a1763df805b9e#readContract) fee from user balance to decentralized service provider.
The product solve this by emulating a gas abstraction by adding "Gas Relayer Actor" in top of smart contracts as: [Identity](https://github.com/status-im/contracts/blob/73-economic-abstraction/contracts/identity/Identity.sol)[GasRelay](https://github.com/status-im/contracts/blob/73-economic-abstraction/contracts/identity/IdentityGasRelay.sol), MultiSigWallet, [SNTController](https://github.com/status-im/contracts/blob/73-economic-abstraction/contracts/status/SNTController.sol#L82) (updated from SNTPlaceHolder).
- Allows SNT holder to broadcast ethereum signed messages to anyone with ETH to validate them in the GasRelay smart contracts, and offering a refund of gas used in a gas price set in SNT.
- Whoever have ether could verify if the gas price worth the SNT gas price offered.
- This becomes a micro trade of ETH->SNT.
- Allow user to use any token they want (even ETH, or ETH stored in Identity).
### Product Description
2018-04-10 23:41:32 -03:00
Gas Relay node:
- Status Destkop extension or an independent node can include messages by making automatic transactions calls to smart contracts to earn tokens being offered as gas price refund.
- Configuration for tokens accepted and types of contract willing to interact with.
Important as fundamental pivot actor.
2018-04-06 23:13:16 -03:00
2018-04-10 23:41:32 -03:00
Identity Gas Relay adaptor:
- include smart contract terms for accepting ethereum signed messages representing authorization to call by/for Identity owner offering a gas price refund for relayer.
- Identity UI should allow user to choose what token it wants to use as gas price.
Important for gas abstraction of call.
2018-04-06 23:13:16 -03:00
2018-04-10 23:41:32 -03:00
SNTController Gas Relay adaptor:
- include smart contract terms for accepting ethereum signed messages to call `IdentityGasRelayFactory` and for moving the tokens from there using SNT controller contract.
- a "wizard" UI would make the calls to create a Identity and send user SNT to Identity (so it can be used as ether gas).
Important for opt-in gas abstraction without ever holding ether.
2018-04-06 23:13:16 -03:00
2018-04-06 23:31:37 -03:00
2018-04-06 23:13:16 -03:00
### Requirements & Dependancies
2018-04-10 23:41:32 -03:00
Idea [145-identity](https://github.com/status-im/ideas/pull/145) is important to seamless and safe integration of gas abstraction for any type of call, so identity can become `msg.sender` for other contracts.
2018-04-06 23:13:16 -03:00
### Minimum Viable Product
2018-04-06 23:31:37 -03:00
Goal Date: 2018-05-15
2018-04-06 23:13:16 -03:00
Description:
2018-04-06 23:31:37 -03:00
- Users can use Identity paying gasPrice in any token.
- Users can create Identity using SNTController and paying with SNT.
- Users can earn tokens running a node that include other's messages
2018-04-06 23:13:16 -03:00
2018-04-10 23:41:32 -03:00
#### Identity Gas RelayIdentity UX should allow user to choose what token it wants to use as gas price.
2018-04-06 23:13:16 -03:00
2018-04-06 23:31:37 -03:00
Goal Date: 2018-04-20
2018-04-06 23:13:16 -03:00
Description:
- Gas Relay Node that recieve whisper messages from Identity owners,
- Identity User Interface with Gas Relayed option of calls
#### SNT Gas Relayer
2018-04-06 23:31:37 -03:00
Goal Date: 2018-04-27
2018-04-06 23:13:16 -03:00
Description:
- Gas Relay Node implements watching messages for SNTController
2018-04-10 23:41:32 -03:00
- User interface for creating Identity (pay gas in SNT)
2018-04-06 23:13:16 -03:00
- Moving SNT to other address from SNTController terms (paying gas in SNT)
2018-04-06 23:31:37 -03:00
#### UX Integration
2018-04-07 02:24:34 -03:00
2018-04-06 23:31:37 -03:00
Goal Date: 2018-05-15
Description:
- User can create Identity paying in SNT.
- User can select differnt tokens in gasPrice when using Identity.
2018-04-06 23:13:16 -03:00
## Success Metrics
Users are able to use Ethereum Virtual Machine and Status Network with only ever holding SNT.
## Supporting Role Communication
## Copyright
Copyright and related rights waived via [CC0](https://creativecommons.org/publicdomain/zero/1.0/).