ETH Price: $2,144.97 (+4.77%)

Transaction Decoder

Block:
18129248 at Sep-13-2023 06:45:11 PM +UTC
Transaction Fee:
0.00119013206352291 ETH $2.55
Gas Used:
72,885 Gas / 16.328902566 Gwei

Account State Difference:

  Address   Before After State Difference Code
0x6D0E0afF...E830c4013
(beaverbuild)
12.211905355100142467 Eth12.211912643600142467 Eth0.0000072885
0xeCAB3064...F8f51fE8D
(OnChainDynamics: Deployer)
114.49531616476643215 Eth
Nonce: 44
114.49412603270290924 Eth
Nonce: 45
0.00119013206352291

Execution Trace

ClaimContract.addData( wallet=[0xfAE0dee509498F98fd912D021F0c3ba89344A83C, 0x52E7bdE89Fcbd1e1C656Db1C08DdE45D82447e25], amount=[400000, 700000] )
pragma solidity 0.8.18;

//SPDX-License-Identifier: MIT Licensed

interface IERC20 {
    function name() external view returns (string memory);

    function symbol() external view returns (string memory);

    function decimals() external view returns (uint8);

    function totalSupply() external view returns (uint256);

    function balanceOf(address owner) external view returns (uint256);

    function allowance(
        address owner,
        address spender
    ) external view returns (uint256);

    function approve(address spender, uint256 value) external;

    function transfer(address to, uint256 value) external;

    function transferFrom(address from, address to, uint256 value) external;

    event Approval(
        address indexed owner,
        address indexed spender,
        uint256 value
    );
    event Transfer(address indexed from, address indexed to, uint256 value);
}

contract ClaimContract {
    IERC20 public TOKEN;

    address public owner;
    uint256 public totalTokenClaimed;
    bool public enableClaim;
    mapping(address => uint256) public wallets;

    modifier onlyOwner() {
        require(msg.sender == owner, " Not an owner");
        _;
    }

    constructor(address _owner, address _TOKEN) {
        owner = _owner;
        TOKEN = IERC20(_TOKEN);
    }

    function addData(
        address[] memory wallet,
        uint256[] memory amount
    ) public onlyOwner {
        for (uint256 i = 0; i < wallet.length; i++) {
            wallets[wallet[i]] += amount[i];
        }
    }

    function Claim() public {
        require(enableClaim == true, "wait for owner to start claim");
        require(wallets[msg.sender] > 0, "already claimed");
        TOKEN.transfer(msg.sender, wallets[msg.sender] * 1e18);
        wallets[msg.sender] = 0;
    }

    // transfer ownership
    function EnableClaim(bool _state) external onlyOwner {
        enableClaim = _state;
    }

    // transfer ownership
    function changeOwner(address payable _newOwner) external onlyOwner {
        owner = _newOwner;
    }

    // change tokens
    function changeToken(address _token) external onlyOwner {
        TOKEN = IERC20(_token);
    }

    // to draw out tokens
    function transferStuckTokens(
        IERC20 token,
        uint256 _value
    ) external onlyOwner {
        token.transfer(msg.sender, _value);
    }
 
}