ETH Price: $1,980.32 (-4.62%)

Transaction Decoder

Block:
24176848 at Jan-06-2026 04:32:11 PM +UTC
Transaction Fee:
0.000043808194407276 ETH $0.09
Gas Used:
70,218 Gas / 0.623888382 Gwei

Emitted Events:

617 DuskToken.Transfer( from=[Receiver] 0xbee3211ab312a8d065c4fef0247448e17a8da000, to=0xC17A40852E4BfE04Bc81Af355Fdf132C539bA753, value=7985000000000000000000 )
618 0xbee3211ab312a8d065c4fef0247448e17a8da000.0xb67719fc33c1f17d31bf3a698690d62066b1e0bae28fcd3c56cf2c015c2863d6( 0xb67719fc33c1f17d31bf3a698690d62066b1e0bae28fcd3c56cf2c015c2863d6, 0x000000000000000000000000940a2db1b7008b6c776d4faaca729d6d4a4aa551, 0x000000000000000000000000c17a40852e4bfe04bc81af355fdf132c539ba753, 0000000000000000000000000000000000000000000001b0de22b9a826240000 )

Account State Difference:

  Address   Before After State Difference Code
(Titan Builder)
16.831318870431229223 Eth16.831318870431369659 Eth0.000000000000140436
0x940a2dB1...d4A4AA551
0xBEEDD84b...280678888
8.671993701142906961 Eth
Nonce: 197294
8.671949892948499685 Eth
Nonce: 197295
0.000043808194407276

Execution Trace

Market Maker: 0xbee...000.69328dec( )
  • 0x4dffeb6b78e57aab41d09e88c796e27cf314de6b.69328dec( )
    • DuskToken.transfer( to=0xC17A40852E4BfE04Bc81Af355Fdf132C539bA753, value=7985000000000000000000 ) => ( True )
      pragma solidity 0.4.25;
      
      // File: openzeppelin-solidity/contracts/token/ERC20/IERC20.sol
      
      /**
       * @title ERC20 interface
       * @dev see https://github.com/ethereum/EIPs/issues/20
       */
      interface IERC20 {
        function totalSupply() external view returns (uint256);
      
        function balanceOf(address who) external view returns (uint256);
      
        function allowance(address owner, address spender)
          external view returns (uint256);
      
        function transfer(address to, uint256 value) external returns (bool);
      
        function approve(address spender, uint256 value)
          external returns (bool);
      
        function transferFrom(address from, address to, uint256 value)
          external returns (bool);
      
        event Transfer(
          address indexed from,
          address indexed to,
          uint256 value
        );
      
        event Approval(
          address indexed owner,
          address indexed spender,
          uint256 value
        );
      }
      
      // File: openzeppelin-solidity/contracts/math/SafeMath.sol
      
      /**
       * @title SafeMath
       * @dev Math operations with safety checks that revert on error
       */
      library SafeMath {
      
        /**
        * @dev Multiplies two numbers, reverts on overflow.
        */
        function mul(uint256 a, uint256 b) internal pure returns (uint256) {
          // Gas optimization: this is cheaper than requiring 'a' not being zero, but the
          // benefit is lost if 'b' is also tested.
          // See: https://github.com/OpenZeppelin/openzeppelin-solidity/pull/522
          if (a == 0) {
            return 0;
          }
      
          uint256 c = a * b;
          require(c / a == b);
      
          return c;
        }
      
        /**
        * @dev Integer division of two numbers truncating the quotient, reverts on division by zero.
        */
        function div(uint256 a, uint256 b) internal pure returns (uint256) {
          require(b > 0); // Solidity only automatically asserts 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, reverts on overflow (i.e. if subtrahend is greater than minuend).
        */
        function sub(uint256 a, uint256 b) internal pure returns (uint256) {
          require(b <= a);
          uint256 c = a - b;
      
          return c;
        }
      
        /**
        * @dev Adds two numbers, reverts on overflow.
        */
        function add(uint256 a, uint256 b) internal pure returns (uint256) {
          uint256 c = a + b;
          require(c >= a);
      
          return c;
        }
      
        /**
        * @dev Divides two numbers and returns the remainder (unsigned integer modulo),
        * reverts when dividing by zero.
        */
        function mod(uint256 a, uint256 b) internal pure returns (uint256) {
          require(b != 0);
          return a % b;
        }
      }
      
      // File: openzeppelin-solidity/contracts/token/ERC20/ERC20.sol
      
      /**
       * @title Standard ERC20 token
       *
       * @dev Implementation of the basic standard token.
       * https://github.com/ethereum/EIPs/blob/master/EIPS/eip-20.md
       * Originally based on code by FirstBlood: https://github.com/Firstbloodio/token/blob/master/smart_contract/FirstBloodToken.sol
       */
      contract ERC20 is IERC20 {
        using SafeMath for uint256;
      
        mapping (address => uint256) private _balances;
      
        mapping (address => mapping (address => uint256)) private _allowed;
      
        uint256 private _totalSupply;
      
        /**
        * @dev Total number of tokens in existence
        */
        function totalSupply() public view returns (uint256) {
          return _totalSupply;
        }
      
        /**
        * @dev Gets the balance of the specified address.
        * @param owner The address to query the balance of.
        * @return An uint256 representing the amount owned by the passed address.
        */
        function balanceOf(address owner) public view returns (uint256) {
          return _balances[owner];
        }
      
        /**
         * @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 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) {
          _transfer(msg.sender, 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) {
          require(spender != address(0));
      
          _allowed[msg.sender][spender] = value;
          emit Approval(msg.sender, spender, value);
          return true;
        }
      
        /**
         * @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(value <= _allowed[from][msg.sender]);
      
          _allowed[from][msg.sender] = _allowed[from][msg.sender].sub(value);
          _transfer(from, to, value);
          return true;
        }
      
        /**
         * @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 increaseAllowance(
          address spender,
          uint256 addedValue
        )
          public
          returns (bool)
        {
          require(spender != address(0));
      
          _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 decreaseAllowance(
          address spender,
          uint256 subtractedValue
        )
          public
          returns (bool)
        {
          require(spender != address(0));
      
          _allowed[msg.sender][spender] = (
            _allowed[msg.sender][spender].sub(subtractedValue));
          emit Approval(msg.sender, spender, _allowed[msg.sender][spender]);
          return true;
        }
      
        /**
        * @dev Transfer token for a specified addresses
        * @param from The address to transfer from.
        * @param to The address to transfer to.
        * @param value The amount to be transferred.
        */
        function _transfer(address from, address to, uint256 value) internal {
          require(value <= _balances[from]);
          require(to != address(0));
      
          _balances[from] = _balances[from].sub(value);
          _balances[to] = _balances[to].add(value);
          emit Transfer(from, to, value);
        }
      
        /**
         * @dev Internal function that mints an amount of the token and assigns it to
         * an account. This encapsulates the modification of balances such that the
         * proper events are emitted.
         * @param account The account that will receive the created tokens.
         * @param value The amount that will be created.
         */
        function _mint(address account, uint256 value) internal {
          require(account != 0);
          _totalSupply = _totalSupply.add(value);
          _balances[account] = _balances[account].add(value);
          emit Transfer(address(0), account, value);
        }
      
        /**
         * @dev Internal function that burns an amount of the token of a given
         * account.
         * @param account The account whose tokens will be burnt.
         * @param value The amount that will be burnt.
         */
        function _burn(address account, uint256 value) internal {
          require(account != 0);
          require(value <= _balances[account]);
      
          _totalSupply = _totalSupply.sub(value);
          _balances[account] = _balances[account].sub(value);
          emit Transfer(account, address(0), value);
        }
      
        /**
         * @dev Internal function that burns an amount of the token of a given
         * account, deducting from the sender's allowance for said account. Uses the
         * internal burn function.
         * @param account The account whose tokens will be burnt.
         * @param value The amount that will be burnt.
         */
        function _burnFrom(address account, uint256 value) internal {
          require(value <= _allowed[account][msg.sender]);
      
          // Should https://github.com/OpenZeppelin/zeppelin-solidity/issues/707 be accepted,
          // this function needs to emit an event with the updated approval.
          _allowed[account][msg.sender] = _allowed[account][msg.sender].sub(
            value);
          _burn(account, value);
        }
      }
      
      // File: contracts/DuskToken.sol
      
      contract DuskToken is ERC20 {
          using SafeMath for uint256;
          
          string public constant name = "Dusk Network";
          string public constant symbol = "DUSK";
          uint8 public constant decimals = 18;
          
          constructor() public {
              // Send all 500,000,000 tokens to contract creator
              _mint(msg.sender, uint256(500000000).mul(10**uint(decimals)));
          }
      }