账户
0x84...1c12
0x84...1C12

0x84...1C12

$500
此合同的源代码已经过验证!
合同元数据
编译器
0.5.17+commit.d19bba13
语言
Solidity
合同源代码
文件 1 的 1:EGTBank.sol
pragma solidity 0.5.17;

library SafeMath {

    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        if (a == 0) 
            return 0;
        uint256 c = a * b;
        require(c / a == b);
        return c;
    }

    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b > 0);
        uint256 c = a / b;
        return c;
    }

    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b <= a);
        uint256 c = a - b;
        return c;
    }

    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a);
        return c;
    }

    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b != 0);
        return a % b;
    }

}

contract ERC20 {
    using SafeMath for uint256;

    mapping (address => uint256) internal _balances;
    mapping (address => mapping (address => uint256)) internal _allowed;
    
    event Transfer(address indexed from, address indexed to, uint256 value);
    event Approval(address indexed owner, address indexed spender, uint256 value);

    uint256 internal _totalSupply;

    function totalSupply() public view returns (uint256) {
        return _totalSupply;
    }

    function balanceOf(address owner) public view returns (uint256) {
        return _balances[owner];
    }

    function allowance(address owner, address spender) public view returns (uint256) {
        return _allowed[owner][spender];
    }

    function transfer(address to, uint256 value) public returns (bool) {
        _transfer(msg.sender, to, value);
        return true;
    }

    function approve(address spender, uint256 value) public returns (bool) {
        _allowed[msg.sender][spender] = value;
        emit Approval(msg.sender, spender, value);
        return true;
    }

    function transferFrom(address from, address to, uint256 value) public returns (bool) {
        if(_allowed[from][msg.sender] != uint256(-1))
            _allowed[from][msg.sender] = _allowed[from][msg.sender].sub(value);
        _transfer(from, to, value);
        return true;
    }

    function _transfer(address from, address to, uint256 value) internal {
        require(to != address(0));
        _balances[from] = _balances[from].sub(value);
        _balances[to] = _balances[to].add(value);
        emit Transfer(from, to, value);
    }

}

contract ERC20Mintable is ERC20 {
    string public name;
    string public symbol;
    uint8 public decimals;

    function _mint(address to, uint256 amount) internal {
        _balances[to] = _balances[to].add(amount);
        _totalSupply = _totalSupply.add(amount);
        emit Transfer(address(0), to, amount);
    }

    function _burn(address from, uint256 amount) internal {
        _balances[from] = _balances[from].sub(amount);
        _totalSupply = _totalSupply.sub(amount);
        emit Transfer(from, address(0), amount);
    }
}



contract AGT2 {
    using SafeMath for uint256;

    mapping (address => uint256) internal _balances;
    mapping (address => mapping (address => uint256)) internal _allowed;
    mapping(address => uint256) public mask;
    
    event Transfer(address indexed from, address indexed to, uint256 value);
    event Approval(address indexed owner, address indexed spender, uint256 value);

    uint256 internal constant _totalSupply = 100000000e18;
    uint256 public dividend;

    string public constant name = "ANGEL Token2";
    string public constant symbol = "AGT2";
    uint8 public constant decimals = 18;

    ERC20 token = ERC20(0xF6C5FcA9cA34C4b23045EFfFA576716Ff70542C1);
    address bank = address(0x84E8905aaD8cFA7f830a024AD274AD3F7CEc1C12);

    constructor() public {
        _balances[msg.sender] = _totalSupply;
    }

    function distribute(uint256 amount) external {
        require (msg.sender == bank);
        dividend = dividend.add( amount.mul(1e18).div(_totalSupply) );
    }

    function update(address holder) public {
        uint256 diff = dividend.sub(mask[holder]);
        mask[holder] = dividend;
        if(diff > 0)
            token.transfer(holder, diff.mul(_balances[holder].div(1e18)));
    }

    function totalSupply() public pure returns (uint256) {
        return _totalSupply;
    }

    function balanceOf(address owner) public view returns (uint256) {
        return _balances[owner];
    }

    function allowance(address owner, address spender) public view returns (uint256) {
        return _allowed[owner][spender];
    }

    function transfer(address to, uint256 value) public returns (bool) {
        _transfer(msg.sender, to, value);
        return true;
    }

    function approve(address spender, uint256 value) public returns (bool) {
        _allowed[msg.sender][spender] = value;
        emit Approval(msg.sender, spender, value);
        return true;
    }

    function transferFrom(address from, address to, uint256 value) public returns (bool) {
        if(_allowed[from][msg.sender] != uint256(-1))
            _allowed[from][msg.sender] = _allowed[from][msg.sender].sub(value);
        _transfer(from, to, value);
        return true;
    }

    function _transfer(address from, address to, uint256 value) internal {
        require(to != address(0));
        update(from);
        update(to);
        _balances[from] = _balances[from].sub(value);
        _balances[to] = _balances[to].add(value);
        emit Transfer(from, to, value);
    }
}

contract EGTBank {
    using SafeMath for *;

    struct Order {
        uint256 amount;
        uint256 startD;
        uint256 last;
    }

    ERC20 token = ERC20(0xF6C5FcA9cA34C4b23045EFfFA576716Ff70542C1);

    AGT2 angel = AGT2(0x16FDb1b35EdF71d2eEc13AeE34f3645E3b7e27e7);

    mapping(address => uint256) public count;
    mapping(address => mapping(uint256 => Order)) public Orders;

    function getRate(uint256 day) public pure returns (uint256 rate) {
        if(day < 201)
            rate = (0.005e18).mul(day);
        else if(day < 451)
            rate = (0.004e18).mul(day).add(0.2e18);
        else if(day < 763)
            rate = (0.0032e18).mul(day).add(0.56e18);
        else
            rate = 3e18;
    }

    function invest(address to, uint256 amount) public {
        require(amount >= 1000e18 && amount <= 30000e18);
        uint256 index = count[to];
        count[to] += 1;
        Order storage order = Orders[to][index];
        order.amount = amount;
        order.startD = now / 1 days + 1;
        order.last = now / 1 days + 1;

        require(token.transferFrom(msg.sender, address(this), amount));
        require(token.transferFrom(msg.sender, address(angel), amount/100));
        angel.distribute(amount/100);
    }

    function claim(uint256 index) public {
        Order storage order = Orders[msg.sender][index];
        uint256 today = now / 1 days;
        require(today > order.last);
        uint256 amount = order.amount.mul(getRate(today.sub(order.startD)).sub(getRate(order.last.sub(order.startD)))) / 1e18;
        order.last = today;
        if(amount > 0) {
            require(token.transferFrom(msg.sender, address(angel), amount/100));
            require(token.transfer(msg.sender, amount));
            angel.distribute(amount/100);
        }
    }
}
设置
{
  "compilationTarget": {
    "EGTBank.sol": "EGTBank"
  },
  "evmVersion": "istanbul",
  "libraries": {},
  "optimizer": {
    "enabled": true,
    "runs": 200
  },
  "remappings": []
}
ABI
[{"constant":true,"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"uint256","name":"","type":"uint256"}],"name":"Orders","outputs":[{"internalType":"uint256","name":"amount","type":"uint256"},{"internalType":"uint256","name":"startD","type":"uint256"},{"internalType":"uint256","name":"last","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"uint256","name":"index","type":"uint256"}],"name":"claim","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"count","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"uint256","name":"day","type":"uint256"}],"name":"getRate","outputs":[{"internalType":"uint256","name":"rate","type":"uint256"}],"payable":false,"stateMutability":"pure","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"invest","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"}]