ETH Price: $1,936.16 (-3.55%)
Gas: 0.06 Gwei

Transaction Decoder

Block:
5876331 at Jun-29-2018 06:38:20 PM +UTC
Transaction Fee:
0.00015332 ETH $0.30
Gas Used:
76,660 Gas / 2 Gwei

Emitted Events:

145 SecretToken.Transfer( _from=[Receiver] SecretToken, _to=[Sender] 0x9e1dc18b3cd5d34066af42932860fa45ade0b0a4, _value=200000000000000000000 )

Account State Difference:

  Address   Before After State Difference Code
0x9E1Dc18b...5aDE0B0A4
0.0011214835 Eth
Nonce: 29
0.0009681635 Eth
Nonce: 30
0.00015332
(MiningPoolHub: Old Address)
23,406.85691737550307561 Eth23,406.85707069550307561 Eth0.00015332
0xEBBDcd19...550cB911d

Execution Trace

SecretToken.CALL( )
  • 0xfbedaa32a23f36f20cddc2150b764042b4eefd25.CALL( )
    /*
    
    Website: http://secret.foundation/
    
    */
    
    pragma solidity 0.4.18;
    
    contract SecretToken {
        string public symbol = "SECRET";
        string public name = "Secret Token";
        uint8 public constant decimals = 18;
        uint256 _totalSupply = 0;
        uint256 _MaxDistribPublicSupply = 300000000;
        uint256 _OwnerDistribSupply = 0;
        uint256 _CurrentDistribPublicSupply = 0;
        uint256 _FreeTokens = 200;
        uint256 _Multiplier1 = 2;
        uint256 _Multiplier2 = 3;
        uint256 _LimitMultiplier1 = 5e15;
        uint256 _LimitMultiplier2 = 14e15;
        uint256 _HighDonateLimit = 1e18;
        uint256 _BonusTokensPerETHdonated = 300000;
        address _DistribFundsReceiverAddress = 0;
        address _remainingTokensReceiverAddress = 0;
        address owner = 0;
        bool setupDone = false;
        bool IsDistribRunning = false;
        bool DistribStarted = false;
    
        event Transfer(address indexed _from, address indexed _to, uint256 _value);
        event Approval(address indexed _owner, address indexed _spender, uint256 _value);
        event Burn(address indexed _owner, uint256 _value);
    
        mapping(address => uint256) balances;
        mapping(address => mapping(address => uint256)) allowed;
        mapping(address => bool) public Claimed;
    
        modifier onlyOwner() {
            require(msg.sender == owner);
            _;
        }
    
        function SecretToken() public {
            owner = msg.sender;
        }
    
        function() public payable {
            if (IsDistribRunning) {
                uint256 _amount;
                if (((_CurrentDistribPublicSupply + _amount) > _MaxDistribPublicSupply) && _MaxDistribPublicSupply > 0) revert();
                if (!_DistribFundsReceiverAddress.send(msg.value)) revert();
                if (Claimed[msg.sender] == false) {
                    _amount = _FreeTokens * 1e18;
                    _CurrentDistribPublicSupply += _amount;
                    balances[msg.sender] += _amount;
                    _totalSupply += _amount;
                    Transfer(this, msg.sender, _amount);
                    Claimed[msg.sender] = true;
                }
    
                require(msg.value <= _HighDonateLimit);
    
                if (msg.value >= 1e15) {
                    if (msg.value >= _LimitMultiplier2) {
                        _amount = msg.value * _BonusTokensPerETHdonated * _Multiplier2;
                    } else {
                        if (msg.value >= _LimitMultiplier1) {
                            _amount = msg.value * _BonusTokensPerETHdonated * _Multiplier1;
                        } else {
    
                            _amount = msg.value * _BonusTokensPerETHdonated;
    
                        }
    
                    }
    
                    _CurrentDistribPublicSupply += _amount;
                    balances[msg.sender] += _amount;
                    _totalSupply += _amount;
                    Transfer(this, msg.sender, _amount);
                }
    
    
    
            } else {
                revert();
            }
        }
    
        function SetupToken(string tokenName, string tokenSymbol, uint256 BonusTokensPerETHdonated, uint256 MaxDistribPublicSupply, uint256 OwnerDistribSupply, address remainingTokensReceiverAddress, address DistribFundsReceiverAddress, uint256 FreeTokens) public {
            if (msg.sender == owner && !setupDone) {
                symbol = tokenSymbol;
                name = tokenName;
                _FreeTokens = FreeTokens;
                _BonusTokensPerETHdonated = BonusTokensPerETHdonated;
                _MaxDistribPublicSupply = MaxDistribPublicSupply * 1e18;
                if (OwnerDistribSupply > 0) {
                    _OwnerDistribSupply = OwnerDistribSupply * 1e18;
                    _totalSupply = _OwnerDistribSupply;
                    balances[owner] = _totalSupply;
                    _CurrentDistribPublicSupply += _totalSupply;
                    Transfer(this, owner, _totalSupply);
                }
                _DistribFundsReceiverAddress = DistribFundsReceiverAddress;
                if (_DistribFundsReceiverAddress == 0) _DistribFundsReceiverAddress = owner;
                _remainingTokensReceiverAddress = remainingTokensReceiverAddress;
    
                setupDone = true;
            }
        }
    
        function SetupMultipliers(uint256 Multiplier1inX, uint256 Multiplier2inX, uint256 LimitMultiplier1inWei, uint256 LimitMultiplier2inWei, uint256 HighDonateLimitInWei) onlyOwner public {
            _Multiplier1 = Multiplier1inX;
            _Multiplier2 = Multiplier2inX;
            _LimitMultiplier1 = LimitMultiplier1inWei;
            _LimitMultiplier2 = LimitMultiplier2inWei;
            _HighDonateLimit = HighDonateLimitInWei;
        }
    
        function SetBonus(uint256 BonusTokensPerETHdonated) onlyOwner public {
            _BonusTokensPerETHdonated = BonusTokensPerETHdonated;
        }
    
        function SetFreeTokens(uint256 FreeTokens) onlyOwner public {
            _FreeTokens = FreeTokens;
        }
    
        function StartDistrib() public returns(bool success) {
            if (msg.sender == owner && !DistribStarted && setupDone) {
                DistribStarted = true;
                IsDistribRunning = true;
            } else {
                revert();
            }
            return true;
        }
    
        function StopDistrib() public returns(bool success) {
            if (msg.sender == owner && IsDistribRunning) {
                if (_remainingTokensReceiverAddress != 0 && _MaxDistribPublicSupply > 0) {
                    uint256 _remainingAmount = _MaxDistribPublicSupply - _CurrentDistribPublicSupply;
                    if (_remainingAmount > 0) {
                        balances[_remainingTokensReceiverAddress] += _remainingAmount;
                        _totalSupply += _remainingAmount;
                        Transfer(this, _remainingTokensReceiverAddress, _remainingAmount);
                    }
                }
                DistribStarted = false;
                IsDistribRunning = false;
            } else {
                revert();
            }
            return true;
        }
    
        function distribution(address[] addresses, uint256 _amount) onlyOwner public {
    
            uint256 _remainingAmount = _MaxDistribPublicSupply - _CurrentDistribPublicSupply;
            require(addresses.length <= 255);
            require(_amount <= _remainingAmount);
            _amount = _amount * 1e18;
    
            for (uint i = 0; i < addresses.length; i++) {
                require(_amount <= _remainingAmount);
                _CurrentDistribPublicSupply += _amount;
                balances[addresses[i]] += _amount;
                _totalSupply += _amount;
                Transfer(this, addresses[i], _amount);
    
            }
    
            if (_CurrentDistribPublicSupply >= _MaxDistribPublicSupply) {
                DistribStarted = false;
                IsDistribRunning = false;
            }
        }
    
        function distributeAmounts(address[] addresses, uint256[] amounts) onlyOwner public {
    
            uint256 _remainingAmount = _MaxDistribPublicSupply - _CurrentDistribPublicSupply;
            uint256 _amount;
    
            require(addresses.length <= 255);
            require(addresses.length == amounts.length);
    
            for (uint8 i = 0; i < addresses.length; i++) {
                _amount = amounts[i] * 1e18;
                require(_amount <= _remainingAmount);
                _CurrentDistribPublicSupply += _amount;
                balances[addresses[i]] += _amount;
                _totalSupply += _amount;
                Transfer(this, addresses[i], _amount);
    
    
                if (_CurrentDistribPublicSupply >= _MaxDistribPublicSupply) {
                    DistribStarted = false;
                    IsDistribRunning = false;
                }
            }
        }
    
        function BurnTokens(uint256 amount) public returns(bool success) {
            uint256 _amount = amount * 1e18;
            if (balances[msg.sender] >= _amount) {
                balances[msg.sender] -= _amount;
                _totalSupply -= _amount;
                Burn(msg.sender, _amount);
                Transfer(msg.sender, 0, _amount);
            } else {
                revert();
            }
            return true;
        }
    
        function totalSupply() public constant returns(uint256 totalSupplyValue) {
            return _totalSupply;
        }
    
        function MaxDistribPublicSupply_() public constant returns(uint256 MaxDistribPublicSupply) {
            return _MaxDistribPublicSupply;
        }
    
        function OwnerDistribSupply_() public constant returns(uint256 OwnerDistribSupply) {
            return _OwnerDistribSupply;
        }
    
        function CurrentDistribPublicSupply_() public constant returns(uint256 CurrentDistribPublicSupply) {
            return _CurrentDistribPublicSupply;
        }
    
        function RemainingTokensReceiverAddress() public constant returns(address remainingTokensReceiverAddress) {
            return _remainingTokensReceiverAddress;
        }
    
        function DistribFundsReceiverAddress() public constant returns(address DistribfundsReceiver) {
            return _DistribFundsReceiverAddress;
        }
    
        function Owner() public constant returns(address ownerAddress) {
            return owner;
        }
    
        function SetupDone() public constant returns(bool setupDoneFlag) {
            return setupDone;
        }
    
        function IsDistribRunningFalg_() public constant returns(bool IsDistribRunningFalg) {
            return IsDistribRunning;
        }
    
        function IsDistribStarted() public constant returns(bool IsDistribStartedFlag) {
            return DistribStarted;
        }
    
        function balanceOf(address _owner) public constant returns(uint256 balance) {
            return balances[_owner];
        }
    
        function transfer(address _to, uint256 _amount) public returns(bool success) {
            if (balances[msg.sender] >= _amount &&
                _amount > 0 &&
                balances[_to] + _amount > balances[_to]) {
                balances[msg.sender] -= _amount;
                balances[_to] += _amount;
                Transfer(msg.sender, _to, _amount);
                return true;
            } else {
                return false;
            }
        }
    
        function transferFrom(
            address _from,
            address _to,
            uint256 _amount
        ) public returns(bool success) {
            if (balances[_from] >= _amount &&
                allowed[_from][msg.sender] >= _amount &&
                _amount > 0 &&
                balances[_to] + _amount > balances[_to]) {
                balances[_from] -= _amount;
                allowed[_from][msg.sender] -= _amount;
                balances[_to] += _amount;
                Transfer(_from, _to, _amount);
                return true;
            } else {
                return false;
            }
        }
    
        function approve(address _spender, uint256 _amount) public returns(bool success) {
            allowed[msg.sender][_spender] = _amount;
            Approval(msg.sender, _spender, _amount);
            return true;
        }
    
        function allowance(address _owner, address _spender) public constant returns(uint256 remaining) {
            return allowed[_owner][_spender];
        }
    }