【问题标题】:Minimal ERC20 contract for testing用于测试的最小 ERC20 合约
【发布时间】:2023-01-08 04:39:45
【问题描述】:

我正在寻找最小的 ERC20 令牌实现。 The OpenZeppelin's ERC20 contract所有这些扩展层对于学生辅导来说太大了

interface IERC20 {
    event Transfer(address indexed from, address indexed to, uint256 value);
    event Approval(address indexed owner, address indexed spender, uint256 value);
    function totalSupply() external view returns (uint256);
    function balanceOf(address account) external view returns (uint256);
    function transfer(address to, uint256 amount) external returns (bool);
    function allowance(address owner, address spender) external view returns (uint256);
    function approve(address spender, uint256 amount) external returns (bool);
    function transferFrom(address from, address to, uint256 amount) external returns (bool);
}

【问题讨论】:

    标签: ethereum solidity smartcontracts erc20 openzeppelin


    【解决方案1】:

    我写了一个 TestERC20 智能合约,它在没有继承的情况下实现了 IERC20 接口。

    它被用来测试erc20-payment-gateway。我认为这也可能对社区有用

    // SPDX-License-Identifier: GPL-3.0
    
    pragma solidity ^0.8.7;
    
    library Math {
        function safeAdd(uint256 x, uint256 y) internal pure returns (uint256) {
            uint256 z = x + y;
            require(z >= x, "math-add-overflow");
            return z;
        }
        function safeSub(uint256 x, uint256 y) internal pure returns (uint256) {
            uint256 z = x - y;
            require(z <= x, "math-sub-underflow");
            return z;
        }
    }
    
    contract TestERC20 {
    
        uint256 public constant decimals = 18;
        string public name;
        string public symbol;
        uint256 public totalSupply;
    
        mapping (address => uint256) public balances;
        mapping (address => mapping (address => uint256)) private allowances;
    
        event Approval(address indexed src, address indexed usr, uint256 wad);
        event Transfer(address indexed src, address indexed dst, uint256 wad);
    
        function getChainId() public view returns(uint256) {
            uint256 chainId;
            assembly {
                chainId := chainid()
            }
            return chainId;
        }
    
        constructor(string memory _symbol, string memory _name) {
            symbol = _symbol;
            name = _name;
        }
    
        function transfer(address dst, uint256 wad) external returns (bool) {
            return transferFrom(msg.sender, dst, wad);
        }
    
        function transferFrom(address src, address dst, uint256 wad) public returns (bool) {
            require(balances[src] >= wad, "nsufficient-balance");
            if (src != msg.sender && allowances[src][msg.sender] != type(uint256).max) {
                require(allowances[src][msg.sender] >= wad, "insufficient-allowances");
                allowances[src][msg.sender] = Math.safeSub(allowances[src][msg.sender], wad);
            }
            balances[src] = Math.safeSub(balances[src], wad);
            balances[dst] = Math.safeAdd(balances[dst], wad);
            emit Transfer(src, dst, wad);
            return true;
        }
    
        function mint(address usr, uint256 wad) public {
            balances[usr] = Math.safeAdd(balances[usr], wad);
            totalSupply = Math.safeAdd(totalSupply, wad);
            emit Transfer(address(0), usr, wad);
        }
    
        function burn(address usr, uint256 wad) public {
            require(balances[usr] >= wad, "insufficient-balance");
            if (usr != msg.sender && allowances[usr][msg.sender] != type(uint256).max) {
                require(allowances[usr][msg.sender] >= wad, "insufficient-allowances");
                allowances[usr][msg.sender] = Math.safeSub(allowances[usr][msg.sender], wad);
            }
            balances[usr] = Math.safeSub(balances[usr], wad);
            totalSupply    = Math.safeSub(totalSupply, wad);
            emit Transfer(usr, address(0), wad);
        }
    
        function approve(address usr, uint256 wad) external returns (bool) {
            allowances[msg.sender][usr] = wad;
            emit Approval(msg.sender, usr, wad);
            return true;
        }
    
        function allowance(address owner, address spender) public view returns (uint256) {
            return allowances[owner][spender];
        }
    
        function balanceOf(address account) public view returns (uint256) {
            return balances[account];
        }
    
    }
    

    【讨论】:

      猜你喜欢
      • 2022-09-27
      • 1970-01-01
      • 1970-01-01
      • 2021-11-24
      • 1970-01-01
      • 1970-01-01
      • 2022-01-01
      • 2021-09-17
      • 2022-07-31
      相关资源
      最近更新 更多