Feature Tip: Add private address tag to any address under My Name Tag !
Overview
ETH Balance
0 ETH
Eth Value
$0.00More Info
Private Name Tags
ContractCreator
Latest 25 from a total of 297 transactions
Transaction Hash |
Method
|
Block
|
From
|
To
|
|||||
---|---|---|---|---|---|---|---|---|---|
Withdraw Eth | 11283445 | 1470 days ago | IN | 0 ETH | 0.00159477 | ||||
Setup | 10512788 | 1588 days ago | IN | 0 ETH | 0.0019614 | ||||
Run Plugin | 10339016 | 1615 days ago | IN | 0 ETH | 0.0024027 | ||||
Buy Sale Lot | 10338928 | 1615 days ago | IN | 0 ETH | 0.00269934 | ||||
Buy Sale Lot | 10321188 | 1618 days ago | IN | 0 ETH | 0.00404901 | ||||
Run Plugin | 10264383 | 1627 days ago | IN | 0 ETH | 0.00173821 | ||||
Run Plugin | 10264035 | 1627 days ago | IN | 0 ETH | 0.00148967 | ||||
Run Plugin | 10264000 | 1627 days ago | IN | 0 ETH | 0.00144984 | ||||
Buy Sale Lot | 10223327 | 1633 days ago | IN | 0 ETH | 0.00260936 | ||||
Buy Cutie | 10223325 | 1633 days ago | IN | 0 ETH | 0.00274397 | ||||
Buy Cutie | 10219512 | 1634 days ago | IN | 0 ETH | 0.00267074 | ||||
Run Plugin | 10202861 | 1636 days ago | IN | 0 ETH | 0.00136173 | ||||
Run Plugin | 10176216 | 1640 days ago | IN | 0 ETH | 0.00140979 | ||||
Buy Cutie | 10104491 | 1652 days ago | IN | 0 ETH | 0.00205346 | ||||
Buy Cutie | 10092544 | 1653 days ago | IN | 0 ETH | 0.00136897 | ||||
Buy Cutie | 9940297 | 1677 days ago | IN | 0 ETH | 0.0007236 | ||||
Buy Cutie | 9940227 | 1677 days ago | IN | 0 ETH | 0.00026684 | ||||
Buy Cutie | 9928822 | 1679 days ago | IN | 0 ETH | 0.00097042 | ||||
Run Plugin | 9926100 | 1679 days ago | IN | 0 ETH | 0.00052058 | ||||
Buy Sale Lot | 9917246 | 1681 days ago | IN | 0 ETH | 0.00053994 | ||||
Run Plugin | 9913272 | 1681 days ago | IN | 0 ETH | 0.00048061 | ||||
Buy Sale Lot | 9909142 | 1682 days ago | IN | 0 ETH | 0.00044995 | ||||
Buy Cutie | 9903166 | 1683 days ago | IN | 0 ETH | 0.0005867 | ||||
Buy Cutie | 9872393 | 1688 days ago | IN | 0 ETH | 0.00024899 | ||||
Buy Cutie | 9869093 | 1688 days ago | IN | 0 ETH | 0.00058813 |
Latest 25 internal transactions (View All)
Advanced mode:
Parent Transaction Hash | Block | From | To | |||
---|---|---|---|---|---|---|
11283445 | 1470 days ago | 47.62063363 ETH | ||||
10339016 | 1615 days ago | 0.00015 ETH | ||||
10264383 | 1627 days ago | 0.0187 ETH | ||||
10264035 | 1627 days ago | 0.0006 ETH | ||||
10264000 | 1627 days ago | 0.0009 ETH | ||||
10223325 | 1633 days ago | 0.002 ETH | ||||
10219512 | 1634 days ago | 0.1 ETH | ||||
10202861 | 1636 days ago | 0.001 ETH | ||||
10176216 | 1640 days ago | 0.00193 ETH | ||||
10104491 | 1652 days ago | 0.03 ETH | ||||
10092544 | 1653 days ago | 0.0015 ETH | ||||
9940297 | 1677 days ago | 0.008 ETH | ||||
9940227 | 1677 days ago | 0.07 ETH | ||||
9928822 | 1679 days ago | 0.0015 ETH | ||||
9926100 | 1679 days ago | 0.0044 ETH | ||||
9913272 | 1681 days ago | 0.0045 ETH | ||||
9903166 | 1683 days ago | 0.002 ETH | ||||
9872393 | 1688 days ago | 0.05 ETH | ||||
9869093 | 1688 days ago | 0.0005 ETH | ||||
9867122 | 1688 days ago | 0.02515379 ETH | ||||
9867102 | 1688 days ago | 0.01 ETH | ||||
9853755 | 1690 days ago | 0.00489419 ETH | ||||
9846441 | 1691 days ago | 0.005 ETH | ||||
9754394 | 1706 days ago | 0.0000285 ETH | ||||
9745587 | 1707 days ago | 0.00088244 ETH |
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
- No Contract Security Audit Submitted- Submit Audit Here
[{"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
Loading...
Loading
Loading...
Loading
Multichain Portfolio | 30 Chains
Chain | Token | Portfolio % | Price | Amount | Value |
---|---|---|---|---|---|
POL | 100.00% | $0.569908 | 0.1 | $0.056991 |
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.