ETH Price: $2,036.97 (-1.58%)

Contract Diff Checker

Contract Name:
BitBeri

Contract Source Code:

File 1 of 1 : BitBeri

pragma solidity ^0.4.13;

contract ERC20 {
  uint public totalSupply;
  function balanceOf(address who) constant returns (uint);
  function allowance(address owner, address spender) constant returns (uint);

  function transfer(address to, uint value) returns (bool ok);
  function transferFrom(address from, address to, uint value) returns (bool ok);
  function approve(address spender, uint value) returns (bool ok);
  event Transfer(address indexed from, address indexed to, uint value);
  event Approval(address indexed owner, address indexed spender, uint value);
}

contract SafeMath {
  function safeMul(uint a, uint b) internal returns (uint) {
    uint c = a * b;
    assert(a == 0 || c / a == b);
    return c;
  }

  function safeDiv(uint a, uint b) internal returns (uint) {
    assert(b > 0);
    uint c = a / b;
    assert(a == b * c + a % b);
    return c;
  }

  function safeSub(uint a, uint b) internal returns (uint) {
    assert(b <= a);
    return a - b;
  }

  function safeAdd(uint a, uint b) internal returns (uint) {
    uint c = a + b;
    assert(c>=a && c>=b);
    return c;
  }

  function max64(uint64 a, uint64 b) internal constant returns (uint64) {
    return a >= b ? a : b;
  }

  function min64(uint64 a, uint64 b) internal constant returns (uint64) {
    return a < b ? a : b;
  }

  function max256(uint256 a, uint256 b) internal constant returns (uint256) {
    return a >= b ? a : b;
  }

  function min256(uint256 a, uint256 b) internal constant returns (uint256) {
    return a < b ? a : b;
  }

}

contract StandardToken is ERC20, SafeMath {

  event Minted(address receiver, uint amount);

  mapping(address => uint) balances;

  mapping (address => mapping (address => uint)) allowed;

  function isToken() public constant returns (bool weAre) {
    return true;
  }

  function transfer(address _to, uint _value) returns (bool success) {
    balances[msg.sender] = safeSub(balances[msg.sender], _value);
    balances[_to] = safeAdd(balances[_to], _value);
    Transfer(msg.sender, _to, _value);
    return true;
  }

  function transferFrom(address _from, address _to, uint _value) returns (bool success) {
    uint _allowance = allowed[_from][msg.sender];

    balances[_to] = safeAdd(balances[_to], _value);
    balances[_from] = safeSub(balances[_from], _value);
    allowed[_from][msg.sender] = safeSub(_allowance, _value);
    Transfer(_from, _to, _value);
    return true;
  }

  function balanceOf(address _owner) constant returns (uint balance) {
    return balances[_owner];
  }

  function approve(address _spender, uint _value) returns (bool success) {

   require((_value == 0) || (allowed[msg.sender][_spender] == 0));

    allowed[msg.sender][_spender] = _value;
    Approval(msg.sender, _spender, _value);
    return true;
  }

  function allowance(address _owner, address _spender) constant returns (uint remaining) {
    return allowed[_owner][_spender];
  }

}

contract BitBeri is StandardToken {

    string public name = "BitBeri";
    string public symbol = "BTB";
    uint public decimals = 18;

    
    bool public halted = false; 
    bool public preTge = true; 
    bool public stageOne = false; 
    bool public stageTwo = false; 
    bool public stageThree = false; 
    bool public freeze = true; 

   
    address public founder = 0x0;
    address public owner = 0x0;

    uint public totalTokens = 100000000000000000000000000;
    uint public team = 5000000000000000000000000;
    uint public bounty = 5000000000000000000000000; 

    uint public preTgeCap = 2500000000000000000000000;
    uint public tgeCap = 50000000000000000000000000; 

    uint public presaleTokenSupply = 0; 
    uint public presaleEtherRaised = 0; 
    uint public preTgeTokenSupply = 0; 

    event Buy(address indexed sender, uint eth, uint fbt);

    event TokensSent(address indexed to, uint256 value);
    event ContributionReceived(address indexed to, uint256 value);
    event Burn(address indexed from, uint256 value);

    function BitBeri(address _founder) payable {
        owner = msg.sender;
        founder = _founder;

        balances[founder] = team;
        totalTokens = safeSub(totalTokens, team);
        totalTokens = safeSub(totalTokens, bounty);
        totalSupply = totalTokens;
        balances[owner] = totalSupply;
    }

   function buy() public payable returns(bool) {
        require(!halted);
        require(msg.value>0);
        
        uint256 weiAmount = msg.value;
        uint256 tokens = safeDiv(safeMul(weiAmount,10**17),13892747985551);

        require(balances[owner]>tokens);

        if (stageThree) {
			preTge = false;
			stageOne = false;
			stageTwo = false;
        }
		
        if (stageTwo) {
			preTge = false;
			stageOne = false;
            tokens = tokens + (tokens / 10);
        }
		
        if (stageOne) {
			preTge = false;
            tokens = tokens + (tokens / 5);
        }
		
        if (preTge) {
            tokens = tokens + (tokens / 2);
        }

        if (preTge) {
            require(safeAdd(presaleTokenSupply, tokens) < preTgeCap);
        } else {
            require(safeAdd(presaleTokenSupply, tokens) < safeSub(tgeCap, preTgeTokenSupply));
        }

        founder.transfer(msg.value);

        balances[msg.sender] = safeAdd(balances[msg.sender], tokens);
        balances[owner] = safeSub(balances[owner], tokens);

        if (preTge) {
            preTgeTokenSupply  = safeAdd(preTgeTokenSupply, tokens);
        }
        presaleTokenSupply = safeAdd(presaleTokenSupply, tokens);
        presaleEtherRaised = safeAdd(presaleEtherRaised, msg.value);

        Buy(msg.sender, msg.value, tokens);

        TokensSent(msg.sender, tokens);
        ContributionReceived(msg.sender, msg.value);
        Transfer(owner, msg.sender, tokens);

        return true;
    }

    function PreTgeEnable() onlyOwner() {
        preTge = true;
    }

    function PreTgeDisable() onlyOwner() {
        preTge = false;
    }

    function StageOneEnable() onlyOwner() {
        stageOne = true;
    }

    function StageOneDisable() onlyOwner() {
        stageOne = false;
    }
	
    function StageTwoEnable() onlyOwner() {
        stageTwo = true;
    }

    function StageTwoDisable() onlyOwner() {
        stageTwo = false;
    }

    function StageThreeEnable() onlyOwner() {
        stageThree = true;
    }

    function StageThreeDisable() onlyOwner() {
        stageThree = false;
    }

    function EventEmergencyStop() onlyOwner() {
        halted = true;
    }

    function EventEmergencyContinue() onlyOwner() {
        halted = false;
    }

    function sendTeamTokens(address _to, uint256 _value) onlyOwner() {
        balances[founder] = safeSub(balances[founder], _value);
        balances[_to] = safeAdd(balances[_to], _value);
        TokensSent(_to, _value);
        Transfer(owner, _to, _value);
    }

    function sendBounty(address _to, uint256 _value) onlyOwner() {
        bounty = safeSub(bounty, _value);
        balances[_to] = safeAdd(balances[_to], _value);
        TokensSent(_to, _value);
        Transfer(owner, _to, _value);
    }

    function sendSupplyTokens(address _to, uint256 _value) onlyOwner() {
        balances[owner] = safeSub(balances[owner], _value);
        balances[_to] = safeAdd(balances[_to], _value);
        TokensSent(_to, _value);
        Transfer(owner, _to, _value);
    }


    function transfer(address _to, uint256 _value) isAvailable() returns (bool success) {
        return super.transfer(_to, _value);
    }

    function transferFrom(address _from, address _to, uint256 _value) isAvailable() returns (bool success) {
        return super.transferFrom(_from, _to, _value);
    }

    function burnRemainingTokens() isAvailable() onlyOwner() {
        Burn(owner, balances[owner]);
        balances[owner] = 0;
    }

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

    modifier isAvailable() {
        require(!halted && !freeze);
        _;
    }

    function() payable {
        buy();
    }

    function freeze() onlyOwner() {
         freeze = true;
    }

    function unFreeze() onlyOwner() {
         freeze = false;
    }

    function changeOwner(address _to) onlyOwner() {
        balances[_to] = balances[owner];
        balances[owner] = 0;
        owner = _to;
    }

    function changeFounder(address _to) onlyOwner() {
        balances[_to] = balances[founder];
        balances[founder] = 0;
        founder = _to;
    }
}

Please enter a contract address above to load the contract details and source code.

Context size (optional):