ETH Price: $3,598.48 (+9.01%)

Contract

0x9EC10471ca0177E92977D95E76115Fb823753125
 

Overview

ETH Balance

0 ETH

Eth Value

$0.00

Multichain Info

No addresses found
Transaction Hash
Method
Block
From
To
Withdraw Eth112834452020-11-18 18:11:431470 days ago1605723103IN
0x9EC10471...823753125
0 ETH0.0015947751.00000145
Setup105127882020-07-23 1:42:281588 days ago1595468548IN
0x9EC10471...823753125
0 ETH0.001961460
Run Plugin103390162020-06-26 3:34:541615 days ago1593142494IN
0x9EC10471...823753125
0 ETH0.002402730
Buy Sale Lot103389282020-06-26 3:16:261615 days ago1593141386IN
0x9EC10471...823753125
0 ETH0.0026993430
Buy Sale Lot103211882020-06-23 9:29:521618 days ago1592904592IN
0x9EC10471...823753125
0 ETH0.0040490145
Run Plugin102643832020-06-14 14:26:561627 days ago1592144816IN
0x9EC10471...823753125
0 ETH0.0017382121.7
Run Plugin102640352020-06-14 13:05:071627 days ago1592139907IN
0x9EC10471...823753125
0 ETH0.0014896718.6
Run Plugin102640002020-06-14 12:58:311627 days ago1592139511IN
0x9EC10471...823753125
0 ETH0.0014498418.1
Buy Sale Lot102233272020-06-08 5:47:111633 days ago1591595231IN
0x9EC10471...823753125
0 ETH0.0026093629
Buy Cutie102233252020-06-08 5:46:501633 days ago1591595210IN
0x9EC10471...823753125
0 ETH0.0027439728
Buy Cutie102195122020-06-07 15:42:051634 days ago1591544525IN
0x9EC10471...823753125
0 ETH0.0026707435
Run Plugin102028612020-06-05 1:51:191636 days ago1591321879IN
0x9EC10471...823753125
0 ETH0.0013617317
Run Plugin101762162020-05-31 22:14:441640 days ago1590963284IN
0x9EC10471...823753125
0 ETH0.0014097917.6
Buy Cutie101044912020-05-20 18:46:301652 days ago1590000390IN
0x9EC10471...823753125
0 ETH0.0020534621
Buy Cutie100925442020-05-18 22:02:161653 days ago1589839336IN
0x9EC10471...823753125
0 ETH0.0013689714
Buy Cutie99402972020-04-25 7:28:301677 days ago1587799710IN
0x9EC10471...823753125
0 ETH0.00072367.4
Buy Cutie99402272020-04-25 7:12:381677 days ago1587798758IN
0x9EC10471...823753125
0 ETH0.000266847
Buy Cutie99288222020-04-23 12:48:301679 days ago1587646110IN
0x9EC10471...823753125
0 ETH0.000970429.9
Run Plugin99261002020-04-23 2:37:381679 days ago1587609458IN
0x9EC10471...823753125
0 ETH0.000520586.5
Buy Sale Lot99172462020-04-21 17:45:591681 days ago1587491159IN
0x9EC10471...823753125
0 ETH0.000539946
Run Plugin99132722020-04-21 2:57:381681 days ago1587437858IN
0x9EC10471...823753125
0 ETH0.000480616
Buy Sale Lot99091422020-04-20 11:51:161682 days ago1587383476IN
0x9EC10471...823753125
0 ETH0.000449955
Buy Cutie99031662020-04-19 13:29:021683 days ago1587302942IN
0x9EC10471...823753125
0 ETH0.00058676
Buy Cutie98723932020-04-14 19:12:171688 days ago1586891537IN
0x9EC10471...823753125
0 ETH0.000248993
Buy Cutie98690932020-04-14 7:10:081688 days ago1586848208IN
0x9EC10471...823753125
0 ETH0.000588136
View all transactions

Latest 25 internal transactions (View All)

Advanced mode:
Parent Transaction Hash Block From To
112834452020-11-18 18:11:431470 days ago1605723103
0x9EC10471...823753125
47.62063363 ETH
103390162020-06-26 3:34:541615 days ago1593142494
0x9EC10471...823753125
0.00015 ETH
102643832020-06-14 14:26:561627 days ago1592144816
0x9EC10471...823753125
0.0187 ETH
102640352020-06-14 13:05:071627 days ago1592139907
0x9EC10471...823753125
0.0006 ETH
102640002020-06-14 12:58:311627 days ago1592139511
0x9EC10471...823753125
0.0009 ETH
102233252020-06-08 5:46:501633 days ago1591595210
0x9EC10471...823753125
0.002 ETH
102195122020-06-07 15:42:051634 days ago1591544525
0x9EC10471...823753125
0.1 ETH
102028612020-06-05 1:51:191636 days ago1591321879
0x9EC10471...823753125
0.001 ETH
101762162020-05-31 22:14:441640 days ago1590963284
0x9EC10471...823753125
0.00193 ETH
101044912020-05-20 18:46:301652 days ago1590000390
0x9EC10471...823753125
0.03 ETH
100925442020-05-18 22:02:161653 days ago1589839336
0x9EC10471...823753125
0.0015 ETH
99402972020-04-25 7:28:301677 days ago1587799710
0x9EC10471...823753125
0.008 ETH
99402272020-04-25 7:12:381677 days ago1587798758
0x9EC10471...823753125
0.07 ETH
99288222020-04-23 12:48:301679 days ago1587646110
0x9EC10471...823753125
0.0015 ETH
99261002020-04-23 2:37:381679 days ago1587609458
0x9EC10471...823753125
0.0044 ETH
99132722020-04-21 2:57:381681 days ago1587437858
0x9EC10471...823753125
0.0045 ETH
99031662020-04-19 13:29:021683 days ago1587302942
0x9EC10471...823753125
0.002 ETH
98723932020-04-14 19:12:171688 days ago1586891537
0x9EC10471...823753125
0.05 ETH
98690932020-04-14 7:10:081688 days ago1586848208
0x9EC10471...823753125
0.0005 ETH
98671222020-04-13 23:52:011688 days ago1586821921
0x9EC10471...823753125
0.02515379 ETH
98671022020-04-13 23:47:271688 days ago1586821647
0x9EC10471...823753125
0.01 ETH
98537552020-04-11 22:51:361690 days ago1586645496
0x9EC10471...823753125
0.00489419 ETH
98464412020-04-10 19:37:231691 days ago1586547443
0x9EC10471...823753125
0.005 ETH
97543942020-03-27 16:06:101706 days ago1585325170
0x9EC10471...823753125
0.0000285 ETH
97455872020-03-26 7:26:101707 days ago1585207570
0x9EC10471...823753125
0.00088244 ETH
View All Internal Transactions
Loading...
Loading

Similar Match Source Code
This contract matches the deployed Bytecode of the Source Code for Contract 0xa1D56d52...70440AE21
The constructor portion of the code might be different and could alter the actual behaviour of the contract

Contract Name:
FiatProxy

Compiler Version
v0.4.26+commit.4563c3fc

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2019-07-17
*/

pragma solidity ^0.4.23;

pragma solidity ^0.4.23;

pragma solidity ^0.4.23;

// ----------------------------------------------------------------------------
contract ERC20 {

    // ERC Token Standard #223 Interface
    // https://github.com/ethereum/EIPs/issues/223

    string public symbol;
    string public  name;
    uint8 public decimals;

    function transfer(address _to, uint _value, bytes _data) external returns (bool success);

    // approveAndCall
    function approveAndCall(address spender, uint tokens, bytes data) external returns (bool success);

    // ERC Token Standard #20 Interface
    // https://github.com/ethereum/EIPs/blob/master/EIPS/eip-20.md


    function totalSupply() public view returns (uint);
    function balanceOf(address tokenOwner) public view returns (uint balance);
    function allowance(address tokenOwner, address spender) public view returns (uint remaining);
    function transfer(address to, uint tokens) public returns (bool success);
    function approve(address spender, uint tokens) public returns (bool success);
    function transferFrom(address from, address to, uint tokens) public returns (bool success);
    event Transfer(address indexed from, address indexed to, uint tokens);
    event Approval(address indexed tokenOwner, address indexed spender, uint tokens);

    // bulk operations
    function transferBulk(address[] to, uint[] tokens) public;
    function approveBulk(address[] spender, uint[] tokens) public;
}

pragma solidity ^0.4.23;

/// @title ERC-721 Non-Fungible Token Standard
/// @dev See https://github.com/ethereum/EIPs/blob/master/EIPS/eip-721.md
///  Note: the ERC-165 identifier for this interface is 0x6466353c
interface ERC721 /*is ERC165*/ {

    /// @notice Query if a contract implements an interface
    /// @param interfaceID The interface identifier, as specified in ERC-165
    /// @dev Interface identification is specified in ERC-165. This function
    ///  uses less than 30,000 gas.
    /// @return `true` if the contract implements `interfaceID` and
    ///  `interfaceID` is not 0xffffffff, `false` otherwise
    function supportsInterface(bytes4 interfaceID) external view returns (bool);

    /// @dev This emits when ownership of any NFT changes by any mechanism.
    ///  This event emits when NFTs are created (`from` == 0) and destroyed
    ///  (`to` == 0). Exception: during contract creation, any number of NFTs
    ///  may be created and assigned without emitting Transfer. At the time of
    ///  any transfer, the approved address for that NFT (if any) is reset to none.
    event Transfer(address indexed _from, address indexed _to, uint256 _tokenId);

    /// @dev This emits when the approved address for an NFT is changed or
    ///  reaffirmed. The zero address indicates there is no approved address.
    ///  When a Transfer event emits, this also indicates that the approved
    ///  address for that NFT (if any) is reset to none.
    event Approval(address indexed _owner, address indexed _approved, uint256 _tokenId);

    /// @dev This emits when an operator is enabled or disabled for an owner.
    ///  The operator can manage all NFTs of the owner.
    event ApprovalForAll(address indexed _owner, address indexed _operator, bool _approved);

    /// @notice Count all NFTs assigned to an owner
    /// @dev NFTs assigned to the zero address are considered invalid, and this
    ///  function throws for queries about the zero address.
    /// @param _owner An address for whom to query the balance
    /// @return The number of NFTs owned by `_owner`, possibly zero
    function balanceOf(address _owner) external view returns (uint256);

    /// @notice Find the owner of an NFT
    /// @param _tokenId The identifier for an NFT
    /// @dev NFTs assigned to zero address are considered invalid, and queries
    ///  about them do throw.
    /// @return The address of the owner of the NFT
    function ownerOf(uint256 _tokenId) external view returns (address);

    /// @notice Transfers the ownership of an NFT from one address to another address
    /// @dev Throws unless `msg.sender` is the current owner, an authorized
    ///  operator, or the approved address for this NFT. Throws if `_from` is
    ///  not the current owner. Throws if `_to` is the zero address. Throws if
    ///  `_tokenId` is not a valid NFT. When transfer is complete, this function
    ///  checks if `_to` is a smart contract (code size > 0). If so, it calls
    ///  `onERC721Received` on `_to` and throws if the return value is not
    ///  `bytes4(keccak256("onERC721Received(address,uint256,bytes)"))`.
    /// @param _from The current owner of the NFT
    /// @param _to The new owner
    /// @param _tokenId The NFT to transfer
    /// @param data Additional data with no specified format, sent in call to `_to`
    function safeTransferFrom(address _from, address _to, uint256 _tokenId, bytes data) external;
    
    /// @notice Transfers the ownership of an NFT from one address to another address
    /// @dev This works identically to the other function with an extra data parameter,
    ///  except this function just sets data to ""
    /// @param _from The current owner of the NFT
    /// @param _to The new owner
    /// @param _tokenId The NFT to transfer
    function safeTransferFrom(address _from, address _to, uint256 _tokenId) external;

    /// @notice Transfer ownership of an NFT -- THE CALLER IS RESPONSIBLE
    ///  TO CONFIRM THAT `_to` IS CAPABLE OF RECEIVING NFTS OR ELSE
    ///  THEY MAY BE PERMANENTLY LOST
    /// @dev Throws unless `msg.sender` is the current owner, an authorized
    ///  operator, or the approved address for this NFT. Throws if `_from` is
    ///  not the current owner. Throws if `_to` is the zero address. Throws if
    ///  `_tokenId` is not a valid NFT.
    /// @param _from The current owner of the NFT
    /// @param _to The new owner
    /// @param _tokenId The NFT to transfer
    function transferFrom(address _from, address _to, uint256 _tokenId) external;

    /// @notice Set or reaffirm the approved address for an NFT
    /// @dev The zero address indicates there is no approved address.
    /// @dev Throws unless `msg.sender` is the current NFT owner, or an authorized
    ///  operator of the current owner.
    /// @param _approved The new approved NFT controller
    /// @param _tokenId The NFT to approve
    function approve(address _approved, uint256 _tokenId) external;

    /// @notice Enable or disable approval for a third party ("operator") to manage
    ///  all your asset.
    /// @dev Emits the ApprovalForAll event
    /// @param _operator Address to add to the set of authorized operators.
    /// @param _approved True if the operators is approved, false to revoke approval
    function setApprovalForAll(address _operator, bool _approved) external;

    /// @notice Get the approved address for a single NFT
    /// @dev Throws if `_tokenId` is not a valid NFT
    /// @param _tokenId The NFT to find the approved address for
    /// @return The approved address for this NFT, or the zero address if there is none
    function getApproved(uint256 _tokenId) external view returns (address);

    /// @notice Query if an address is an authorized operator for another address
    /// @param _owner The address that owns the NFTs
    /// @param _operator The address that acts on behalf of the owner
    /// @return True if `_operator` is an approved operator for `_owner`, false otherwise
    function isApprovedForAll(address _owner, address _operator) external view returns (bool);


   /// @notice A descriptive name for a collection of NFTs in this contract
    function name() external pure returns (string _name);

    /// @notice An abbreviated name for NFTs in this contract
    function symbol() external pure returns (string _symbol);

    
    /// @notice A distinct Uniform Resource Identifier (URI) for a given asset.
    /// @dev Throws if `_tokenId` is not a valid NFT. URIs are defined in RFC
    ///  3986. The URI may point to a JSON file that conforms to the "ERC721
    ///  Metadata JSON Schema".
    function tokenURI(uint256 _tokenId) external view returns (string);

     /// @notice Count NFTs tracked by this contract
    /// @return A count of valid NFTs tracked by this contract, where each one of
    ///  them has an assigned and queryable owner not equal to the zero address
    function totalSupply() external view returns (uint256);

    /// @notice Enumerate valid NFTs
    /// @dev Throws if `_index` >= `totalSupply()`.
    /// @param _index A counter less than `totalSupply()`
    /// @return The token identifier for the `_index`th NFT,
    ///  (sort order not specified)
    function tokenByIndex(uint256 _index) external view returns (uint256);

    /// @notice Enumerate NFTs assigned to an owner
    /// @dev Throws if `_index` >= `balanceOf(_owner)` or if
    ///  `_owner` is the zero address, representing invalid NFTs.
    /// @param _owner An address where we are interested in NFTs owned by them
    /// @param _index A counter less than `balanceOf(_owner)`
    /// @return The token identifier for the `_index`th NFT assigned to `_owner`,
    ///   (sort order not specified)
    function tokenOfOwnerByIndex(address _owner, uint256 _index) external view returns (uint256);

    /// @notice Transfers a Cutie to another address. When transferring to a smart
    ///  contract, ensure that it is aware of ERC-721 (or
    ///  BlockchainCuties specifically), otherwise the Cutie may be lost forever.
    /// @param _to The address of the recipient, can be a user or contract.
    /// @param _cutieId The ID of the Cutie to transfer.
    function transfer(address _to, uint256 _cutieId) external;
}

pragma solidity ^0.4.23;

pragma solidity ^0.4.23;


/**
 * @title ERC165
 * @dev https://github.com/ethereum/EIPs/blob/master/EIPS/eip-165.md
 */
interface ERC165 {

    /**
     * @notice Query if a contract implements an interface
     * @param _interfaceId The interface identifier, as specified in ERC-165
     * @dev Interface identification is specified in ERC-165. This function
     * uses less than 30,000 gas.
     */
    function supportsInterface(bytes4 _interfaceId)
    external
    view
    returns (bool);
}


/**
    @title ERC-1155 Multi Token Standard
    @dev See https://github.com/ethereum/EIPs/blob/master/EIPS/eip-1155.md
    Note: The ERC-165 identifier for this interface is 0xd9b67a26.
 */
interface IERC1155 /* is ERC165 */ {
    /**
        @dev Either `TransferSingle` or `TransferBatch` MUST emit when tokens are transferred, including zero value transfers as well as minting or burning (see "Safe Transfer Rules" section of the standard).
        The `_operator` argument MUST be msg.sender.
        The `_from` argument MUST be the address of the holder whose balance is decreased.
        The `_to` argument MUST be the address of the recipient whose balance is increased.
        The `_id` argument MUST be the token type being transferred.
        The `_value` argument MUST be the number of tokens the holder balance is decreased by and match what the recipient balance is increased by.
        When minting/creating tokens, the `_from` argument MUST be set to `0x0` (i.e. zero address).
        When burning/destroying tokens, the `_to` argument MUST be set to `0x0` (i.e. zero address).
    */
    event TransferSingle(address indexed _operator, address indexed _from, address indexed _to, uint256 _id, uint256 _value);

    /**
        @dev Either `TransferSingle` or `TransferBatch` MUST emit when tokens are transferred, including zero value transfers as well as minting or burning (see "Safe Transfer Rules" section of the standard).
        The `_operator` argument MUST be msg.sender.
        The `_from` argument MUST be the address of the holder whose balance is decreased.
        The `_to` argument MUST be the address of the recipient whose balance is increased.
        The `_ids` argument MUST be the list of tokens being transferred.
        The `_values` argument MUST be the list of number of tokens (matching the list and order of tokens specified in _ids) the holder balance is decreased by and match what the recipient balance is increased by.
        When minting/creating tokens, the `_from` argument MUST be set to `0x0` (i.e. zero address).
        When burning/destroying tokens, the `_to` argument MUST be set to `0x0` (i.e. zero address).
    */
    event TransferBatch(address indexed _operator, address indexed _from, address indexed _to, uint256[] _ids, uint256[] _values);

    /**
        @dev MUST emit when approval for a second party/operator address to manage all tokens for an owner address is enabled or disabled (absense of an event assumes disabled).
    */
    event ApprovalForAll(address indexed _owner, address indexed _operator, bool _approved);

    /**
        @dev MUST emit when the URI is updated for a token ID.
        URIs are defined in RFC 3986.
        The URI MUST point a JSON file that conforms to the "ERC-1155 Metadata URI JSON Schema".

        The URI value allows for ID substitution by clients. If the string {id} exists in any URI,
        clients MUST replace this with the actual token ID in hexadecimal form.
    */
    event URI(string _value, uint256 indexed _id);

    /**
        @notice Transfers `_value` amount of an `_id` from the `_from` address to the `_to` address specified (with safety call).
        @dev Caller must be approved to manage the tokens being transferred out of the `_from` account (see "Approval" section of the standard).
        MUST revert if `_to` is the zero address.
        MUST revert if balance of holder for token `_id` is lower than the `_value` sent.
        MUST revert on any other error.
        MUST emit the `TransferSingle` event to reflect the balance change (see "Safe Transfer Rules" section of the standard).
        After the above conditions are met, this function MUST check if `_to` is a smart contract (e.g. code size > 0). If so, it MUST call `onERC1155Received` on `_to` and act appropriately (see "Safe Transfer Rules" section of the standard).
        @param _from    Source address
        @param _to      Target address
        @param _id      ID of the token type
        @param _value   Transfer amount
        @param _data    Additional data with no specified format, MUST be sent unaltered in call to `onERC1155Received` on `_to`
    */
    function safeTransferFrom(address _from, address _to, uint256 _id, uint256 _value, bytes _data) external;

    /**
        @notice Transfers `_values` amount(s) of `_ids` from the `_from` address to the `_to` address specified (with safety call).
        @dev Caller must be approved to manage the tokens being transferred out of the `_from` account (see "Approval" section of the standard).
        MUST revert if `_to` is the zero address.
        MUST revert if length of `_ids` is not the same as length of `_values`.
        MUST revert if any of the balance(s) of the holder(s) for token(s) in `_ids` is lower than the respective amount(s) in `_values` sent to the recipient.
        MUST revert on any other error.
        MUST emit `TransferSingle` or `TransferBatch` event(s) such that all the balance changes are reflected (see "Safe Transfer Rules" section of the standard).
        Balance changes and events MUST follow the ordering of the arrays (_ids[0]/_values[0] before _ids[1]/_values[1], etc).
        After the above conditions for the transfer(s) in the batch are met, this function MUST check if `_to` is a smart contract (e.g. code size > 0). If so, it MUST call the relevant `ERC1155TokenReceiver` hook(s) on `_to` and act appropriately (see "Safe Transfer Rules" section of the standard).
        @param _from    Source address
        @param _to      Target address
        @param _ids     IDs of each token type (order and length must match _values array)
        @param _values  Transfer amounts per token type (order and length must match _ids array)
        @param _data    Additional data with no specified format, MUST be sent unaltered in call to the `ERC1155TokenReceiver` hook(s) on `_to`
    */
    function safeBatchTransferFrom(address _from, address _to, uint256[] _ids, uint256[] _values, bytes _data) external;

    /**
        @notice Get the balance of an account's Tokens.
        @param _owner  The address of the token holder
        @param _id     ID of the Token
        @return        The _owner's balance of the Token type requested
     */
    function balanceOf(address _owner, uint256 _id) external view returns (uint256);

    /**
        @notice Get the balance of multiple account/token pairs
        @param _owners The addresses of the token holders
        @param _ids    ID of the Tokens
        @return        The _owner's balance of the Token types requested (i.e. balance for each (owner, id) pair)
     */
    function balanceOfBatch(address[] _owners, uint256[] _ids) external view returns (uint256[] memory);

    /**
        @notice Enable or disable approval for a third party ("operator") to manage all of the caller's tokens.
        @dev MUST emit the ApprovalForAll event on success.
        @param _operator  Address to add to the set of authorized operators
        @param _approved  True if the operator is approved, false to revoke approval
    */
    function setApprovalForAll(address _operator, bool _approved) external;

    /**
        @notice Queries the approval status of an operator for a given owner.
        @param _owner     The owner of the Tokens
        @param _operator  Address of authorized operator
        @return           True if the operator is approved, false if not
    */
    function isApprovedForAll(address _owner, address _operator) external view returns (bool);
}


contract Operators
{
    mapping (address=>bool) ownerAddress;
    mapping (address=>bool) operatorAddress;

    constructor() public
    {
        ownerAddress[msg.sender] = true;
    }

    modifier onlyOwner()
    {
        require(ownerAddress[msg.sender]);
        _;
    }

    function isOwner(address _addr) public view returns (bool) {
        return ownerAddress[_addr];
    }

    function addOwner(address _newOwner) external onlyOwner {
        require(_newOwner != address(0));

        ownerAddress[_newOwner] = true;
    }

    function removeOwner(address _oldOwner) external onlyOwner {
        delete(ownerAddress[_oldOwner]);
    }

    modifier onlyOperator() {
        require(isOperator(msg.sender));
        _;
    }

    function isOperator(address _addr) public view returns (bool) {
        return operatorAddress[_addr] || ownerAddress[_addr];
    }

    function addOperator(address _newOperator) external onlyOwner {
        require(_newOperator != address(0));

        operatorAddress[_newOperator] = true;
    }

    function removeOperator(address _oldOperator) external onlyOwner {
        delete(operatorAddress[_oldOperator]);
    }

    function withdrawERC20(ERC20 _tokenContract) external onlyOwner
    {
        uint256 balance = _tokenContract.balanceOf(address(this));
        _tokenContract.transfer(msg.sender, balance);
    }

    function approveERC721(ERC721 _tokenContract) external onlyOwner
    {
        _tokenContract.setApprovalForAll(msg.sender, true);
    }

    function approveERC1155(IERC1155 _tokenContract) external onlyOwner
    {
        _tokenContract.setApprovalForAll(msg.sender, true);
    }

    function withdrawEth() external onlyOwner
    {
        if (address(this).balance > 0)
        {
            msg.sender.transfer(address(this).balance);
        }
    }
}

pragma solidity ^0.4.23;

/// @title Auction Market for Blockchain Cuties.
/// @author https://BlockChainArchitect.io
contract MarketInterface 
{
    function withdrawEthFromBalance() external;

    function createAuction(uint40 _cutieId, uint128 _startPrice, uint128 _endPrice, uint40 _duration, address _seller) external payable;
    function createAuctionWithTokens(uint40 _cutieId, uint128 _startPrice, uint128 _endPrice, uint40 _duration, address _seller, address[] allowedTokens) external payable;

    function bid(uint40 _cutieId) external payable;

    function cancelActiveAuctionWhenPaused(uint40 _cutieId) external;

	function getAuctionInfo(uint40 _cutieId)
        external
        view
        returns
    (
        address seller,
        uint128 startPrice,
        uint128 endPrice,
        uint40 duration,
        uint40 startedAt,
        uint128 featuringFee,
        address[] allowedTokens
    );
}

pragma solidity ^0.4.23;

pragma solidity ^0.4.23;

/// @title BlockchainCuties: Collectible and breedable cuties on the Ethereum blockchain.
/// @author https://BlockChainArchitect.io
/// @dev This is the BlockchainCuties configuration. It can be changed redeploying another version.
interface ConfigInterface
{
    function isConfig() external pure returns (bool);

    function getCooldownIndexFromGeneration(uint16 _generation, uint40 _cutieId) external view returns (uint16);
    function getCooldownEndTimeFromIndex(uint16 _cooldownIndex, uint40 _cutieId) external view returns (uint40);
    function getCooldownIndexFromGeneration(uint16 _generation) external view returns (uint16);
    function getCooldownEndTimeFromIndex(uint16 _cooldownIndex) external view returns (uint40);

    function getCooldownIndexCount() external view returns (uint256);

    function getBabyGenFromId(uint40 _momId, uint40 _dadId) external view returns (uint16);
    function getBabyGen(uint16 _momGen, uint16 _dadGen) external pure returns (uint16);

    function getTutorialBabyGen(uint16 _dadGen) external pure returns (uint16);

    function getBreedingFee(uint40 _momId, uint40 _dadId) external view returns (uint256);
}


contract CutieCoreInterface
{
    function isCutieCore() pure public returns (bool);

    ConfigInterface public config;

    function transferFrom(address _from, address _to, uint256 _cutieId) external;
    function transfer(address _to, uint256 _cutieId) external;

    function ownerOf(uint256 _cutieId)
        external
        view
        returns (address owner);

    function getCutie(uint40 _id)
        external
        view
        returns (
        uint256 genes,
        uint40 birthTime,
        uint40 cooldownEndTime,
        uint40 momId,
        uint40 dadId,
        uint16 cooldownIndex,
        uint16 generation
    );

    function getGenes(uint40 _id)
        public
        view
        returns (
        uint256 genes
    );


    function getCooldownEndTime(uint40 _id)
        public
        view
        returns (
        uint40 cooldownEndTime
    );

    function getCooldownIndex(uint40 _id)
        public
        view
        returns (
        uint16 cooldownIndex
    );


    function getGeneration(uint40 _id)
        public
        view
        returns (
        uint16 generation
    );

    function getOptional(uint40 _id)
        public
        view
        returns (
        uint64 optional
    );


    function changeGenes(
        uint40 _cutieId,
        uint256 _genes)
        public;

    function changeCooldownEndTime(
        uint40 _cutieId,
        uint40 _cooldownEndTime)
        public;

    function changeCooldownIndex(
        uint40 _cutieId,
        uint16 _cooldownIndex)
        public;

    function changeOptional(
        uint40 _cutieId,
        uint64 _optional)
        public;

    function changeGeneration(
        uint40 _cutieId,
        uint16 _generation)
        public;

    function createSaleAuction(
        uint40 _cutieId,
        uint128 _startPrice,
        uint128 _endPrice,
        uint40 _duration
    )
    public;

    function getApproved(uint256 _tokenId) external returns (address);
    function totalSupply() view external returns (uint256);
    function createPromoCutie(uint256 _genes, address _owner) external;
    function checkOwnerAndApprove(address _claimant, uint40 _cutieId, address _pluginsContract) external view;
    function breedWith(uint40 _momId, uint40 _dadId) public payable returns (uint40);
    function getBreedingFee(uint40 _momId, uint40 _dadId) public view returns (uint256);
    function restoreCutieToAddress(uint40 _cutieId, address _recipient) external;
    function createGen0Auction(uint256 _genes, uint128 startPrice, uint128 endPrice, uint40 duration) external;
    function createGen0AuctionWithTokens(uint256 _genes, uint128 startPrice, uint128 endPrice, uint40 duration, address[] allowedTokens) external;
    function createPromoCutieWithGeneration(uint256 _genes, address _owner, uint16 _generation) external;
    function createPromoCutieBulk(uint256[] _genes, address _owner, uint16 _generation) external;
}

pragma solidity ^0.4.23;

/// @title BlockchainCuties Presale Contract
/// @author https://BlockChainArchitect.io
interface PresaleInterface
{
    function bidWithPlugin(uint32 lotId, address purchaser, uint valueForEvent, address tokenForEvent) external payable;
    function bidWithPluginReferrer(uint32 lotId, address purchaser, uint valueForEvent, address tokenForEvent, address referrer) external payable;

    function getLotNftFixedRewards(uint32 lotId) external view returns (
        uint256 rewardsNFTFixedKind,
        uint256 rewardsNFTFixedIndex
    );
    function getLotToken1155Rewards(uint32 lotId) external view returns (
        uint256[10] memory rewardsToken1155tokenId,
        uint256[10] memory rewardsToken1155count
    );
    function getLotCutieRewards(uint32 lotId) external view returns (
        uint256[10] memory rewardsCutieGenome,
        uint256[10] memory rewardsCutieGeneration
    );
    function getLotNftMintRewards(uint32 lotId) external view returns (
        uint256[10] memory rewardsNFTMintNftKind
    );

    function getLotToken1155RewardByIndex(uint32 lotId, uint index) external view returns (
        uint256 rewardsToken1155tokenId,
        uint256 rewardsToken1155count
    );
    function getLotCutieRewardByIndex(uint32 lotId, uint index) external view returns (
        uint256 rewardsCutieGenome,
        uint256 rewardsCutieGeneration
    );
    function getLotNftMintRewardByIndex(uint32 lotId, uint index) external view returns (
        uint256 rewardsNFTMintNftKind
    );

    function getLotToken1155RewardCount(uint32 lotId) external view returns (uint);
    function getLotCutieRewardCount(uint32 lotId) external view returns (uint);
    function getLotNftMintRewardCount(uint32 lotId) external view returns (uint);

    function getLotRewards(uint32 lotId) external view returns (
        uint256[5] memory rewardsToken1155tokenId,
        uint256[5] memory rewardsToken1155count,
        uint256[5] memory rewardsNFTMintNftKind,
        uint256[5] memory rewardsNFTFixedKind,
        uint256[5] memory rewardsNFTFixedIndex,
        uint256[5] memory rewardsCutieGenome,
        uint256[5] memory rewardsCutieGeneration
    );
}

pragma solidity ^0.4.23;

interface BlockchainCutiesERC1155Interface
{
    function mintNonFungibleSingleShort(uint128 _type, address _to) external;
    function mintNonFungibleSingle(uint256 _type, address _to) external;
    function mintNonFungibleShort(uint128 _type, address[] _to) external;
    function mintNonFungible(uint256 _type, address[] _to) external;
    function mintFungibleSingle(uint256 _id, address _to, uint256 _quantity) external;
    function mintFungible(uint256 _id, address[] _to, uint256[] _quantities) external;
    function isNonFungible(uint256 _id) external pure returns(bool);
    function ownerOf(uint256 _id) external view returns (address);
    function totalSupplyNonFungible(uint256 _type) view external returns (uint256);
    function totalSupplyNonFungibleShort(uint128 _type) view external returns (uint256);

    /**
        @notice A distinct Uniform Resource Identifier (URI) for a given token.
        @dev URIs are defined in RFC 3986.
        The URI may point to a JSON file that conforms to the "ERC-1155 Metadata URI JSON Schema".
        @return URI string
    */
    function uri(uint256 _id) external view returns (string memory);
    function proxyTransfer721(address _from, address _to, uint256 _tokenId, bytes _data) external;
    function proxyTransfer20(address _from, address _to, uint256 _tokenId, uint256 _value) external;
    /**
        @notice Get the balance of an account's Tokens.
        @param _owner  The address of the token holder
        @param _id     ID of the Token
        @return        The _owner's balance of the Token type requested
     */
    function balanceOf(address _owner, uint256 _id) external view returns (uint256);
    /**
        @notice Transfers `_value` amount of an `_id` from the `_from` address to the `_to` address specified (with safety call).
        @dev Caller must be approved to manage the tokens being transferred out of the `_from` account (see "Approval" section of the standard).
        MUST revert if `_to` is the zero address.
        MUST revert if balance of holder for token `_id` is lower than the `_value` sent.
        MUST revert on any other error.
        MUST emit the `TransferSingle` event to reflect the balance change (see "Safe Transfer Rules" section of the standard).
        After the above conditions are met, this function MUST check if `_to` is a smart contract (e.g. code size > 0). If so, it MUST call `onERC1155Received` on `_to` and act appropriately (see "Safe Transfer Rules" section of the standard).
        @param _from    Source address
        @param _to      Target address
        @param _id      ID of the token type
        @param _value   Transfer amount
        @param _data    Additional data with no specified format, MUST be sent unaltered in call to `onERC1155Received` on `_to`
    */
    function safeTransferFrom(address _from, address _to, uint256 _id, uint256 _value, bytes _data) external;
}

pragma solidity ^0.4.23;

interface PluginsInterface
{
    function isPlugin(address contractAddress) external view returns(bool);
    function withdraw() external;
    function setMinSign(uint40 _newMinSignId) external;

    function runPluginOperator(
        address _pluginAddress,
        uint40 _signId,
        uint40 _cutieId,
        uint128 _value,
        uint256 _parameter,
        address _sender) external payable;
}

pragma solidity ^0.4.23;

/**
    Note: The ERC-165 identifier for this interface is 0x43b236a2.
*/
interface IERC1155TokenReceiver {

    /**
        @notice Handle the receipt of a single ERC1155 token type.
        @dev An ERC1155-compliant smart contract MUST call this function on the token recipient contract, at the end of a `safeTransferFrom` after the balance has been updated.
        This function MUST return `bytes4(keccak256("accept_erc1155_tokens()"))` (i.e. 0x4dc21a2f) if it accepts the transfer.
        This function MUST revert if it rejects the transfer.
        Return of any other value than the prescribed keccak256 generated value MUST result in the transaction being reverted by the caller.
        @param _operator  The address which initiated the transfer (i.e. msg.sender)
        @param _from      The address which previously owned the token
        @param _id        The id of the token being transferred
        @param _value     The amount of tokens being transferred
        @param _data      Additional data with no specified format
        @return           `bytes4(keccak256("accept_erc1155_tokens()"))`
    */
    function onERC1155Received(address _operator, address _from, uint256 _id, uint256 _value, bytes _data) external returns(bytes4);

    /**
        @notice Handle the receipt of multiple ERC1155 token types.
        @dev An ERC1155-compliant smart contract MUST call this function on the token recipient contract, at the end of a `safeBatchTransferFrom` after the balances have been updated.
        This function MUST return `bytes4(keccak256("accept_batch_erc1155_tokens()"))` (i.e. 0xac007889) if it accepts the transfer(s).
        This function MUST revert if it rejects the transfer(s).
        Return of any other value than the prescribed keccak256 generated value MUST result in the transaction being reverted by the caller.
        @param _operator  The address which initiated the batch transfer (i.e. msg.sender)
        @param _from      The address which previously owned the token
        @param _ids       An array containing ids of each token being transferred (order and length must match _values array)
        @param _values    An array containing amounts of each token being transferred (order and length must match _ids array)
        @param _data      Additional data with no specified format
        @return           `bytes4(keccak256("accept_batch_erc1155_tokens()"))`
    */
    function onERC1155BatchReceived(address _operator, address _from, uint256[] _ids, uint256[] _values, bytes _data) external returns(bytes4);

    /**
        @notice Indicates whether a contract implements the `ERC1155TokenReceiver` functions and so can accept ERC1155 token types.
        @dev This function MUST return `bytes4(keccak256("isERC1155TokenReceiver()"))` (i.e. 0x0d912442).
        This function MUST NOT consume more than 5,000 gas.
        @return           `bytes4(keccak256("isERC1155TokenReceiver()"))`
    */
    function isERC1155TokenReceiver() external view returns (bytes4);
}


/// @title BlockchainCuties: Collectible and breedable cuties on the Ethereum blockchain.
/// @dev This contract allows players to buy cutie for fiat currency.
///      Server accepts fiat payment and call proxy contract bo buy cutie on market and
///      transfer it to purchaser.
/// @author https://BlockChainArchitect.io
contract FiatProxy is Operators, IERC1155TokenReceiver {

    CutieCoreInterface public core;
    PluginsInterface public plugins;
    PresaleInterface public sale;

    event OrderSuccess(uint orderId, uint value, address purchaser);

    function setup(CutieCoreInterface _core, PluginsInterface _plugins, PresaleInterface _sale) external onlyOwner
    {
        core = _core;
        plugins = _plugins;
        sale = _sale;
    }

    function deposit() external payable
    {
        // accept money
    }

    function () external payable
    {
        // accept money
    }

    function buyCutie(uint40 _orderId, uint40 _cutieId, uint _value, address _saleMarketAddress, address _purchaser) external onlyOperator
    {
        MarketInterface market = MarketInterface(_saleMarketAddress);
        market.bid.value(_value)(_cutieId);

        core.transfer(_purchaser, _cutieId);

        emit OrderSuccess(_orderId, _value, _purchaser);
    }

    function buySaleLot(uint40 _orderId, uint32 _lotId, uint _value, address _purchaser) external onlyOperator
    {
        sale.bidWithPlugin(_lotId, _purchaser, _value, address(0x0));

        emit OrderSuccess(_orderId, _value, _purchaser);
    }

    function runPlugin(
        uint40 _orderId,
        address _pluginAddress,
        uint40 _signId,
        uint40 _cutieId,
        uint128 _value,
        uint256 _parameter,
        address _purchaser) external onlyOperator
    {
        plugins.runPluginOperator.value(_value)(_pluginAddress, _signId, _cutieId, _value, _parameter, _purchaser);

        emit OrderSuccess(_orderId, _value, _purchaser);
    }

    function isERC1155TokenReceiver() external view returns (bytes4)
    {
        return bytes4(keccak256("isERC1155TokenReceiver()"));
    }

    function onERC1155BatchReceived(address, address, uint256[], uint256[], bytes) external returns(bytes4)
    {
        return bytes4(keccak256("accept_batch_erc1155_tokens()"));
    }

    function onERC1155Received(address, address, uint256, uint256, bytes) external returns(bytes4)
    {
        return bytes4(keccak256("accept_erc1155_tokens()"));
    }
}

Contract Security Audit

Contract ABI

[{"constant":true,"inputs":[],"name":"isERC1155TokenReceiver","outputs":[{"name":"","type":"bytes4"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_orderId","type":"uint40"},{"name":"_pluginAddress","type":"address"},{"name":"_signId","type":"uint40"},{"name":"_cutieId","type":"uint40"},{"name":"_value","type":"uint128"},{"name":"_parameter","type":"uint256"},{"name":"_purchaser","type":"address"}],"name":"runPlugin","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"_oldOwner","type":"address"}],"name":"removeOwner","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"_addr","type":"address"}],"name":"isOwner","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_tokenContract","type":"address"}],"name":"approveERC721","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"plugins","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"sale","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"name":"_addr","type":"address"}],"name":"isOperator","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_newOwner","type":"address"}],"name":"addOwner","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"_core","type":"address"},{"name":"_plugins","type":"address"},{"name":"_sale","type":"address"}],"name":"setup","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"_orderId","type":"uint40"},{"name":"_lotId","type":"uint32"},{"name":"_value","type":"uint256"},{"name":"_purchaser","type":"address"}],"name":"buySaleLot","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"_newOperator","type":"address"}],"name":"addOperator","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[],"name":"withdrawEth","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"_orderId","type":"uint40"},{"name":"_cutieId","type":"uint40"},{"name":"_value","type":"uint256"},{"name":"_saleMarketAddress","type":"address"},{"name":"_purchaser","type":"address"}],"name":"buyCutie","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"_oldOperator","type":"address"}],"name":"removeOperator","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"","type":"address"},{"name":"","type":"address"},{"name":"","type":"uint256[]"},{"name":"","type":"uint256[]"},{"name":"","type":"bytes"}],"name":"onERC1155BatchReceived","outputs":[{"name":"","type":"bytes4"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"_tokenContract","type":"address"}],"name":"approveERC1155","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[],"name":"deposit","outputs":[],"payable":true,"stateMutability":"payable","type":"function"},{"constant":false,"inputs":[{"name":"","type":"address"},{"name":"","type":"address"},{"name":"","type":"uint256"},{"name":"","type":"uint256"},{"name":"","type":"bytes"}],"name":"onERC1155Received","outputs":[{"name":"","type":"bytes4"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"core","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_tokenContract","type":"address"}],"name":"withdrawERC20","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"payable":true,"stateMutability":"payable","type":"fallback"},{"anonymous":false,"inputs":[{"indexed":false,"name":"orderId","type":"uint256"},{"indexed":false,"name":"value","type":"uint256"},{"indexed":false,"name":"purchaser","type":"address"}],"name":"OrderSuccess","type":"event"}]

Deployed Bytecode

0x60806040526004361061011c5763ffffffff7c01000000000000000000000000000000000000000000000000000000006000350416630d912442811461011e5780630dfdcb3c14610168578063173825d9146101c25780632f54bf6e146101e357806346195c121461021857806358af80cf146102395780636ad1fe021461026a5780636d70f7ae1461027f5780637065cb48146102a057806377b8b1c7146102c15780638909da18146102ee5780639870d7fe14610325578063a0ef91df14610346578063a5659f381461035b578063ac8a584a14610395578063bc197c81146103b6578063c6b72a1f14610218578063d0e30db014610403578063f23a6e611461040b578063f2f4eb2614610448578063f4f3b2001461045d575b005b34801561012a57600080fd5b5061013361047e565b604080517fffffffff000000000000000000000000000000000000000000000000000000009092168252519081900360200190f35b34801561017457600080fd5b5061011c64ffffffffff600435811690600160a060020a03602435811691604435811691606435909116906fffffffffffffffffffffffffffffffff608435169060a4359060c435166104b3565b3480156101ce57600080fd5b5061011c600160a060020a03600435166105f1565b3480156101ef57600080fd5b50610204600160a060020a0360043516610630565b604080519115158252519081900360200190f35b34801561022457600080fd5b5061011c600160a060020a036004351661064e565b34801561024557600080fd5b5061024e6106ee565b60408051600160a060020a039092168252519081900360200190f35b34801561027657600080fd5b5061024e6106fd565b34801561028b57600080fd5b50610204600160a060020a036004351661070c565b3480156102ac57600080fd5b5061011c600160a060020a0360043516610751565b3480156102cd57600080fd5b5061011c600160a060020a03600435811690602435811690604435166107a8565b3480156102fa57600080fd5b5061011c64ffffffffff6004351663ffffffff60243516604435600160a060020a0360643516610812565b34801561033157600080fd5b5061011c600160a060020a0360043516610914565b34801561035257600080fd5b5061011c61096e565b34801561036757600080fd5b5061011c64ffffffffff60043581169060243516604435600160a060020a03606435811690608435166109c7565b3480156103a157600080fd5b5061011c600160a060020a0360043516610b4b565b3480156103c257600080fd5b50610133600160a060020a03600480358216916024803590911691604435808301929082013591606435808301929082013591608435918201910135610b8a565b61011c6109c5565b34801561041757600080fd5b50610133600160a060020a036004803582169160248035909116916044359160643591608435918201910135610bc8565b34801561045457600080fd5b5061024e610c04565b34801561046957600080fd5b5061011c600160a060020a0360043516610c13565b604080517f697345524331313535546f6b656e5265636569766572282900000000000000008152905190819003601801902090565b6104bc3361070c565b15156104c757600080fd5b600354604080517f3281f140000000000000000000000000000000000000000000000000000000008152600160a060020a03898116600483015264ffffffffff808a166024840152881660448301526fffffffffffffffffffffffffffffffff871660648301526084820186905284811660a483015291519190921691633281f14091869160c48082019260009290919082900301818588803b15801561056d57600080fd5b505af1158015610581573d6000803e3d6000fd5b50506040805164ffffffffff8c1681526fffffffffffffffffffffffffffffffff88166020820152600160a060020a0386168183015290517fee36984dc5479d79d41ef58f94200ff3be5ca95f31a4dad4d9ef17884230e54494509081900360600192509050a150505050505050565b3360009081526020819052604090205460ff16151561060f57600080fd5b600160a060020a03166000908152602081905260409020805460ff19169055565b600160a060020a031660009081526020819052604090205460ff1690565b3360009081526020819052604090205460ff16151561066c57600080fd5b604080517fa22cb465000000000000000000000000000000000000000000000000000000008152336004820152600160248201529051600160a060020a0383169163a22cb46591604480830192600092919082900301818387803b1580156106d357600080fd5b505af11580156106e7573d6000803e3d6000fd5b5050505050565b600354600160a060020a031681565b600454600160a060020a031681565b600160a060020a03811660009081526001602052604081205460ff168061074b5750600160a060020a03821660009081526020819052604090205460ff165b92915050565b3360009081526020819052604090205460ff16151561076f57600080fd5b600160a060020a038116151561078457600080fd5b600160a060020a03166000908152602081905260409020805460ff19166001179055565b3360009081526020819052604090205460ff1615156107c657600080fd5b60028054600160a060020a0394851673ffffffffffffffffffffffffffffffffffffffff1991821617909155600380549385169382169390931790925560048054919093169116179055565b61081b3361070c565b151561082657600080fd5b60048054604080517fb536b23500000000000000000000000000000000000000000000000000000000815263ffffffff871693810193909352600160a060020a03848116602485015260448401869052600060648501819052915192169263b536b235926084808301939282900301818387803b1580156108a657600080fd5b505af11580156108ba573d6000803e3d6000fd5b50506040805164ffffffffff8816815260208101869052600160a060020a0385168183015290517fee36984dc5479d79d41ef58f94200ff3be5ca95f31a4dad4d9ef17884230e5449350908190036060019150a150505050565b3360009081526020819052604090205460ff16151561093257600080fd5b600160a060020a038116151561094757600080fd5b600160a060020a03166000908152600160208190526040909120805460ff19169091179055565b3360009081526020819052604090205460ff16151561098c57600080fd5b6000303111156109c5576040513390303180156108fc02916000818181858888f193505050501580156109c3573d6000803e3d6000fd5b505b565b60006109d23361070c565b15156109dd57600080fd5b82905080600160a060020a031663c170fd5485876040518363ffffffff167c0100000000000000000000000000000000000000000000000000000000028152600401808264ffffffffff1664ffffffffff1681526020019150506000604051808303818588803b158015610a5057600080fd5b505af1158015610a64573d6000803e3d6000fd5b5050600254604080517fa9059cbb000000000000000000000000000000000000000000000000000000008152600160a060020a03888116600483015264ffffffffff8c166024830152915191909216945063a9059cbb93506044808301935060009282900301818387803b158015610adb57600080fd5b505af1158015610aef573d6000803e3d6000fd5b50506040805164ffffffffff8a16815260208101889052600160a060020a0386168183015290517fee36984dc5479d79d41ef58f94200ff3be5ca95f31a4dad4d9ef17884230e5449350908190036060019150a1505050505050565b3360009081526020819052604090205460ff161515610b6957600080fd5b600160a060020a03166000908152600160205260409020805460ff19169055565b604080517f6163636570745f62617463685f657263313135355f746f6b656e7328290000008152905190819003601d01902098975050505050505050565b604080517f6163636570745f657263313135355f746f6b656e732829000000000000000000815290519081900360170190209695505050505050565b600254600160a060020a031681565b3360009081526020819052604081205460ff161515610c3157600080fd5b604080517f70a082310000000000000000000000000000000000000000000000000000000081523060048201529051600160a060020a038416916370a082319160248083019260209291908290030181600087803b158015610c9257600080fd5b505af1158015610ca6573d6000803e3d6000fd5b505050506040513d6020811015610cbc57600080fd5b5051604080517fa9059cbb000000000000000000000000000000000000000000000000000000008152336004820152602481018390529051919250600160a060020a0384169163a9059cbb916044808201926020929091908290030181600087803b158015610d2a57600080fd5b505af1158015610d3e573d6000803e3d6000fd5b505050506040513d6020811015610d5457600080fd5b505050505600a165627a7a723058206b4fb33d57791ceccc94803852b6aa41948bbc1bb5dc2b4c339278a2c12c816b0029

Deployed Bytecode Sourcemap

34456:2199:0:-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;36140:141;;8:9:-1;5:2;;;30:1;27;20:12;5:2;36140:141:0;;;;;;;;;;;;;;;;;;;;;;;35707:425;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;35707:425:0;;;;;;;-1:-1:-1;;;;;35707:425:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;18729:109;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;18729:109:0;-1:-1:-1;;;;;18729:109:0;;;;;18459:104;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;18459:104:0;-1:-1:-1;;;;;18459:104:0;;;;;;;;;;;;;;;;;;;;;;;19591:139;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;19591:139:0;-1:-1:-1;;;;;19591:139:0;;;;;34557:31;;8:9:-1;5:2;;;30:1;27;20:12;5:2;34557:31:0;;;;;;;;-1:-1:-1;;;;;34557:31:0;;;;;;;;;;;;;;34595:28;;8:9:-1;5:2;;;30:1;27;20:12;5:2;34595:28:0;;;;18940:133;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;18940:133:0;-1:-1:-1;;;;;18940:133:0;;;;;18571:150;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;18571:150:0;-1:-1:-1;;;;;18571:150:0;;;;;34704:199;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;34704:199:0;-1:-1:-1;;;;;34704:199:0;;;;;;;;;;;;;;;35448:251;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;35448:251:0;;;;;;;;;;;-1:-1:-1;;;;;35448:251:0;;;;;19081:165;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;19081:165:0;-1:-1:-1;;;;;19081:165:0;;;;;19888:174;;8:9:-1;5:2;;;30:1;27;20:12;5:2;19888:174:0;;;;35068:372;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;35068:372:0;;;;;;;;;;;;-1:-1:-1;;;;;35068:372:0;;;;;;;;;;19254:121;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;19254:121:0;-1:-1:-1;;;;;19254:121:0;;;;;36289:185;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;36289:185:0;-1:-1:-1;;;;;36289:185:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;34911:74;;;;36482:170;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;36482:170:0;-1:-1:-1;;;;;36482:170:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;34520:30;;8:9:-1;5:2;;;30:1;27;20:12;5:2;34520:30:0;;;;19383:200;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;19383:200:0;-1:-1:-1;;;;;19383:200:0;;;;;36140:141;36235:37;;;;;;;;;;;;;;;;36140:141;:::o;35707:425::-;18889:22;18900:10;18889;:22::i;:::-;18881:31;;;;;;;;35958:7;;:106;;;;;;-1:-1:-1;;;;;35958:106:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:7;;;;;:25;;35990:6;;35958:106;;;;;:7;;:106;;;;;;;;35990:6;35958:7;:106;;;5:2:-1;;;;30:1;27;20:12;5:2;35958:106:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;-1:-1;;36082:42:0;;;;;;;;;;;;;;;-1:-1:-1;;;;;36082:42:0;;;;;;;;;;-1:-1:-1;36082:42:0;;;;;;;-1:-1:-1;36082:42:0;-1:-1:-1;36082:42:0;35707:425;;;;;;;:::o;18729:109::-;18419:10;18406:12;:24;;;;;;;;;;;;;18398:33;;;;;;;;-1:-1:-1;;;;;18806:23:0;:12;:23;;;;;;;;;;18799:31;;-1:-1:-1;;18799:31:0;;;18729:109::o;18459:104::-;-1:-1:-1;;;;;18536:19:0;18512:4;18536:19;;;;;;;;;;;;;;18459:104::o;19591:139::-;18419:10;18406:12;:24;;;;;;;;;;;;;18398:33;;;;;;;;19672:50;;;;;;19705:10;19672:50;;;;19717:4;19672:50;;;;;;-1:-1:-1;;;;;19672:32:0;;;;;:50;;;;;-1:-1:-1;;19672:50:0;;;;;;;-1:-1:-1;19672:32:0;:50;;;5:2:-1;;;;30:1;27;20:12;5:2;19672:50:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;19672:50:0;;;;19591:139;:::o;34557:31::-;;;-1:-1:-1;;;;;34557:31:0;;:::o;34595:28::-;;;-1:-1:-1;;;;;34595:28:0;;:::o;18940:133::-;-1:-1:-1;;;;;19020:22:0;;18996:4;19020:22;;;:15;:22;;;;;;;;;:45;;-1:-1:-1;;;;;;19046:19:0;;:12;:19;;;;;;;;;;;;;19020:45;19013:52;18940:133;-1:-1:-1;;18940:133:0:o;18571:150::-;18419:10;18406:12;:24;;;;;;;;;;;;;18398:33;;;;;;;;-1:-1:-1;;;;;18646:23:0;;;;18638:32;;;;;;-1:-1:-1;;;;;18683:23:0;:12;:23;;;;;;;;;;:30;;-1:-1:-1;;18683:30:0;18709:4;18683:30;;;18571:150::o;34704:199::-;18419:10;18406:12;:24;;;;;;;;;;;;;18398:33;;;;;;;;34831:4;:12;;-1:-1:-1;;;;;34831:12:0;;;-1:-1:-1;;34831:12:0;;;;;;;34854:7;:18;;;;;;;;;;;;;;;34883:4;:12;;;;;;;;;;;34704:199::o;35448:251::-;18889:22;18900:10;18889;:22::i;:::-;18881:31;;;;;;;;35571:4;;;:60;;;;;;;;;;;;;;;;-1:-1:-1;;;;;35571:60:0;;;;;;;;;;;;;:4;:60;;;;;;;;:4;;;:18;;:60;;;;;:4;:60;;;;;:4;;:60;;;5:2:-1;;;;30:1;27;20:12;5:2;35571:60:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;-1:-1;;35649:42:0;;;;;;;;;;;;;;-1:-1:-1;;;;;35649:42:0;;;;;;;;;;-1:-1:-1;35649:42:0;;;;;;;-1:-1:-1;35649:42:0;35448:251;;;;:::o;19081:165::-;18419:10;18406:12;:24;;;;;;;;;;;;;18398:33;;;;;;;;-1:-1:-1;;;;;19162:26:0;;;;19154:35;;;;;;-1:-1:-1;;;;;19202:29:0;;;;;19234:4;19202:29;;;;;;;;:36;;-1:-1:-1;;19202:36:0;;;;;;19081:165::o;19888:174::-;18419:10;18406:12;:24;;;;;;;;;;;;;18398:33;;;;;;;;19974:1;19958:4;19950:21;:25;19946:109;;;20001:42;;:10;;20029:4;20021:21;20001:42;;;;;;;;;20021:21;20001:10;:42;;;;;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;20001:42:0;19946:109;19888:174::o;35068:372::-;35219:22;18889;18900:10;18889;:22::i;:::-;18881:31;;;;;;;;35260:18;35219:60;;35290:6;-1:-1:-1;;;;;35290:10:0;;35307:6;35315:8;35290:34;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;35290:34:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;-1:-1;;35337:4:0;;:35;;;;;;-1:-1:-1;;;;;35337:35:0;;;;;;;;;;;;;;;;:4;;;;;-1:-1:-1;35337:13:0;;-1:-1:-1;35337:35:0;;;;;-1:-1:-1;35337:4:0;;:35;;;;;:4;;:35;;;5:2:-1;;;;30:1;27;20:12;5:2;35337:35:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;-1:-1;;35390:42:0;;;;;;;;;;;;;;-1:-1:-1;;;;;35390:42:0;;;;;;;;;;-1:-1:-1;35390:42:0;;;;;;;-1:-1:-1;35390:42:0;35068:372;;;;;;:::o;19254:121::-;18419:10;18406:12;:24;;;;;;;;;;;;;18398:33;;;;;;;;-1:-1:-1;;;;;19337:29:0;;;;;:15;:29;;;;;19330:37;;-1:-1:-1;;19330:37:0;;;19254:121::o;36289:185::-;36423:42;;;;;;;;;;;;;;;;36289:185;;;;;;;;;;:::o;36482:170::-;36607:36;;;;;;;;;;;;;;;;36482:170;;;;;;;;:::o;34520:30::-;;;-1:-1:-1;;;;;34520:30:0;;:::o;19383:200::-;18419:10;19463:15;18406:24;;;;;;;;;;;;;18398:33;;;;;;;;19481:39;;;;;;19514:4;19481:39;;;;;;-1:-1:-1;;;;;19481:24:0;;;;;:39;;;;;;;;;;;;;;-1:-1:-1;19481:24:0;:39;;;5:2:-1;;;;30:1;27;20:12;5:2;19481:39:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;19481:39:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;19481:39:0;19531:44;;;;;;19555:10;19531:44;;;;;;;;;;;;19481:39;;-1:-1:-1;;;;;;19531:23:0;;;;;:44;;;;;19481:39;;19531:44;;;;;;;;-1:-1:-1;19531:23:0;:44;;;5:2:-1;;;;30:1;27;20:12;5:2;19531:44:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;19531:44:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;19383:200:0:o

Swarm Source

bzzr://6b4fb33d57791ceccc94803852b6aa41948bbc1bb5dc2b4c339278a2c12c816b

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  ]
[ 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.