ETH Price: $2,529.91 (-0.77%)

Transaction Decoder

Block:
19517887 at Mar-26-2024 10:01:23 AM +UTC
Transaction Fee:
0.001458109326243787 ETH $3.69
Gas Used:
59,353 Gas / 24.566733379 Gwei

Emitted Events:

134 StandardToken.Transfer( from=[Receiver] 0xf42408c7e7e5dac41332747c8cedf539d97859dd, to=[Sender] 0x74dec05e5b894b0efec69cdf6316971802a2f9a1, value=2000000000000000000 )
135 0x2754b28227f041a66c46509d5620782bfc4766ef.0xa64da754fccf55aa65a1f0128a648633fade3884b236e879ee9f64c78df5d5d7( 0xa64da754fccf55aa65a1f0128a648633fade3884b236e879ee9f64c78df5d5d7, 0x000000000000000000000000f42408c7e7e5dac41332747c8cedf539d97859dd, 0x00000000000000000000000074dec05e5b894b0efec69cdf6316971802a2f9a1, 0x0000000000000000000000004a220e6096b25eadb88358cb44068a3248254675, 0000000000000000000000000000000000000000000000001bc16d674ec80000 )

Account State Difference:

  Address   Before After State Difference Code
0x4a220E60...248254675
0x74dEc05E...802A2F9a1
(Bitpanda 3)
330.633475054097715315 Eth
Nonce: 994710
330.632016944771471528 Eth
Nonce: 994711
0.001458109326243787
(beaverbuild)
7.982105914783562893 Eth7.982194944283562893 Eth0.0000890295

Execution Trace

0xf42408c7e7e5dac41332747c8cedf539d97859dd.6ea056a9( )
  • 0x2754b28227f041a66c46509d5620782bfc4766ef.3c18d318( )
  • 0x5e85f6cdb466771b870757658593d073b8f3f9c8.6ea056a9( )
    • 0x2754b28227f041a66c46509d5620782bfc4766ef.CALL( )
    • 0x2754b28227f041a66c46509d5620782bfc4766ef.CALL( )
    • 0x2754b28227f041a66c46509d5620782bfc4766ef.CALL( )
    • StandardToken.balanceOf( _owner=0xF42408c7E7e5dac41332747C8CEdf539d97859DD ) => ( balance=2000000000000000000 )
    • StandardToken.transfer( _to=0x74dEc05E5b894b0EfEc69Cdf6316971802A2F9a1, _value=2000000000000000000 ) => ( True )
    • 0x2754b28227f041a66c46509d5620782bfc4766ef.28090abb( )
      pragma solidity ^0.4.21;
      
      /**
       * @title ERC20Basic
       * @dev Simpler version of ERC20 interface
       * @dev see https://github.com/ethereum/EIPs/issues/179
       */
      contract ERC20Basic {
        function totalSupply() public view returns (uint256);
        function balanceOf(address who) public view returns (uint256);
        function transfer(address to, uint256 value) public returns (bool);
        event Transfer(address indexed from, address indexed to, uint256 value);
      }
      
      /**
       * @title SafeMath
       * @dev Math operations with safety checks that throw on error
       */
      library SafeMath {
      
        /**
         * @dev Multiplies two numbers, throws on overflow.
         */
        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;
        }
      
        /**
         * @dev Integer division of two numbers, truncating the quotient.
         */
        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;
        }
      
        /**
         * @dev Subtracts two numbers, throws on overflow (i.e. if subtrahend is greater than minuend).
         */
        function sub(uint256 a, uint256 b) internal pure returns (uint256) {
          assert(b <= a);
          return a - b;
        }
      
        /**
         * @dev Adds two numbers, throws on overflow.
         */
        function add(uint256 a, uint256 b) internal pure returns (uint256) {
          uint256 c = a + b;
          assert(c >= a);
          return c;
        }
      }
      
      /**
       * @title Basic token
       * @dev Basic version of StandardToken, with no allowances.
       */
      contract BasicToken is ERC20Basic {
        using SafeMath for uint256;
      
        mapping(address => uint256) balances;
      
        uint256 totalSupply_ = 45467000000000000000000000;
      
        /**
        * @dev total number of tokens in existence
        */
        function totalSupply() public view returns (uint256) {
          return totalSupply_;
        }
      
        /**
        * @dev transfer token for a specified address
        * @param _to The address to transfer to.
        * @param _value The amount to be transferred.
        */
        function transfer(address _to, uint256 _value) public returns (bool) {
          require(_to != address(0));
          require(_value <= balances[msg.sender]);
      
          // SafeMath.sub will throw if there is not enough balance.
          balances[msg.sender] = balances[msg.sender].sub(_value);
          balances[_to] = balances[_to].add(_value);
          emit Transfer(msg.sender, _to, _value);
          return true;
        }
      
        /**
        * @dev Gets the balance of the specified address.
        * @param _owner The address to query the the balance of.
        * @return An uint256 representing the amount owned by the passed address.
        */
        function balanceOf(address _owner) public view returns (uint256 balance) {
          return balances[_owner];
        }
      
      }
      
      /**
       * @title ERC20 interface
       * @dev see https://github.com/ethereum/EIPs/issues/20
       */
      contract ERC20 is ERC20Basic {
        function allowance(address owner, address spender) public view returns (uint256);
        function transferFrom(address from, address to, uint256 value) public returns (bool);
        function approve(address spender, uint256 value) public returns (bool);
        event Approval(address indexed owner, address indexed spender, uint256 value);
      }
      
      /**
       * @title Standard ERC20 token
       *
       * @dev Implementation of the basic standard token.
       * @dev https://github.com/ethereum/EIPs/issues/20
       * @dev Based on code by FirstBlood: https://github.com/Firstbloodio/token/blob/master/smart_contract/FirstBloodToken.sol
       */
      contract StandardToken is ERC20, BasicToken {
      
        // Name of the token
        string constant public name = "Quant";
        // Token abbreviation
        string constant public symbol = "QNT";
        // Decimal places
        uint8 constant public decimals = 18;
        // Zeros after the point
        uint256 constant public DECIMAL_ZEROS = 1000000000000000000;
      
        mapping (address => mapping (address => uint256)) internal allowed;
      
        address public crowdsale;
      
        modifier onlyCrowdsale() {
          require(msg.sender == crowdsale);
          _;
        }
      
        function StandardToken(address _crowdsale) public {
          require(_crowdsale != address(0));
          crowdsale = _crowdsale;
        }
      
        function mint(address _address, uint256 _value) public onlyCrowdsale {
          balances[_address] = balances[_address].add(_value);
          emit Transfer(0, _address, _value);
        }
      
        /**
         * @dev Transfer tokens from one address to another
         * @param _from address The address which you want to send tokens from
         * @param _to address The address which you want to transfer to
         * @param _value uint256 the amount of tokens to be transferred
         */
        function transferFrom(address _from, address _to, uint256 _value) public returns (bool) {
          require(_to != address(0));
          require(_value <= balances[_from]);
          require(_value <= allowed[_from][msg.sender]);
      
          balances[_from] = balances[_from].sub(_value);
          balances[_to] = balances[_to].add(_value);
          allowed[_from][msg.sender] = allowed[_from][msg.sender].sub(_value);
          emit Transfer(_from, _to, _value);
          return true;
        }
      
        /**
         * @dev Approve the passed address to spend the specified amount of tokens on behalf of msg.sender.
         *
         * Beware that changing an allowance with this method brings the risk that someone may use both the old
         * and the new allowance by unfortunate transaction ordering. One possible solution to mitigate this
         * race condition is to first reduce the spender's allowance to 0 and set the desired value afterwards:
         * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
         * @param _spender The address which will spend the funds.
         * @param _value The amount of tokens to be spent.
         */
        function approve(address _spender, uint256 _value) public returns (bool) {
          allowed[msg.sender][_spender] = _value;
          emit Approval(msg.sender, _spender, _value);
          return true;
        }
      
        /**
         * @dev Function to check the amount of tokens that an owner allowed to a spender.
         * @param _owner address The address which owns the funds.
         * @param _spender address The address which will spend the funds.
         * @return A uint256 specifying the amount of tokens still available for the spender.
         */
        function allowance(address _owner, address _spender) public view returns (uint256) {
          return allowed[_owner][_spender];
        }
      
        /**
         * @dev Increase the amount of tokens that an owner allowed to a spender.
         *
         * approve should be called when allowed[_spender] == 0. To increment
         * allowed value is better to use this function to avoid 2 calls (and wait until
         * the first transaction is mined)
         * From MonolithDAO Token.sol
         * @param _spender The address which will spend the funds.
         * @param _addedValue The amount of tokens to increase the allowance by.
         */
        function increaseApproval(address _spender, uint _addedValue) public returns (bool) {
          allowed[msg.sender][_spender] = allowed[msg.sender][_spender].add(_addedValue);
          emit Approval(msg.sender, _spender, allowed[msg.sender][_spender]);
          return true;
        }
      
        /**
         * @dev Decrease the amount of tokens that an owner allowed to a spender.
         *
         * approve should be called when allowed[_spender] == 0. To decrement
         * allowed value is better to use this function to avoid 2 calls (and wait until
         * the first transaction is mined)
         * From MonolithDAO Token.sol
         * @param _spender The address which will spend the funds.
         * @param _subtractedValue The amount of tokens to decrease the allowance by.
         */
        function decreaseApproval(address _spender, uint _subtractedValue) public returns (bool) {
          uint oldValue = allowed[msg.sender][_spender];
          if (_subtractedValue > oldValue) {
            allowed[msg.sender][_spender] = 0;
          } else {
            allowed[msg.sender][_spender] = oldValue.sub(_subtractedValue);
          }
          emit Approval(msg.sender, _spender, allowed[msg.sender][_spender]);
          return true;
        }
      
      }