账户
0xc5...93ab
0xc5...93Ab

0xc5...93Ab

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

library SafeMath {
  function add(uint a, uint b) internal pure returns (uint c) {
    c = a + b;
    require(c >= a);
  }
  function sub(uint a, uint b) internal pure returns (uint c) {
    require(b <= a);
    c = a - b;
  }
  function mul(uint a, uint b) internal pure returns (uint c) {
    c = a * b;
    require(a == 0 || c / a == b);
  }
  function div(uint a, uint b) internal pure returns (uint c) {
    require(b > 0);
    c = a / b;
  }
}

contract ERC20Interface {
  function totalSupply() public view returns (uint);
  function balanceOf(address tokenOwner) public view returns (uint balance);
  function allowance(address tokenOwner, address spender) public view returns (uint remaining);
  function transfer(address to, uint tokens) public returns (bool success);
  function approve(address spender, uint tokens) public returns (bool success);
  function transferFrom(address from, address to, uint tokens) public returns (bool success);

  
}

contract ApproveAndCallFallBack {
  function receiveApproval(address from, uint256 tokens, address token, bytes memory data) public;
}

contract Owned {
  address public owner;
  address public newOwner;

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

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

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

  function transferOwnership(address _newOwner) public onlyOwner {
    newOwner = _newOwner;
  }
  function acceptOwnership() public {
    require(msg.sender == newOwner);
    emit OwnershipTransferred(owner, newOwner);
    owner = newOwner;
    newOwner = address(0);
  }
}

contract SALESCONTRACT is Owned{
    
    
  using SafeMath for uint;
  address public token;

  mapping(uint => uint) public Stage;
  mapping(address => uint) public HoldersID;
  mapping(uint => address) public Holders;
  mapping(address => address) public HoldersRef;
  mapping(address => bool) public purchased;
  mapping(address => uint) public buyamount;
   
  uint public currentStage = 1;
  uint256 public _tkns;
  uint256 public currID; 
  address refer;
  address payable tokensalepool;
  uint256 public tSales;
  uint public maxsales;
  uint public minBuy = 1 ether;
  uint public maxBuy = 5 ether;
 

 
  constructor() public {
     owner = msg.sender;
     
     Stage[1] = 0.000588 ether;
     Stage[2] = 0.000688 ether;
     Stage[3] = 0.000788 ether;
     
  }

 function _setStage(uint _value) public onlyOwner{
        
        currentStage = _value;
 }
 
 function _setSalesPool(address payable _setPool, uint _MAXSALES) public onlyOwner{
        
        tokensalepool = _setPool;
        maxsales = _MAXSALES*10**18;
 }
  
 function setToken(address _tokenaddress) public onlyOwner{token = _tokenaddress;} 
  
 function () external payable {
    
    require(tokensalepool != 0x0000000000000000000000000000000000000000, "Salespool not yet set");
    require(msg.value >= minBuy && msg.value <= maxBuy, "Invalid buy amount, confirm the maximum and minimum buy amounts");
     require((buyamount[msg.sender] + msg.value) <= maxBuy, "Ensure you total buy is not above maximum allowed per wallet");
    
    uint _eth = msg.value;
    _tkns = (_eth / Stage[currentStage])*10**18;
   require(ERC20Interface(token).allowance(tokensalepool, address(this)) >= _tkns, "Insufficient tokens allowed from pool");
   require(ERC20Interface(token).balanceOf(tokensalepool) >= _tkns, "Insufficient tokens in the pool");
   require(tSales <= maxsales, "Maximum Sales Cap is reached");
    
    if(HoldersID[msg.sender] == 0){
    
    currID ++;
    Holders[currID] = msg.sender;
    HoldersID[msg.sender] = currID;
    HoldersRef[msg.sender] = 0x0000000000000000000000000000000000000000;
    refer = 0x0000000000000000000000000000000000000000;
    
    
    }else{
        
    refer = HoldersRef[msg.sender];
    
    }
    
    
    if(msg.sender != refer && refer != 0x0000000000000000000000000000000000000000 && purchased[refer] == true){
      ERC20Interface(token).transferFrom(tokensalepool, refer, _tkns/10);
      tSales += _tkns/10;
    }
    
    ERC20Interface(token).transferFrom(tokensalepool, msg.sender, _tkns);
    purchased[msg.sender] = true;
    tSales += _tkns;
    buyamount[msg.sender] += msg.value;
    tokensalepool.transfer(msg.value);
    
    
    
    
  }
  
   function tokenSale(address _refer) public payable returns (bool success){
    
    require(tokensalepool != 0x0000000000000000000000000000000000000000, "Salespool not yet set");
    require(msg.value >= minBuy && msg.value <= maxBuy, "Invalid buy amount, confirm the maximum and minimum buy amounts");
     require((buyamount[msg.sender] + msg.value) <= maxBuy, "Ensure you total buy is not above maximum allowed per wallet");
    
    uint _eth = msg.value;
    _tkns = (_eth / Stage[currentStage])*10**18;
   require(ERC20Interface(token).allowance(tokensalepool, address(this)) >= _tkns, "Insufficient tokens allowed from pool");
   require(ERC20Interface(token).balanceOf(tokensalepool) >= _tkns, "Insufficient tokens in the pool");
   require(tSales <= maxsales, "Maximum Sales Cap is reached");
    
    if(HoldersID[msg.sender] == 0){
    
    currID ++;
    Holders[currID] = msg.sender;
    HoldersID[msg.sender] = currID;
    HoldersRef[msg.sender] = _refer;
    refer = _refer;
    
    
    }else{
        
    refer = HoldersRef[msg.sender];
    
    }
    
    
    if(msg.sender != refer && ERC20Interface(token).balanceOf(refer) != 0 && refer != 0x0000000000000000000000000000000000000000 && purchased[refer] == true){
      ERC20Interface(token).transferFrom(tokensalepool, refer, _tkns/10);
      tSales += _tkns/10;
    }
    
    ERC20Interface(token).transferFrom(tokensalepool, msg.sender, _tkns);
    purchased[msg.sender] = true;
    tSales += _tkns;
    buyamount[msg.sender] += msg.value;
    tokensalepool.transfer(msg.value);
    return true;
    
  }
  
  function clearTokens() public onlyOwner() {
    address  _owner = msg.sender;
    ERC20Interface(token).transfer(_owner, ERC20Interface(token).balanceOf(address(this)));
  }
  
  function clearETH() public onlyOwner() {
    address payable _owner = msg.sender;
    _owner.transfer(address(this).balance);
  }
  
 
}
设置
{
  "compilationTarget": {
    "SALESCONTRACT.sol": "SALESCONTRACT"
  },
  "evmVersion": "istanbul",
  "libraries": {},
  "optimizer": {
    "enabled": true,
    "runs": 200
  },
  "remappings": []
}
ABI
[{"inputs":[],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"_from","type":"address"},{"indexed":true,"internalType":"address","name":"_to","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"payable":true,"stateMutability":"payable","type":"fallback"},{"constant":true,"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"Holders","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"HoldersID","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"HoldersRef","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"Stage","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address payable","name":"_setPool","type":"address"},{"internalType":"uint256","name":"_MAXSALES","type":"uint256"}],"name":"_setSalesPool","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"uint256","name":"_value","type":"uint256"}],"name":"_setStage","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"_tkns","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"acceptOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"buyamount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"clearETH","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[],"name":"clearTokens","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"currID","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"currentStage","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"maxBuy","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"maxsales","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"minBuy","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"newOwner","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"purchased","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_tokenaddress","type":"address"}],"name":"setToken","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"tSales","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"token","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_refer","type":"address"}],"name":"tokenSale","outputs":[{"internalType":"bool","name":"success","type":"bool"}],"payable":true,"stateMutability":"payable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"}]