Alert Source Discuss
⚠️ Draft Standards Track: ERC

ERC-7254: Token Revenue Sharing

Revenue token is a token that shares rewards for holders.

Authors Quy Phan (@quyphandang), Quy Phan <quy.phan@cryptoviet.info>
Created 2023-06-29
Discussion Link https://ethereum-magicians.org/t/token-revenue-sharing/14872

Abstract

With the aspiration of bringing forth unique functionality and enhancing value for holders of ERC-20 tokens, our project aims to effortlessly reward token holders without necessitating users to lock, stake, or farm their tokens. Whenever the project generates profits, these profits can be distributed to the token holders.

Revenue Sharing is an extended version of ERC-20. It proposes an additional payment method for token holders.

This standard includes updating rewards for holders and allowing token holders to withdraw rewards.

Potential use cases encompass:

  • Companies distributing dividends to token holders.
  • Direct sharing of revenue derived from business activities, such as marketplaces, Automated Market Makers (AMMs), and games.

Specification

Methods

maxTokenReward

Returns max token reward.

function maxTokenReward() public view returns (uint256)

informationOf

Returns the account information of another account with the address token and account, including: inReward, outReward and withdraw.

function informationOf(address token, address account) public view returns (UserInformation memory)

informationOfBatch

Returns the list account information of another account with the account, including: inReward, outReward and withdraw.

function informationOfBatch(address account) public view returns (UserInformation[] memory)

UserInformation

inReward: when user’s balance decreases, inReward will be updated outReward: when user’s balance increases, outReward will be updated withdraw: total amount of reward tokens withdrawn

struct UserInformation {
    uint256 inReward;
    uint256 outReward;
    uint256 withdraw;
}

tokenReward

Returns the list token reward address of the token.

function tokenReward() public view returns (address[] memory)

updateReward

Updates rewardPerShare of token reward. rewardPerShare = rewardPerShare + amount / totalSupply()

function updateReward(address[] memory token, uint256[] memory amount) public

viewReward

Returns the list amount of reward for an account

function viewReward(address account) public view returns (uint256[] memory)

getReward

Gets and returns reward with list token reward.

function getReward(address[] memory token) public

getRewardPerShare

Returns the reward per share of token reward.

function getRewardPerShare(address token) public view returns (uint256)

existsTokenReward

Returns the status of token reward.

function existsTokenReward(address token) public view returns (bool)

Rationale

TBD

Reference Implementation

Security Considerations

Needs discussion.

Copyright and related rights waived via CC0.

Citation

Please cite this document as:

Quy Phan (@quyphandang), Quy Phan <quy.phan@cryptoviet.info>, "ERC-7254: Token Revenue Sharing [DRAFT]," Ethereum Improvement Proposals, no. 7254, June 2023. [Online serial]. Available: https://eips.ethereum.org/EIPS/eip-7254.