ETH Price: $2,544.49 (-2.55%)

Contract

0x82746E26cDB0D95D12802b895Ba81cE0f261f140
 

Overview

ETH Balance

0 ETH

Eth Value

$0.00

Multichain Info

No addresses found
Transaction Hash
Method
Block
From
To
Set Enabled169575892023-04-01 23:34:23548 days ago1680392063IN
0x82746E26...0f261f140
0 ETH0.000438118.31156693
Burn And Mint169575742023-04-01 23:31:23548 days ago1680391883IN
0x82746E26...0f261f140
0 ETH0.0063833918.51293644
Burn And Mint169575212023-04-01 23:20:23548 days ago1680391223IN
0x82746E26...0f261f140
0 ETH0.0027477417.2546412
Burn And Mint169573922023-04-01 22:54:23548 days ago1680389663IN
0x82746E26...0f261f140
0 ETH0.0055175816.00196443
Burn And Mint169573792023-04-01 22:51:47548 days ago1680389507IN
0x82746E26...0f261f140
0 ETH0.0062188818.03584106
Burn And Mint169573572023-04-01 22:47:23548 days ago1680389243IN
0x82746E26...0f261f140
0 ETH0.0024703916.81149762
Burn And Mint169573272023-04-01 22:41:11548 days ago1680388871IN
0x82746E26...0f261f140
0 ETH0.0055076515.97315867
Burn And Mint169572942023-04-01 22:34:35548 days ago1680388475IN
0x82746E26...0f261f140
0 ETH0.00377116.16706912
Burn And Mint169572622023-04-01 22:28:11548 days ago1680388091IN
0x82746E26...0f261f140
0 ETH0.0039013716.72580379
Burn And Mint169572312023-04-01 22:21:59548 days ago1680387719IN
0x82746E26...0f261f140
0 ETH0.0056749616.45837514
Burn And Mint169572002023-04-01 22:15:35548 days ago1680387335IN
0x82746E26...0f261f140
0 ETH0.0046362916.05881593
Burn And Mint169570972023-04-01 21:54:47548 days ago1680386087IN
0x82746E26...0f261f140
0 ETH0.0025737116.16176617
Burn And Mint169570372023-04-01 21:42:35548 days ago1680385355IN
0x82746E26...0f261f140
0 ETH0.0049042817.74300132
Burn And Mint169569422023-04-01 21:23:23548 days ago1680384203IN
0x82746E26...0f261f140
0 ETH0.006268818.18061233
Burn And Mint169569322023-04-01 21:21:23548 days ago1680384083IN
0x82746E26...0f261f140
0 ETH0.0032469122.09583037
Burn And Mint169569152023-04-01 21:17:59548 days ago1680383879IN
0x82746E26...0f261f140
0 ETH0.0061309217.78075327
Burn And Mint169569102023-04-01 21:16:59548 days ago1680383819IN
0x82746E26...0f261f140
0 ETH0.0063265618.60716018
Burn And Mint169567932023-04-01 20:53:11548 days ago1680382391IN
0x82746E26...0f261f140
0 ETH0.004705817.02491433
Burn And Mint169567932023-04-01 20:53:11548 days ago1680382391IN
0x82746E26...0f261f140
0 ETH0.0027111617.02491433
Burn And Mint169566412023-04-01 20:22:23548 days ago1680380543IN
0x82746E26...0f261f140
0 ETH0.0029820718.72611865
Burn And Mint169566142023-04-01 20:16:59548 days ago1680380219IN
0x82746E26...0f261f140
0 ETH0.0064463918.6956594
Burn And Mint169561542023-04-01 18:43:35548 days ago1680374615IN
0x82746E26...0f261f140
0 ETH0.0054176219.60017115
Burn And Mint169561452023-04-01 18:41:47548 days ago1680374507IN
0x82746E26...0f261f140
0 ETH0.0061155321.86055226
Burn And Mint169561392023-04-01 18:40:35548 days ago1680374435IN
0x82746E26...0f261f140
0 ETH0.0037516922.86921636
Burn And Mint169559742023-04-01 18:06:59548 days ago1680372419IN
0x82746E26...0f261f140
0 ETH0.0078558122.78321722
View all transactions

View more zero value Internal Transactions in Advanced View mode

Advanced mode:
Loading...
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
BalloonBurn

Compiler Version
v0.8.18+commit.87f61d96

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion
File 1 of 6 : BalloonBurn.sol
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.18;

import "./IManifoldERC1155.sol";
import "./IBurnExtension.sol";
import "@openzeppelin/contracts/access/Ownable.sol";

contract BalloonBurn is Ownable {
    IManifoldERC1155 public balloonContract =
        IManifoldERC1155(0x1386f70A946Cf9F06E32190cFB2F4F4f18365b87);
    IBurnExtension public balloonBurn = IBurnExtension(0xfa1B15dF09c2944a91A2F9F10A6133090d4119BD);

    uint256 pinkBurnIndex = 561955056;
    uint256 blackBurnIndex = 547537136;
    uint256 blueBurnIndex = 547496176;
    uint256 greenBurnIndex = 547492080;

    uint256 public ticketTokenId = 2;
    uint256 public pinkBalloonTokenId = 3;
    uint256 public blackBalloonTokenId = 4;
    uint256 public blueBalloonTokenId = 5;
    uint256 public greenBalloonTokenId = 6;

    uint256[] public ticketTokenIds;

    bool public enabled;

    constructor() {
        enabled = false;

        ticketTokenIds = new uint256[](1);
        ticketTokenIds[0] = ticketTokenId;
    }

    event BalloonMint(
        address indexed user,
        uint32 pinkBalloons,
        uint32 blackBalloons,
        uint32 blueBalloons,
        uint32 greenBalloons
    );

    function burnAndMint(
        uint32 pinkBalloons,
        uint32 blackBalloons,
        uint32 blueBalloons,
        uint32 greenBalloons
    ) external {
        require(enabled, "BalloonBurn: Contract is not enabled");
        require(
            pinkBalloons + blackBalloons + blueBalloons + greenBalloons > 0,
            "BalloonBurn: You must burn at least one ticket"
        );

        uint256[] memory ticketAmounts = new uint256[](1);
        ticketAmounts[0] = pinkBalloons + blackBalloons + blueBalloons + greenBalloons;
        balloonContract.burn(msg.sender, ticketTokenIds, ticketAmounts);

        address[] memory addresses = new address[](1);
        addresses[0] = msg.sender;
        if (pinkBalloons > 0) {
            uint32[] memory pinkBalloonsArr = new uint32[](1);
            pinkBalloonsArr[0] = pinkBalloons;
            balloonBurn.airdrop(
                address(balloonContract),
                pinkBurnIndex,
                addresses,
                pinkBalloonsArr
            );
        }
        if (blackBalloons > 0) {
            uint32[] memory blackBalloonsArr = new uint32[](1);
            blackBalloonsArr[0] = blackBalloons;
            balloonBurn.airdrop(
                address(balloonContract),
                blackBurnIndex,
                addresses,
                blackBalloonsArr
            );
        }
        if (blueBalloons > 0) {
            uint32[] memory blueBalloonsArr = new uint32[](1);
            blueBalloonsArr[0] = blueBalloons;
            balloonBurn.airdrop(
                address(balloonContract),
                blueBurnIndex,
                addresses,
                blueBalloonsArr
            );
        }
        if (greenBalloons > 0) {
            uint32[] memory greenBalloonsArr = new uint32[](1);
            greenBalloonsArr[0] = greenBalloons;
            balloonBurn.airdrop(
                address(balloonContract),
                greenBurnIndex,
                addresses,
                greenBalloonsArr
            );
        }

        emit BalloonMint(msg.sender, pinkBalloons, blackBalloons, blueBalloons, greenBalloons);
    }

    function setEnabled(bool newState) external onlyOwner {
        enabled = newState;
    }

    function getInfo(
        address user
    )
        public
        view
        returns (
            uint256 ticketAmount,
            uint256 balance,
            bool hasApproved,
            bool isEnabled,
            uint256 pinkBalloonAmount,
            uint256 blackBalloonAmount,
            uint256 blueBalloonAmount,
            uint256 greenBalloonAmount,
            uint256 pinkBalloonTotalAmount,
            uint256 blackBalloonTotalAmount,
            uint256 blueBalloonTotalAmount,
            uint256 greenBalloonTotalAmount
        )
    {
        if (user == address(0)) {
            ticketAmount = 0;
            hasApproved = false;
            balance = 0;

            pinkBalloonAmount = 0;
            blackBalloonAmount = 0;
            blueBalloonAmount = 0;
            greenBalloonAmount = 0;
        } else {
            ticketAmount = balloonContract.balanceOf(user, ticketTokenId);
            hasApproved = balloonContract.isApprovedForAll(user, address(this));
            balance = payable(user).balance;

            pinkBalloonAmount = balloonContract.balanceOf(user, pinkBalloonTokenId);
            blackBalloonAmount = balloonContract.balanceOf(user, blackBalloonTokenId);
            blueBalloonAmount = balloonContract.balanceOf(user, blueBalloonTokenId);
            greenBalloonAmount = balloonContract.balanceOf(user, greenBalloonTokenId);
        }

        isEnabled = enabled;

        pinkBalloonTotalAmount = balloonContract.totalSupply(pinkBalloonTokenId);
        blackBalloonTotalAmount = balloonContract.totalSupply(blackBalloonTokenId);
        blueBalloonTotalAmount = balloonContract.totalSupply(blueBalloonTokenId);
        greenBalloonTotalAmount = balloonContract.totalSupply(greenBalloonTokenId);
    }
}

File 2 of 6 : IBurnExtension.sol
//SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.18;

interface IBurnExtension {
    function airdrop(
        address creatorContractAddress,
        uint256 index,
        address[] calldata recipients,
        uint32[] calldata amounts
    ) external;
}

File 3 of 6 : IManifoldERC1155.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.7.0) (token/ERC1155/IERC1155.sol)

pragma solidity ^0.8.0;

import "@openzeppelin/contracts/utils/introspection/IERC165.sol";

/**
 * @dev Required interface of an ERC1155 compliant contract, as defined in the
 * https://eips.ethereum.org/EIPS/eip-1155[EIP].
 *
 * _Available since v3.1._
 */
interface IManifoldERC1155 is IERC165 {
    /**
     * @dev Emitted when `value` tokens of token type `id` are transferred from `from` to `to` by `operator`.
     */
    event TransferSingle(
        address indexed operator,
        address indexed from,
        address indexed to,
        uint256 id,
        uint256 value
    );

    /**
     * @dev Equivalent to multiple {TransferSingle} events, where `operator`, `from` and `to` are the same for all
     * transfers.
     */
    event TransferBatch(
        address indexed operator,
        address indexed from,
        address indexed to,
        uint256[] ids,
        uint256[] values
    );

    /**
     * @dev Emitted when `account` grants or revokes permission to `operator` to transfer their tokens, according to
     * `approved`.
     */
    event ApprovalForAll(address indexed account, address indexed operator, bool approved);

    /**
     * @dev Emitted when the URI for token type `id` changes to `value`, if it is a non-programmatic URI.
     *
     * If an {URI} event was emitted for `id`, the standard
     * https://eips.ethereum.org/EIPS/eip-1155#metadata-extensions[guarantees] that `value` will equal the value
     * returned by {IERC1155MetadataURI-uri}.
     */
    event URI(string value, uint256 indexed id);

    /**
     * @dev Returns the amount of tokens of token type `id` owned by `account`.
     *
     * Requirements:
     *
     * - `account` cannot be the zero address.
     */
    function balanceOf(address account, uint256 id) external view returns (uint256);

    /**
     * @dev xref:ROOT:erc1155.adoc#batch-operations[Batched] version of {balanceOf}.
     *
     * Requirements:
     *
     * - `accounts` and `ids` must have the same length.
     */
    function balanceOfBatch(
        address[] calldata accounts,
        uint256[] calldata ids
    ) external view returns (uint256[] memory);

    /**
     * @dev Grants or revokes permission to `operator` to transfer the caller's tokens, according to `approved`,
     *
     * Emits an {ApprovalForAll} event.
     *
     * Requirements:
     *
     * - `operator` cannot be the caller.
     */
    function setApprovalForAll(address operator, bool approved) external;

    /**
     * @dev Returns true if `operator` is approved to transfer ``account``'s tokens.
     *
     * See {setApprovalForAll}.
     */
    function isApprovedForAll(address account, address operator) external view returns (bool);

    /**
     * @dev Transfers `amount` tokens of token type `id` from `from` to `to`.
     *
     * Emits a {TransferSingle} event.
     *
     * Requirements:
     *
     * - `to` cannot be the zero address.
     * - If the caller is not `from`, it must have been approved to spend ``from``'s tokens via {setApprovalForAll}.
     * - `from` must have a balance of tokens of type `id` of at least `amount`.
     * - If `to` refers to a smart contract, it must implement {IERC1155Receiver-onERC1155Received} and return the
     * acceptance magic value.
     */
    function safeTransferFrom(
        address from,
        address to,
        uint256 id,
        uint256 amount,
        bytes calldata data
    ) external;

    /**
     * @dev xref:ROOT:erc1155.adoc#batch-operations[Batched] version of {safeTransferFrom}.
     *
     * Emits a {TransferBatch} event.
     *
     * Requirements:
     *
     * - `ids` and `amounts` must have the same length.
     * - If `to` refers to a smart contract, it must implement {IERC1155Receiver-onERC1155BatchReceived} and return the
     * acceptance magic value.
     */
    function safeBatchTransferFrom(
        address from,
        address to,
        uint256[] calldata ids,
        uint256[] calldata amounts,
        bytes calldata data
    ) external;

    function totalSupply(uint256 id) external view returns (uint256);

    function mintBaseExisting(
        address[] calldata to,
        uint256[] calldata tokenIds,
        uint256[] calldata amounts
    ) external;

    function burn(address account, uint256[] memory tokenIds, uint256[] memory amounts) external;
}

File 4 of 6 : Ownable.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.7.0) (access/Ownable.sol)

pragma solidity ^0.8.0;

import "../utils/Context.sol";

/**
 * @dev Contract module which provides a basic access control mechanism, where
 * there is an account (an owner) that can be granted exclusive access to
 * specific functions.
 *
 * By default, the owner account will be the one that deploys the contract. This
 * can later be changed with {transferOwnership}.
 *
 * This module is used through inheritance. It will make available the modifier
 * `onlyOwner`, which can be applied to your functions to restrict their use to
 * the owner.
 */
abstract contract Ownable is Context {
    address private _owner;

    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor() {
        _transferOwnership(_msgSender());
    }

    /**
     * @dev Throws if called by any account other than the owner.
     */
    modifier onlyOwner() {
        _checkOwner();
        _;
    }

    /**
     * @dev Returns the address of the current owner.
     */
    function owner() public view virtual returns (address) {
        return _owner;
    }

    /**
     * @dev Throws if the sender is not the owner.
     */
    function _checkOwner() internal view virtual {
        require(owner() == _msgSender(), "Ownable: caller is not the owner");
    }

    /**
     * @dev Leaves the contract without owner. It will not be possible to call
     * `onlyOwner` functions anymore. Can only be called by the current owner.
     *
     * NOTE: Renouncing ownership will leave the contract without an owner,
     * thereby removing any functionality that is only available to the owner.
     */
    function renounceOwnership() public virtual onlyOwner {
        _transferOwnership(address(0));
    }

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     * Can only be called by the current owner.
     */
    function transferOwnership(address newOwner) public virtual onlyOwner {
        require(newOwner != address(0), "Ownable: new owner is the zero address");
        _transferOwnership(newOwner);
    }

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     * Internal function without access restriction.
     */
    function _transferOwnership(address newOwner) internal virtual {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}

File 5 of 6 : Context.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (utils/Context.sol)

pragma solidity ^0.8.0;

/**
 * @dev Provides information about the current execution context, including the
 * sender of the transaction and its data. While these are generally available
 * via msg.sender and msg.data, they should not be accessed in such a direct
 * manner, since when dealing with meta-transactions the account sending and
 * paying for execution may not be the actual sender (as far as an application
 * is concerned).
 *
 * This contract is only required for intermediate, library-like contracts.
 */
abstract contract Context {
    function _msgSender() internal view virtual returns (address) {
        return msg.sender;
    }

    function _msgData() internal view virtual returns (bytes calldata) {
        return msg.data;
    }
}

File 6 of 6 : IERC165.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)

pragma solidity ^0.8.0;

/**
 * @dev Interface of the ERC165 standard, as defined in the
 * https://eips.ethereum.org/EIPS/eip-165[EIP].
 *
 * Implementers can declare support of contract interfaces, which can then be
 * queried by others ({ERC165Checker}).
 *
 * For an implementation, see {ERC165}.
 */
interface IERC165 {
    /**
     * @dev Returns true if this contract implements the interface defined by
     * `interfaceId`. See the corresponding
     * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]
     * to learn more about how these ids are created.
     *
     * This function call must use less than 30 000 gas.
     */
    function supportsInterface(bytes4 interfaceId) external view returns (bool);
}

Settings
{
  "optimizer": {
    "enabled": true,
    "runs": 200
  },
  "evmVersion": "paris",
  "remappings": [],
  "libraries": {},
  "outputSelection": {
    "*": {
      "*": [
        "evm.bytecode",
        "evm.deployedBytecode",
        "devdoc",
        "userdoc",
        "metadata",
        "abi"
      ]
    }
  }
}

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":false,"internalType":"uint32","name":"pinkBalloons","type":"uint32"},{"indexed":false,"internalType":"uint32","name":"blackBalloons","type":"uint32"},{"indexed":false,"internalType":"uint32","name":"blueBalloons","type":"uint32"},{"indexed":false,"internalType":"uint32","name":"greenBalloons","type":"uint32"}],"name":"BalloonMint","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"inputs":[],"name":"balloonBurn","outputs":[{"internalType":"contract IBurnExtension","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"balloonContract","outputs":[{"internalType":"contract IManifoldERC1155","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"blackBalloonTokenId","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"blueBalloonTokenId","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint32","name":"pinkBalloons","type":"uint32"},{"internalType":"uint32","name":"blackBalloons","type":"uint32"},{"internalType":"uint32","name":"blueBalloons","type":"uint32"},{"internalType":"uint32","name":"greenBalloons","type":"uint32"}],"name":"burnAndMint","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"enabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"user","type":"address"}],"name":"getInfo","outputs":[{"internalType":"uint256","name":"ticketAmount","type":"uint256"},{"internalType":"uint256","name":"balance","type":"uint256"},{"internalType":"bool","name":"hasApproved","type":"bool"},{"internalType":"bool","name":"isEnabled","type":"bool"},{"internalType":"uint256","name":"pinkBalloonAmount","type":"uint256"},{"internalType":"uint256","name":"blackBalloonAmount","type":"uint256"},{"internalType":"uint256","name":"blueBalloonAmount","type":"uint256"},{"internalType":"uint256","name":"greenBalloonAmount","type":"uint256"},{"internalType":"uint256","name":"pinkBalloonTotalAmount","type":"uint256"},{"internalType":"uint256","name":"blackBalloonTotalAmount","type":"uint256"},{"internalType":"uint256","name":"blueBalloonTotalAmount","type":"uint256"},{"internalType":"uint256","name":"greenBalloonTotalAmount","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"greenBalloonTokenId","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"pinkBalloonTokenId","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"newState","type":"bool"}],"name":"setEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"ticketTokenId","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"ticketTokenIds","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"}]

6080604052600180546001600160a01b0319908116731386f70a946cf9f06e32190cfb2f4f4f18365b87179091556002805490911673fa1b15df09c2944a91a2f9f10a6133090d4119bd17815563217ec0f060039081556320a2c0f060049081556320a220f060059081556320a210f06006908155600794909455600892909255600955600a55600b553480156200009657600080fd5b50620000a2336200010a565b600d805460ff19169055604080516001808252818301909252906020808301908036833750508151620000dd92600c9250602001906200015a565b50600754600c600081548110620000f857620000f8620001c1565b600091825260209091200155620001d7565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b82805482825590600052602060002090810192821562000198579160200282015b82811115620001985782518255916020019190600101906200017b565b50620001a6929150620001aa565b5090565b5b80821115620001a65760008155600101620001ab565b634e487b7160e01b600052603260045260246000fd5b61120980620001e76000396000f3fe608060405234801561001057600080fd5b50600436106100f55760003560e01c80639509cf1f11610097578063e62f603211610066578063e62f6032146101cd578063e9539ab8146101d6578063f2fde38b146101e9578063ffdd5cf1146101fc57600080fd5b80639509cf1f1461019f5780639dc56747146101b2578063bcc141a0146101bb578063cdd229f9146101c457600080fd5b80633a98cdb1116100d35780633a98cdb11461015c578063715018a61461016f57806383ab08d0146101775780638da5cb5b1461018e57600080fd5b8063238dafe0146100fa578063328d8f721461011c5780633782ba4d14610131575b600080fd5b600d546101079060ff1681565b60405190151581526020015b60405180910390f35b61012f61012a366004610f4e565b61026e565b005b600254610144906001600160a01b031681565b6040516001600160a01b039091168152602001610113565b600154610144906001600160a01b031681565b61012f610289565b61018060085481565b604051908152602001610113565b6000546001600160a01b0316610144565b61012f6101ad366004610f8b565b61029d565b61018060075481565b61018060095481565b610180600b5481565b610180600a5481565b6101806101e4366004610fdf565b610830565b61012f6101f7366004610ff8565b610851565b61020f61020a366004610ff8565b6108ca565b604080519c8d5260208d019b909b52981515998b019990995295151560608a0152608089019490945260a088019290925260c087015260e086015261010085015261012084015261014083019190915261016082015261018001610113565b610276610e96565b600d805460ff1916911515919091179055565b610291610e96565b61029b6000610ef0565b565b600d5460ff166103005760405162461bcd60e51b8152602060048201526024808201527f42616c6c6f6f6e4275726e3a20436f6e7472616374206973206e6f7420656e61604482015263189b195960e21b60648201526084015b60405180910390fd5b6000818361030e8688611021565b6103189190611021565b6103229190611021565b63ffffffff161161038c5760405162461bcd60e51b815260206004820152602e60248201527f42616c6c6f6f6e4275726e3a20596f75206d757374206275726e206174206c6560448201526d185cdd081bdb99481d1a58dad95d60921b60648201526084016102f7565b6040805160018082528183019092526000916020808301908036833701905050905081836103ba8688611021565b6103c49190611021565b6103ce9190611021565b63ffffffff16816000815181106103e7576103e7611053565b6020908102919091010152600154604051633db0f8ab60e01b81526001600160a01b0390911690633db0f8ab90610427903390600c908690600401611069565b600060405180830381600087803b15801561044157600080fd5b505af1158015610455573d6000803e3d6000fd5b5060009250600191506104659050565b60405190808252806020026020018201604052801561048e578160200160208202803683370190505b50905033816000815181106104a5576104a5611053565b6001600160a01b039092166020928302919091019091015263ffffffff861615610583576040805160018082528183019092526000916020808301908036833701905050905086816000815181106104ff576104ff611053565b63ffffffff90921660209283029190910190910152600254600154600354604051630c2065c160e41b81526001600160a01b039384169363c2065c109361054f93911691879087906004016110fc565b600060405180830381600087803b15801561056957600080fd5b505af115801561057d573d6000803e3d6000fd5b50505050505b63ffffffff851615610649576040805160018082528183019092526000916020808301908036833701905050905085816000815181106105c5576105c5611053565b63ffffffff9092166020928302919091019091015260025460015460048054604051630c2065c160e41b81526001600160a01b039485169463c2065c1094610615949116929188918891016110fc565b600060405180830381600087803b15801561062f57600080fd5b505af1158015610643573d6000803e3d6000fd5b50505050505b63ffffffff84161561070f5760408051600180825281830190925260009160208083019080368337019050509050848160008151811061068b5761068b611053565b63ffffffff90921660209283029190910190910152600254600154600554604051630c2065c160e41b81526001600160a01b039384169363c2065c10936106db93911691879087906004016110fc565b600060405180830381600087803b1580156106f557600080fd5b505af1158015610709573d6000803e3d6000fd5b50505050505b63ffffffff8316156107d55760408051600180825281830190925260009160208083019080368337019050509050838160008151811061075157610751611053565b63ffffffff90921660209283029190910190910152600254600154600654604051630c2065c160e41b81526001600160a01b039384169363c2065c10936107a193911691879087906004016110fc565b600060405180830381600087803b1580156107bb57600080fd5b505af11580156107cf573d6000803e3d6000fd5b50505050505b6040805163ffffffff888116825287811660208301528681168284015285166060820152905133917fc8f2af6bd3276ae88d54b5eb661b11c3f839f6d80b7f93f8f314c3e34a54188d919081900360800190a2505050505050565b600c818154811061084057600080fd5b600091825260209091200154905081565b610859610e96565b6001600160a01b0381166108be5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016102f7565b6108c781610ef0565b50565b600080808080808080808080806001600160a01b038d166109065760009b506000995060009a5060009750600096506000955060009450610cb6565b600160009054906101000a90046001600160a01b03166001600160a01b031662fdd58e8e6007546040518363ffffffff1660e01b815260040161095e9291906001600160a01b03929092168252602082015260400190565b602060405180830381865afa15801561097b573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061099f919061119d565b9b50600160009054906101000a90046001600160a01b03166001600160a01b031663e985e9c58e306040518363ffffffff1660e01b81526004016109f99291906001600160a01b0392831681529116602082015260400190565b602060405180830381865afa158015610a16573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a3a91906111b6565b99508c6001600160a01b0316319a50600160009054906101000a90046001600160a01b03166001600160a01b031662fdd58e8e6008546040518363ffffffff1660e01b8152600401610aa19291906001600160a01b03929092168252602082015260400190565b602060405180830381865afa158015610abe573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610ae2919061119d565b9750600160009054906101000a90046001600160a01b03166001600160a01b031662fdd58e8e6009546040518363ffffffff1660e01b8152600401610b3c9291906001600160a01b03929092168252602082015260400190565b602060405180830381865afa158015610b59573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610b7d919061119d565b9650600160009054906101000a90046001600160a01b03166001600160a01b031662fdd58e8e600a546040518363ffffffff1660e01b8152600401610bd79291906001600160a01b03929092168252602082015260400190565b602060405180830381865afa158015610bf4573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610c18919061119d565b9550600160009054906101000a90046001600160a01b03166001600160a01b031662fdd58e8e600b546040518363ffffffff1660e01b8152600401610c729291906001600160a01b03929092168252602082015260400190565b602060405180830381865afa158015610c8f573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610cb3919061119d565b94505b600d5460015460085460405163bd85b03960e01b8152600481019190915260ff9092169a506001600160a01b03169063bd85b03990602401602060405180830381865afa158015610d0b573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610d2f919061119d565b60015460095460405163bd85b03960e01b815260048101919091529195506001600160a01b03169063bd85b03990602401602060405180830381865afa158015610d7d573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610da1919061119d565b600154600a5460405163bd85b03960e01b815260048101919091529194506001600160a01b03169063bd85b03990602401602060405180830381865afa158015610def573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e13919061119d565b600154600b5460405163bd85b03960e01b815260048101919091529193506001600160a01b03169063bd85b03990602401602060405180830381865afa158015610e61573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e85919061119d565b905091939597999b5091939597999b565b6000546001600160a01b0316331461029b5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016102f7565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b80151581146108c757600080fd5b600060208284031215610f6057600080fd5b8135610f6b81610f40565b9392505050565b803563ffffffff81168114610f8657600080fd5b919050565b60008060008060808587031215610fa157600080fd5b610faa85610f72565b9350610fb860208601610f72565b9250610fc660408601610f72565b9150610fd460608601610f72565b905092959194509250565b600060208284031215610ff157600080fd5b5035919050565b60006020828403121561100a57600080fd5b81356001600160a01b0381168114610f6b57600080fd5b63ffffffff81811683821601908082111561104c57634e487b7160e01b600052601160045260246000fd5b5092915050565b634e487b7160e01b600052603260045260246000fd5b6001600160a01b0384168152606060208083018290528454918301829052600085815281812090929091906080850190845b818110156110b75784548352600194850194928401920161109b565b50508481036040860152855180825290820192508186019060005b818110156110ee578251855293830193918301916001016110d2565b509298975050505050505050565b6001600160a01b0385811682526020808301869052608060408401819052855190840181905260009286830192909160a0860190855b81811015611150578551851683529483019491830191600101611132565b5050858103606087015286518082529082019350915080860160005b8381101561118e57815163ffffffff168552938201939082019060010161116c565b50929998505050505050505050565b6000602082840312156111af57600080fd5b5051919050565b6000602082840312156111c857600080fd5b8151610f6b81610f4056fea2646970667358221220a0cb060a5fbb541e3d268c90787186d67327000d24dc8b3c4384884baaac71d164736f6c63430008120033

Deployed Bytecode

0x608060405234801561001057600080fd5b50600436106100f55760003560e01c80639509cf1f11610097578063e62f603211610066578063e62f6032146101cd578063e9539ab8146101d6578063f2fde38b146101e9578063ffdd5cf1146101fc57600080fd5b80639509cf1f1461019f5780639dc56747146101b2578063bcc141a0146101bb578063cdd229f9146101c457600080fd5b80633a98cdb1116100d35780633a98cdb11461015c578063715018a61461016f57806383ab08d0146101775780638da5cb5b1461018e57600080fd5b8063238dafe0146100fa578063328d8f721461011c5780633782ba4d14610131575b600080fd5b600d546101079060ff1681565b60405190151581526020015b60405180910390f35b61012f61012a366004610f4e565b61026e565b005b600254610144906001600160a01b031681565b6040516001600160a01b039091168152602001610113565b600154610144906001600160a01b031681565b61012f610289565b61018060085481565b604051908152602001610113565b6000546001600160a01b0316610144565b61012f6101ad366004610f8b565b61029d565b61018060075481565b61018060095481565b610180600b5481565b610180600a5481565b6101806101e4366004610fdf565b610830565b61012f6101f7366004610ff8565b610851565b61020f61020a366004610ff8565b6108ca565b604080519c8d5260208d019b909b52981515998b019990995295151560608a0152608089019490945260a088019290925260c087015260e086015261010085015261012084015261014083019190915261016082015261018001610113565b610276610e96565b600d805460ff1916911515919091179055565b610291610e96565b61029b6000610ef0565b565b600d5460ff166103005760405162461bcd60e51b8152602060048201526024808201527f42616c6c6f6f6e4275726e3a20436f6e7472616374206973206e6f7420656e61604482015263189b195960e21b60648201526084015b60405180910390fd5b6000818361030e8688611021565b6103189190611021565b6103229190611021565b63ffffffff161161038c5760405162461bcd60e51b815260206004820152602e60248201527f42616c6c6f6f6e4275726e3a20596f75206d757374206275726e206174206c6560448201526d185cdd081bdb99481d1a58dad95d60921b60648201526084016102f7565b6040805160018082528183019092526000916020808301908036833701905050905081836103ba8688611021565b6103c49190611021565b6103ce9190611021565b63ffffffff16816000815181106103e7576103e7611053565b6020908102919091010152600154604051633db0f8ab60e01b81526001600160a01b0390911690633db0f8ab90610427903390600c908690600401611069565b600060405180830381600087803b15801561044157600080fd5b505af1158015610455573d6000803e3d6000fd5b5060009250600191506104659050565b60405190808252806020026020018201604052801561048e578160200160208202803683370190505b50905033816000815181106104a5576104a5611053565b6001600160a01b039092166020928302919091019091015263ffffffff861615610583576040805160018082528183019092526000916020808301908036833701905050905086816000815181106104ff576104ff611053565b63ffffffff90921660209283029190910190910152600254600154600354604051630c2065c160e41b81526001600160a01b039384169363c2065c109361054f93911691879087906004016110fc565b600060405180830381600087803b15801561056957600080fd5b505af115801561057d573d6000803e3d6000fd5b50505050505b63ffffffff851615610649576040805160018082528183019092526000916020808301908036833701905050905085816000815181106105c5576105c5611053565b63ffffffff9092166020928302919091019091015260025460015460048054604051630c2065c160e41b81526001600160a01b039485169463c2065c1094610615949116929188918891016110fc565b600060405180830381600087803b15801561062f57600080fd5b505af1158015610643573d6000803e3d6000fd5b50505050505b63ffffffff84161561070f5760408051600180825281830190925260009160208083019080368337019050509050848160008151811061068b5761068b611053565b63ffffffff90921660209283029190910190910152600254600154600554604051630c2065c160e41b81526001600160a01b039384169363c2065c10936106db93911691879087906004016110fc565b600060405180830381600087803b1580156106f557600080fd5b505af1158015610709573d6000803e3d6000fd5b50505050505b63ffffffff8316156107d55760408051600180825281830190925260009160208083019080368337019050509050838160008151811061075157610751611053565b63ffffffff90921660209283029190910190910152600254600154600654604051630c2065c160e41b81526001600160a01b039384169363c2065c10936107a193911691879087906004016110fc565b600060405180830381600087803b1580156107bb57600080fd5b505af11580156107cf573d6000803e3d6000fd5b50505050505b6040805163ffffffff888116825287811660208301528681168284015285166060820152905133917fc8f2af6bd3276ae88d54b5eb661b11c3f839f6d80b7f93f8f314c3e34a54188d919081900360800190a2505050505050565b600c818154811061084057600080fd5b600091825260209091200154905081565b610859610e96565b6001600160a01b0381166108be5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016102f7565b6108c781610ef0565b50565b600080808080808080808080806001600160a01b038d166109065760009b506000995060009a5060009750600096506000955060009450610cb6565b600160009054906101000a90046001600160a01b03166001600160a01b031662fdd58e8e6007546040518363ffffffff1660e01b815260040161095e9291906001600160a01b03929092168252602082015260400190565b602060405180830381865afa15801561097b573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061099f919061119d565b9b50600160009054906101000a90046001600160a01b03166001600160a01b031663e985e9c58e306040518363ffffffff1660e01b81526004016109f99291906001600160a01b0392831681529116602082015260400190565b602060405180830381865afa158015610a16573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a3a91906111b6565b99508c6001600160a01b0316319a50600160009054906101000a90046001600160a01b03166001600160a01b031662fdd58e8e6008546040518363ffffffff1660e01b8152600401610aa19291906001600160a01b03929092168252602082015260400190565b602060405180830381865afa158015610abe573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610ae2919061119d565b9750600160009054906101000a90046001600160a01b03166001600160a01b031662fdd58e8e6009546040518363ffffffff1660e01b8152600401610b3c9291906001600160a01b03929092168252602082015260400190565b602060405180830381865afa158015610b59573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610b7d919061119d565b9650600160009054906101000a90046001600160a01b03166001600160a01b031662fdd58e8e600a546040518363ffffffff1660e01b8152600401610bd79291906001600160a01b03929092168252602082015260400190565b602060405180830381865afa158015610bf4573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610c18919061119d565b9550600160009054906101000a90046001600160a01b03166001600160a01b031662fdd58e8e600b546040518363ffffffff1660e01b8152600401610c729291906001600160a01b03929092168252602082015260400190565b602060405180830381865afa158015610c8f573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610cb3919061119d565b94505b600d5460015460085460405163bd85b03960e01b8152600481019190915260ff9092169a506001600160a01b03169063bd85b03990602401602060405180830381865afa158015610d0b573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610d2f919061119d565b60015460095460405163bd85b03960e01b815260048101919091529195506001600160a01b03169063bd85b03990602401602060405180830381865afa158015610d7d573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610da1919061119d565b600154600a5460405163bd85b03960e01b815260048101919091529194506001600160a01b03169063bd85b03990602401602060405180830381865afa158015610def573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e13919061119d565b600154600b5460405163bd85b03960e01b815260048101919091529193506001600160a01b03169063bd85b03990602401602060405180830381865afa158015610e61573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e85919061119d565b905091939597999b5091939597999b565b6000546001600160a01b0316331461029b5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016102f7565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b80151581146108c757600080fd5b600060208284031215610f6057600080fd5b8135610f6b81610f40565b9392505050565b803563ffffffff81168114610f8657600080fd5b919050565b60008060008060808587031215610fa157600080fd5b610faa85610f72565b9350610fb860208601610f72565b9250610fc660408601610f72565b9150610fd460608601610f72565b905092959194509250565b600060208284031215610ff157600080fd5b5035919050565b60006020828403121561100a57600080fd5b81356001600160a01b0381168114610f6b57600080fd5b63ffffffff81811683821601908082111561104c57634e487b7160e01b600052601160045260246000fd5b5092915050565b634e487b7160e01b600052603260045260246000fd5b6001600160a01b0384168152606060208083018290528454918301829052600085815281812090929091906080850190845b818110156110b75784548352600194850194928401920161109b565b50508481036040860152855180825290820192508186019060005b818110156110ee578251855293830193918301916001016110d2565b509298975050505050505050565b6001600160a01b0385811682526020808301869052608060408401819052855190840181905260009286830192909160a0860190855b81811015611150578551851683529483019491830191600101611132565b5050858103606087015286518082529082019350915080860160005b8381101561118e57815163ffffffff168552938201939082019060010161116c565b50929998505050505050505050565b6000602082840312156111af57600080fd5b5051919050565b6000602082840312156111c857600080fd5b8151610f6b81610f4056fea2646970667358221220a0cb060a5fbb541e3d268c90787186d67327000d24dc8b3c4384884baaac71d164736f6c63430008120033

Block Transaction Difficulty Gas Used Reward
View All Blocks Produced

Block Uncle Number Difficulty Gas Used Reward
View All Uncles
Loading...
Loading
Loading...
Loading

Validator Index Block Amount
View All Withdrawals

Transaction Hash Block Value Eth2 PubKey Valid
View All Deposits
Loading...
Loading
[ Download: CSV Export  ]

A contract address hosts a smart contract, which is a set of code stored on the blockchain that runs when predetermined conditions are met. Learn more about addresses in our Knowledge Base.