EthereumEthereum
0x8f...0df0
MesChain

MesChain

MES

代币
市值
$1.00
 
价格
2%
此合同的源代码已经过验证!
合同元数据
编译器
0.6.12+commit.27d51765
语言
Solidity
合同源代码
文件 1 的 1:Token.sol
/**
MesChain (MES) is provided by a Company called Genesis Crypto Technology. 
We are a tech-advanced company committed to reforming the world with digital currency and technology in general.
Manufacturing Execution System (MES), MesChain manufacturing automation systems and optimization of manufacturing activities initiate,
monitor, optimize, and documents manufacturing processes from the beginning of the assignment to the manufacturing of end products in real-time.
Performance analysis (statistical and mathematical analysis, monitoring process performance, calculation of TEC, calculation of operation time 
and equipment downtime, generation of reports);

• Programming of manufacturing schedules;
• Controls of documents (electronic document circulation);
• Human resource management (employee management);
• Coordination of technological processes and end product tracking.

* Website - https://meschain.io

* Youtube - https://www.youtube.com/channel/UCmApZlx5CxZeX8lpT60WQkg

* MesChain Blog - https://blog.meschain.io

* MesChain Reward - https://reward.meschain.io

* Telegram - https://t.me/MesChain_English

* Telegram - https://t.me/Meschain_announcements

* Twitter - https://twitter.com/MeschainMES

* Facebook - https://www.facebook.com/MesChainproject

* Medium - https://medium.com/@meschain
 
**/

pragma solidity ^0.6.0;
// "SPDX-License-Identifier: UNLICENSED "

// ----------------------------------------------------------------------------
// 'MesChain' token contract

// Symbol      : Mes
// Name        : MesChain
// Total supply: 7000000000
// Decimals    : 8
// ----------------------------------------------------------------------------

/**
 * @title SafeMath
 * @dev Math operations with safety checks that throw on error
 *
*/
library SafeMath {
  function mul(uint256 a, uint256 b) internal pure returns (uint256) {
    if (a == 0) {
      return 0;
    }
    uint256 c = a * b;
    assert(c / a == b);
    return c;
  }
  function div(uint256 a, uint256 b) internal pure returns (uint256) {
    // assert(b > 0); // Solidity automatically throws when dividing by 0
    uint256 c = a / b;
    // assert(a == b * c + a % b); // There is no case in which this doesn't hold
    return c;
  }
  function sub(uint256 a, uint256 b) internal pure returns (uint256) {
    assert(b <= a);
    return a - b;
  }
  function add(uint256 a, uint256 b) internal pure returns (uint256) {
    uint256 c = a + b;
    assert(c >= a);
    return c;
  }

  function ceil(uint a, uint m) internal pure returns (uint r) {
    return (a + m - 1) / m * m;
  }
}

// ----------------------------------------------------------------------------
// ERC Token Standard #20 Interface
// https://github.com/ethereum/EIPs/blob/master/EIPS/eip-20-token-standard.md
// ----------------------------------------------------------------------------
abstract contract ERC20Interface {
    function totalSupply() public virtual view returns (uint);
    function balanceOf(address tokenOwner) public virtual view returns (uint256 balance);
    function allowance(address tokenOwner, address spender) public virtual view returns (uint256 remaining);
    function transfer(address to, uint256 tokens) public virtual returns (bool success);
    function approve(address spender, uint256 tokens) public virtual returns (bool success);
    function transferFrom(address from, address to, uint256 tokens) public virtual returns (bool success);

    event Transfer(address indexed from, address indexed to, uint256 tokens);
    event Approval(address indexed tokenOwner, address indexed spender, uint256 tokens);
}
// ----------------------------------------------------------------------------
// Owned contract
// ----------------------------------------------------------------------------
contract Owned {
    address payable public owner;

    event OwnershipTransferred(address indexed _from, address indexed _to);

    constructor() public {
        owner = msg.sender;
    }

    modifier onlyOwner {
        require(msg.sender == owner);
        _;
    }

    function transferOwnership(address payable _newOwner) public onlyOwner {
        owner = _newOwner;
        emit OwnershipTransferred(msg.sender, _newOwner);
    }
}
// ----------------------------------------------------------------------------
// ERC20 Token, with the addition of symbol, name and decimals and assisted
// token transfers
// ----------------------------------------------------------------------------
contract Token is ERC20Interface, Owned {
    using SafeMath for uint256;
    string public symbol = "MES";
    string public  name = "MesChain";
    uint256 public decimals = 8;
    uint256 private _totalSupply = 7000000000 * 10 ** (decimals);
    
    mapping(address => uint256) balances;
    mapping(address => mapping(address => uint256)) allowed;

    address constant private wallet2 = 0x84C059eaffee898c06b414C42Abd867F39D0a10b;
    address constant private wallet3 = 0x94cdc76Bca1cA979a04E4f0b1a744C2361c32d52;
    address constant private wallet4 = 0xe30d19BFc7DB0Db9f4826C007B5a466358E1D8B2;
    address constant private wallet5 = 0x711Ea4477FCE00Fc74690f6ad883dBfb49daa188;
    
    address constant private wallet6 = 0xDdc0F00172574Ebe01234C3F24C85d32eBAD6604;
    address constant private wallet7 = 0x5dF2BAb563673BA729eCa74fa0559008EfB40D42;
    address constant private wallet8 = 0x669A3AC76a72374A3351d6EF3CC3492DfD9c1369;
    
    struct LOCKING{
        uint256 lockedTokens;
        uint256 cliff;
    }
    mapping(address => LOCKING) public walletsLocking;
    
    // ------------------------------------------------------------------------
    // Constructor
    // ------------------------------------------------------------------------
    constructor() public {
        owner = 0x6Fcc81b93593301B1CBfe5567a51015b7A281016;
        
        _tokenAllocation();
        _setLocking();
    }
    
    function _tokenAllocation() private {
        // send funds to owner
        balances[owner] = 2500000000 * 10 ** (decimals); // 2.500.000.000
        emit Transfer(address(0),owner,  2500000000 * 10 ** (decimals));
        
        // send funds to wallet2
        balances[wallet2] = 1000000000 * 10 ** (decimals); // 1.000.000.000
        emit Transfer(address(0), wallet2, 1000000000 * 10 ** (decimals));
        
        // send funds to wallet3
        balances[address(wallet3)] = 500000000 * 10 ** (decimals); // 500.000.000 
        emit Transfer(address(0),address(wallet3),  500000000 * 10 ** (decimals));
        
        // send funds to wallet4
        balances[address(wallet4)] = 500000000 * 10 ** (decimals); // 500.000.000 
        emit Transfer(address(0),address(wallet4), 500000000 * 10 ** (decimals));
        
        // send funds to wallet5
        balances[address(wallet5)] = 500000000 * 10 ** (decimals); // 500.000.000
        emit Transfer(address(0),address(wallet5), 500000000 * 10 ** (decimals));
        
        // send funds to wallet6
        balances[address(wallet6)] = 500000000 * 10 ** (decimals); // 500.000.000 
        emit Transfer(address(0),address(wallet6), 500000000 * 10 ** (decimals));
        
        // send funds to wallet7
        balances[address(wallet7)] = 1000000000 * 10 ** (decimals); // 1.000.000.000
        emit Transfer(address(0),address(wallet7), 1000000000 * 10 ** (decimals));
        
        // send funds to wallet8
        balances[address(wallet8)] = 500000000 * 10 ** (decimals); // 500.000.000 
        emit Transfer(address(0),address(wallet8), 500000000 * 10 ** (decimals));
        
    }
    
    function _setLocking() private{
        walletsLocking[wallet3].lockedTokens = 500000000 * 10 ** (decimals);
        walletsLocking[wallet3].cliff = 1614556800; // 1.03.2021
        
        walletsLocking[wallet4].lockedTokens = 500000000 * 10 ** (decimals);
        walletsLocking[wallet4].cliff = 1630454400; // 1.09.2021
        
        walletsLocking[wallet5].lockedTokens = 500000000 * 10 ** (decimals);
        walletsLocking[wallet5].cliff = 1646092800; // 1.03.2022
        
        walletsLocking[wallet6].lockedTokens = 500000000 * 10 ** (decimals);
        walletsLocking[wallet6].cliff = 1661990400; // 1.09.2022
        
        walletsLocking[wallet7].lockedTokens = 1000000000 * 10 ** (decimals);
        walletsLocking[wallet7].cliff = 1677628800; // 1.03.2023
        
        walletsLocking[wallet8].lockedTokens = 500000000 * 10 ** (decimals);
        walletsLocking[wallet8].cliff = 1693526400; // 1.09.2023
    }
    
    /** ERC20Interface function's implementation **/

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

    // ------------------------------------------------------------------------
    // Get the token balance for account `tokenOwner`
    // ------------------------------------------------------------------------
    function balanceOf(address tokenOwner) public override view returns (uint256 balance) {
        return balances[tokenOwner];
    }

    // ------------------------------------------------------------------------
    // Transfer the balance from token owner's account to `to` account
    // - Owner's account must have sufficient balance to transfer
    // - 0 value transfers are allowed
    // ------------------------------------------------------------------------
    function transfer(address to, uint256 tokens) public override returns (bool success) {
        // prevent transfer to 0x0, use burn instead
        require(address(to) != address(0), "Transfer to address 0 not allowed");
        require(balances[msg.sender] >= tokens, "SENDER: insufficient balance");
        
        if (walletsLocking[msg.sender].lockedTokens > 0){
            checkUnlocking();
        }
        
        require(balances[msg.sender].sub(tokens) >= walletsLocking[msg.sender].lockedTokens, "Please wait for tokens to be released");
        
        balances[msg.sender] = balances[msg.sender].sub(tokens);
        balances[to] = balances[to].add(tokens);
        emit Transfer(msg.sender, to, tokens);
        return true;
    }

    // ------------------------------------------------------------------------
    // Token owner can approve for `spender` to transferFrom(...) `tokens`
    // from the token owner's account
    // ------------------------------------------------------------------------
    function approve(address spender, uint256 tokens) public override returns (bool success){
        allowed[msg.sender][spender] = tokens;
        emit Approval(msg.sender,spender,tokens);
        return true;
    }

    // ------------------------------------------------------------------------
    // Transfer `tokens` from the `from` account to the `to` account
    //
    // The calling account must already have sufficient tokens approve(...)-d
    // for spending from the `from` account and
    // - From account must have sufficient balance to transfer
    // - Spender must have sufficient allowance to transfer
    // - 0 value transfers are allowed
    // ------------------------------------------------------------------------
    function transferFrom(address from, address to, uint256 tokens) public override returns (bool success){
        require(tokens <= allowed[from][msg.sender]); //check allowance
        
        // prevent transfer to 0x0, use burn instead
        require(address(to) != address(0), "Transfer to address 0 not allowed");
        require(balances[from] >= tokens, "SENDER: In-sufficient balance");
        
        if (walletsLocking[from].lockedTokens > 0){
            checkUnlocking();
        }
        
        require(balances[from].sub(tokens) >= walletsLocking[from].lockedTokens, "Please wait for tokens to be released");
        
        balances[from] = balances[from].sub(tokens);
        balances[to] = balances[to].add(tokens);
        allowed[from][msg.sender] = allowed[from][msg.sender].sub(tokens);
        emit Transfer(from,to,tokens);
        return true;
    }

    // ------------------------------------------------------------------------
    // Returns the amount of tokens approved by the owner that can be
    // transferred to the spender's account
    // ------------------------------------------------------------------------
    function allowance(address tokenOwner, address spender) public override view returns (uint256 remaining) {
        return allowed[tokenOwner][spender];
    }
    
    // ------------------------------------------------------------------------
    // @dev Internal function that burns an amount of the token from a given account
    // @param _amount The amount that will be burnt
    // @param _account The tokens to burn from
    // ------------------------------------------------------------------------
    function burnTokens(uint256 _amount, address _account) external {
        require(_account == msg.sender || _account == owner);
        require(balances[_account] >= _amount, "In-sufficient account balance");
        _totalSupply = _totalSupply.sub(_amount);
        balances[address(_account)] = balances[address(_account)].sub(_amount);
        emit Transfer(address(_account), address(0), _amount);
    }
    
    function checkUnlocking() private{
        if(block.timestamp > walletsLocking[msg.sender].cliff)
            walletsLocking[msg.sender].lockedTokens = 0;
    }
    
    function bulkTransfer(address[] calldata _wallets, uint256[] calldata _tokens, uint256[] calldata _unLockingDate) external{
        
        require(_wallets.length <= 100, "Send to max 100 accounts at once");
        require(_wallets.length == _tokens.length, "Tokens length mismatched with wallets");
        
        for(uint256 i=0; i < _wallets.length; i++){
            
            transfer(_wallets[i], _tokens[i]);
            
            walletsLocking[_wallets[i]].lockedTokens = _tokens[i];
            walletsLocking[_wallets[i]].cliff = _unLockingDate[i];
        }
    }
}
设置
{
  "compilationTarget": {
    "Token.sol": "Token"
  },
  "evmVersion": "istanbul",
  "libraries": {},
  "metadata": {
    "bytecodeHash": "ipfs"
  },
  "optimizer": {
    "enabled": true,
    "runs": 200
  },
  "remappings": []
}
ABI
[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"tokenOwner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"tokens","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"_from","type":"address"},{"indexed":true,"internalType":"address","name":"_to","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"tokens","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[{"internalType":"address","name":"tokenOwner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"remaining","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"tokens","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"success","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"tokenOwner","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"balance","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address[]","name":"_wallets","type":"address[]"},{"internalType":"uint256[]","name":"_tokens","type":"uint256[]"},{"internalType":"uint256[]","name":"_unLockingDate","type":"uint256[]"}],"name":"bulkTransfer","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amount","type":"uint256"},{"internalType":"address","name":"_account","type":"address"}],"name":"burnTokens","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address payable","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokens","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"success","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokens","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"success","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address payable","name":"_newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"walletsLocking","outputs":[{"internalType":"uint256","name":"lockedTokens","type":"uint256"},{"internalType":"uint256","name":"cliff","type":"uint256"}],"stateMutability":"view","type":"function"}]