Contract 0xc90EcA83aC8b56f350129588b73B31feE67fE9D0

 

Contract Overview

Balance:
0.025 BNB

BNB Value:
$8.78 (@ $351.12/BNB)

Token:
Txn Hash
Block
From
To
Value [Txn Fee]
0xf39f1ce57f2597433b46024907aa4dcb5d257da50c3c76a47ce50ee73317f45a70756322021-05-02 15:07:0846 days 18 hrs agoArtstro: Deployer IN  0xc90eca83ac8b56f350129588b73b31fee67fe9d00.025 BNB0.00093812
0x83870fef04652a3310130d6b89f9d6d61a47105588f331c90068e6c4fabdc35962767212021-04-04 14:35:0374 days 19 hrs agoArtstro: Deployer IN  0xc90eca83ac8b56f350129588b73b31fee67fe9d00 BNB0.00030568
0xe83a7a25e553bba9b9a97b0dc55ad28e865ab6156c0c0f111b0726dc9f3c8a0962359042021-04-03 4:10:4076 days 5 hrs agoArtstro: Deployer IN  0xc90eca83ac8b56f350129588b73b31fee67fe9d00.025 BNB0.00196024
0x800de75b53991b9c831cf774d5bcb131a8475fc7b102ff5ade0c01f9ac3da50d62313182021-04-03 0:21:2176 days 9 hrs agoArtstro: Deployer IN  0xc90eca83ac8b56f350129588b73b31fee67fe9d00 BNB0.00030568
0x17fdcdf5ba916291f2d5d82bda5730d90242f776f59fb0af44bb6de4404947a862252662021-04-02 19:18:1676 days 14 hrs ago0xa3996b9388d492a5cfb130f6408b1109da63277a IN  0xc90eca83ac8b56f350129588b73b31fee67fe9d00.025 BNB0.00187624
0xc63c90272f0036d5fd83b2d950852849cb64f1650a6a1f61a99e3dcd1a67abe159922552021-03-25 15:18:2784 days 18 hrs agoArtstro: Deployer IN  0xc90eca83ac8b56f350129588b73b31fee67fe9d00 BNB0.00030568
0x3c8f9e5421f3ff3c136eaf0d1dbd092ff9ca992133afc09210babde69158fe4e59921912021-03-25 15:15:1584 days 18 hrs agoArtstro: Deployer IN  0xc90eca83ac8b56f350129588b73b31fee67fe9d00.025 BNB0.00202624
0x82649abab7beda4a9b69664e4e57fe3674d59532b8a4facb58ab95d0e179e41a59919982021-03-25 15:05:3684 days 18 hrs agoArtstro: Deployer IN  Contract Creation0 BNB0.01278163
[ Download CSV Export 
Latest 3 internal transactions
Parent Txn Hash Block From To Value
0x83870fef04652a3310130d6b89f9d6d61a47105588f331c90068e6c4fabdc35962767212021-04-04 14:35:0374 days 19 hrs ago 0xc90eca83ac8b56f350129588b73b31fee67fe9d0Artstro: Deployer0.025 BNB
0x800de75b53991b9c831cf774d5bcb131a8475fc7b102ff5ade0c01f9ac3da50d62313182021-04-03 0:21:2176 days 9 hrs ago 0xc90eca83ac8b56f350129588b73b31fee67fe9d0Artstro: Deployer0.025 BNB
0xc63c90272f0036d5fd83b2d950852849cb64f1650a6a1f61a99e3dcd1a67abe159922552021-03-25 15:18:2784 days 18 hrs ago 0xc90eca83ac8b56f350129588b73b31fee67fe9d0Artstro: Deployer0.025 BNB
[ Download CSV Export 
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
BuySale

Compiler Version
v0.8.0+commit.c7dfd78e

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, None license

Contract Source Code (Solidity)

/**
 *Submitted for verification at BscScan.com on 2021-03-25
*/

pragma solidity ^0.8.0;

library SafeMath {
    /**
     * @dev Returns the addition of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `+` operator.
     *
     * Requirements:
     *
     * - Addition cannot overflow.
     */
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");

        return c;
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting on
     * overflow (when the result is negative).
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return sub(a, b, "SafeMath: subtraction overflow");
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting with custom message on
     * overflow (when the result is negative).
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b <= a, errorMessage);
        uint256 c = a - b;

        return c;
    }

    /**
     * @dev Returns the multiplication of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `*` operator.
     *
     * Requirements:
     *
     * - Multiplication cannot overflow.
     */
    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        // Gas optimization: this is cheaper than requiring 'a' not being zero, but the
        // benefit is lost if 'b' is also tested.
        // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522
        if (a == 0) {
            return 0;
        }

        uint256 c = a * b;
        require(c / a == b, "SafeMath: multiplication overflow");

        return c;
    }

    /**
     * @dev Returns the integer division of two unsigned integers. Reverts on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return div(a, b, "SafeMath: division by zero");
    }

    /**
     * @dev Returns the integer division of two unsigned integers. Reverts with custom message on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b > 0, errorMessage);
        uint256 c = a / b;
        // assert(a == b * c + a % b); // There is no case in which this doesn't hold

        return c;
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * Reverts when dividing by zero.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        return mod(a, b, "SafeMath: modulo by zero");
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * Reverts with custom message when dividing by zero.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b != 0, errorMessage);
        return a % b;
    }
}


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

/**
 * @dev Required interface of an ERC721 compliant contract.
 */
interface IERC721 is IERC165 {
    /**
     * @dev Emitted when `tokenId` token is transferred from `from` to `to`.
     */
    event Transfer(address indexed from, address indexed to, uint256 indexed tokenId);

    /**
     * @dev Emitted when `owner` enables `approved` to manage the `tokenId` token.
     */
    event Approval(address indexed owner, address indexed approved, uint256 indexed tokenId);

    /**
     * @dev Emitted when `owner` enables or disables (`approved`) `operator` to manage all of its assets.
     */
    event ApprovalForAll(address indexed owner, address indexed operator, bool approved);

    /**
     * @dev Returns the number of tokens in ``owner``'s account.
     */
    function balanceOf(address owner) external view returns (uint256 balance);

    /**
     * @dev Returns the owner of the `tokenId` token.
     *
     * Requirements:
     *
     * - `tokenId` must exist.
     */
    function ownerOf(uint256 tokenId) external view returns (address owner);

    /**
     * @dev Safely transfers `tokenId` token from `from` to `to`, checking first that contract recipients
     * are aware of the ERC721 protocol to prevent tokens from being forever locked.
     *
     * Requirements:
     *
     * - `from` cannot be the zero address.
     * - `to` cannot be the zero address.
     * - `tokenId` token must exist and be owned by `from`.
     * - If the caller is not `from`, it must be have been allowed to move this token by either {approve} or {setApprovalForAll}.
     * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.
     *
     * Emits a {Transfer} event.
     */
    function safeTransferFrom(address from, address to, uint256 tokenId) external;

    /**
     * @dev Transfers `tokenId` token from `from` to `to`.
     *
     * WARNING: Usage of this method is discouraged, use {safeTransferFrom} whenever possible.
     *
     * Requirements:
     *
     * - `from` cannot be the zero address.
     * - `to` cannot be the zero address.
     * - `tokenId` token must be owned by `from`.
     * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.
     *
     * Emits a {Transfer} event.
     */
    function transferFrom(address from, address to, uint256 tokenId) external;

    /**
     * @dev Gives permission to `to` to transfer `tokenId` token to another account.
     * The approval is cleared when the token is transferred.
     *
     * Only a single account can be approved at a time, so approving the zero address clears previous approvals.
     *
     * Requirements:
     *
     * - The caller must own the token or be an approved operator.
     * - `tokenId` must exist.
     *
     * Emits an {Approval} event.
     */
    function approve(address to, uint256 tokenId) external;

    /**
     * @dev Returns the account approved for `tokenId` token.
     *
     * Requirements:
     *
     * - `tokenId` must exist.
     */
    function getApproved(uint256 tokenId) external view returns (address operator);

    /**
     * @dev Approve or remove `operator` as an operator for the caller.
     * Operators can call {transferFrom} or {safeTransferFrom} for any token owned by the caller.
     *
     * Requirements:
     *
     * - The `operator` cannot be the caller.
     *
     * Emits an {ApprovalForAll} event.
     */
    function setApprovalForAll(address operator, bool _approved) external;

    /**
     * @dev Returns if the `operator` is allowed to manage all of the assets of `owner`.
     *
     * See {setApprovalForAll}
     */
    function isApprovedForAll(address owner, address operator) external view returns (bool);

    /**
      * @dev Safely transfers `tokenId` token from `from` to `to`.
      *
      * Requirements:
      *
      * - `from` cannot be the zero address.
      * - `to` cannot be the zero address.
      * - `tokenId` token must exist and be owned by `from`.
      * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.
      * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.
      *
      * Emits a {Transfer} event.
      */
    function safeTransferFrom(address from, address to, uint256 tokenId, bytes calldata data) external;
}

/**
 * @title ERC-721 Non-Fungible Token Standard, optional metadata extension
 * @dev See https://eips.ethereum.org/EIPS/eip-721
 */
interface IERC721Metadata is IERC721 {

    /**
     * @dev Returns the token collection name.
     */
    function name() external view returns (string memory);

    /**
     * @dev Returns the token collection symbol.
     */
    function symbol() external view returns (string memory);

    /**
     * @dev Returns the Uniform Resource Identifier (URI) for `tokenId` token.
     */
    function tokenURI(uint256 tokenId) external view returns (string memory);
}


interface artstro is IERC721Metadata {
    function tokenRoyaltyShare(uint256 _id) external view returns(uint256); 
    function firstOwnerOfToken(uint256 _id) external view returns(address);
    function NFTValue(uint256 _if) external view returns(uint256);
}

abstract contract Context {
    function _msgSender() internal view virtual returns (address) {
        return msg.sender;
    }

    function _msgData() internal view virtual returns (bytes calldata) {
        this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691
        return msg.data;
    }
}

abstract contract Ownable is Context {
    address private _owner;

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

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor () {
        address msgSender = _msgSender();
        _owner = msgSender;
        emit OwnershipTransferred(address(0), msgSender);
    }

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

    /**
     * @dev Throws if called by any account other than the owner.
     */
    modifier onlyOwner() {
        require(owner() == _msgSender(), "Ownable: caller is not the owner");
        _;
    }

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

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

contract BuySale is Ownable(){
    artstro token; 
    
    uint256 fees;
    using SafeMath for uint256;
    
    mapping(uint256 => address) public tokenRegistered;
    mapping(uint256 => bool) public isAvailable;
    mapping(uint256 => uint256) public tokenPrice;
    
    event NftRegistered(address indexed _user,address indexed _to,uint256 _tokenId,uint256 _price,string _uri);
    event tokenSold(address indexed _from, address indexed _to,uint256 _tokenId,uint256 _tokenPrice,string _uri,address indexed tokenOwner);
    
    constructor() public {
        token = artstro(0x92595603D198B4Dc99098701DDC313D2fEc56E88);
        fees = 0.025 ether;
    }
    
    function registerNFT(uint256 _tokenId) public payable {
        require(msg.value >= fees,"ERROR: you don't have enough fees");
        require(token.balanceOf(msg.sender) > 0,"ERROR: not enough balance");
        require(token.ownerOf(_tokenId) == msg.sender,"ERROR: you don't own this token");
        require(!isAvailable[_tokenId],"ERROR: token already registered");
        
        tokenRegistered[_tokenId] = msg.sender;
        isAvailable[_tokenId] = true;
        tokenPrice[_tokenId] = getTokenValue(_tokenId);
        
        token.transferFrom(msg.sender,address(this),_tokenId);
        
        emit NftRegistered(msg.sender,address(this),_tokenId,tokenPrice[_tokenId],token.tokenURI(_tokenId));
    } 
    
    function buyToken(uint256 _tokenId) public payable {
        require(isAvailable[_tokenId],"ERROR: this token is not available for sell");
        require(msg.value >= fees + tokenPrice[_tokenId],"ERROR: not enough price for token");
        
        uint256 royalty = getRoyalty(_tokenId);
        address firstOwner = getFirstOwner(_tokenId);
        uint256 balance = tokenPrice[_tokenId];
        address seller = tokenRegistered[_tokenId];
        uint256 royaltyBalance = balance.mul(royalty).div(100);
        balance = balance.sub(royaltyBalance);
        
        payable(firstOwner).transfer(royaltyBalance);
        payable(seller).transfer(balance);
        
        token.transferFrom(address(this),msg.sender,_tokenId);
        isAvailable[_tokenId] = false;
        tokenRegistered[_tokenId] = msg.sender;
        emit tokenSold(address(this),msg.sender,_tokenId,tokenPrice[_tokenId],token.tokenURI(_tokenId),seller);
    }
    
    function changeTokenPrice(uint256 _tokenId,uint256 _newTokenPrice) public payable {
        require(msg.sender == tokenRegistered[_tokenId],"ERROR: you are not owner of this token");
        require(msg.value >= fees,"ERROR: not enough fees");
        tokenPrice[_tokenId] = _newTokenPrice;
    }
    
    function findToken(uint256 _tokenId) public view returns(string memory _uri){
        if(isAvailable[_tokenId]){
            return token.tokenURI(_tokenId);
        }else{
            return 'ERROR';
        }
    }
    
    /* ONLY OWNER  */
    
    function changeFees(uint256 _newFee) public onlyOwner {
        fees = _newFee;
    }
    
    function withdrawFees() public onlyOwner {
        payable(owner()).transfer(address(this).balance);
    }
    
    function contarctBalance() public view returns(uint256) {
        return address(this).balance;
    }
    
    function nftBalance() public view returns(uint256) {
        return token.balanceOf(address(this));
    }
    
    function getRoyalty(uint256 _id) public view returns(uint256) {
        return token.tokenRoyaltyShare(_id);
    }
    
    function getFirstOwner(uint256 _id) public view returns(address) {
        return token.firstOwnerOfToken(_id);
    }
    
    function getTokenValue(uint256 _id) public view returns(uint256) {
        return token.NFTValue(_id);
    }
}

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"_user","type":"address"},{"indexed":true,"internalType":"address","name":"_to","type":"address"},{"indexed":false,"internalType":"uint256","name":"_tokenId","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"_price","type":"uint256"},{"indexed":false,"internalType":"string","name":"_uri","type":"string"}],"name":"NftRegistered","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"_from","type":"address"},{"indexed":true,"internalType":"address","name":"_to","type":"address"},{"indexed":false,"internalType":"uint256","name":"_tokenId","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"_tokenPrice","type":"uint256"},{"indexed":false,"internalType":"string","name":"_uri","type":"string"},{"indexed":true,"internalType":"address","name":"tokenOwner","type":"address"}],"name":"tokenSold","type":"event"},{"inputs":[{"internalType":"uint256","name":"_tokenId","type":"uint256"}],"name":"buyToken","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_newFee","type":"uint256"}],"name":"changeFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_tokenId","type":"uint256"},{"internalType":"uint256","name":"_newTokenPrice","type":"uint256"}],"name":"changeTokenPrice","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"contarctBalance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_tokenId","type":"uint256"}],"name":"findToken","outputs":[{"internalType":"string","name":"_uri","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"}],"name":"getFirstOwner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"}],"name":"getRoyalty","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"}],"name":"getTokenValue","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"isAvailable","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"nftBalance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_tokenId","type":"uint256"}],"name":"registerNFT","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"tokenPrice","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"tokenRegistered","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"withdrawFees","outputs":[],"stateMutability":"nonpayable","type":"function"}]

608060405234801561001057600080fd5b50600061001b61009b565b600080546001600160a01b0319166001600160a01b0383169081178255604051929350917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350600180546001600160a01b0319167392595603d198b4dc99098701ddc313d2fec56e881790556658d15e1762800060025561009f565b3390565b6114fa806100ae6000396000f3fe6080604052600436106100fe5760003560e01c806362e8e8ac11610095578063b4c2c7fa11610064578063b4c2c7fa14610271578063d10424c714610284578063d4ddce8a146102a4578063df9b2097146102c4578063f2fde38b146102e4576100fe565b806362e8e8ac146102145780636cda375b14610227578063715018a6146102475780638da5cb5b1461025c576100fe565b806340f52b82116100d157806340f52b82146101a85780634730169b146101bd578063476343ee146101ea5780635301fa6f146101ff576100fe565b80631af9cf49146101035780632d296bf1146101395780633a178d991461014e57806340a58a321461017b575b600080fd5b34801561010f57600080fd5b5061012361011e366004611046565b610304565b60405161013091906113bd565b60405180910390f35b61014c610147366004611046565b61038d565b005b34801561015a57600080fd5b5061016e610169366004611046565b610640565b60405161013091906110fb565b34801561018757600080fd5b5061019b610196366004611046565b610655565b60405161013091906110c3565b3480156101b457600080fd5b506101236106d6565b3480156101c957600080fd5b506101dd6101d8366004611046565b6106da565b6040516101309190611106565b3480156101f657600080fd5b5061014c6107a1565b34801561020b57600080fd5b50610123610823565b61014c610222366004611076565b6108a9565b34801561023357600080fd5b5061014c610242366004611046565b610913565b34801561025357600080fd5b5061014c610957565b34801561026857600080fd5b5061019b6109e0565b61014c61027f366004611046565b6109ef565b34801561029057600080fd5b5061012361029f366004611046565b610d0f565b3480156102b057600080fd5b506101236102bf366004611046565b610d40565b3480156102d057600080fd5b5061019b6102df366004611046565b610d52565b3480156102f057600080fd5b5061014c6102ff366004610f6b565b610d6d565b60015460405163a35c16bb60e01b81526000916001600160a01b03169063a35c16bb906103359085906004016113bd565b60206040518083038186803b15801561034d57600080fd5b505afa158015610361573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610385919061105e565b90505b919050565b60008181526004602052604090205460ff166103c45760405162461bcd60e51b81526004016103bb90611372565b60405180910390fd5b6000818152600560205260409020546002546103e091906113e5565b3410156103ff5760405162461bcd60e51b81526004016103bb90611295565b600061040a82610304565b9050600061041783610655565b6000848152600560209081526040808320546003909252822054929350916001600160a01b031690610454606461044e8588610e2d565b90610e7b565b90506104608382610ebd565b6040519093506001600160a01b0385169082156108fc029083906000818181858888f19350505050158015610499573d6000803e3d6000fd5b506040516001600160a01b0383169084156108fc029085906000818181858888f193505050501580156104d0573d6000803e3d6000fd5b506001546040516323b872dd60e01b81526001600160a01b03909116906323b872dd9061050590309033908b906004016110d7565b600060405180830381600087803b15801561051f57600080fd5b505af1158015610533573d6000803e3d6000fd5b5050506000878152600460208181526040808420805460ff191690556003825280842080546001600160a01b0319163390811790915560059092529283902054600154935163c87b56dd60e01b81526001600160a01b038881169650929430947fa8286777d3ed22d852686e65f3b228a69c889705259fd397c23ce98218db0680948e949392169163c87b56dd916105cd918691016113bd565b60006040518083038186803b1580156105e557600080fd5b505afa1580156105f9573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526106219190810190610fa3565b604051610630939291906113c6565b60405180910390a4505050505050565b60046020526000908152604090205460ff1681565b600154604051632ae74e3d60e21b81526000916001600160a01b03169063ab9d38f4906106869085906004016113bd565b60206040518083038186803b15801561069e57600080fd5b505afa1580156106b2573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906103859190610f87565b4790565b60008181526004602052604090205460609060ff161561077f5760015460405163c87b56dd60e01b81526001600160a01b039091169063c87b56dd906107249085906004016113bd565b60006040518083038186803b15801561073c57600080fd5b505afa158015610750573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526107789190810190610fa3565b9050610388565b5060408051808201909152600581526422a92927a960d91b6020820152610388565b6107a9610eff565b6001600160a01b03166107ba6109e0565b6001600160a01b0316146107e05760405162461bcd60e51b81526004016103bb906112d6565b6107e86109e0565b6001600160a01b03166108fc479081150290604051600060405180830381858888f19350505050158015610820573d6000803e3d6000fd5b50565b6001546040516370a0823160e01b81526000916001600160a01b0316906370a08231906108549030906004016110c3565b60206040518083038186803b15801561086c57600080fd5b505afa158015610880573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108a4919061105e565b905090565b6000828152600360205260409020546001600160a01b031633146108df5760405162461bcd60e51b81526004016103bb90611119565b6002543410156109015760405162461bcd60e51b81526004016103bb9061130b565b60009182526005602052604090912055565b61091b610eff565b6001600160a01b031661092c6109e0565b6001600160a01b0316146109525760405162461bcd60e51b81526004016103bb906112d6565b600255565b61095f610eff565b6001600160a01b03166109706109e0565b6001600160a01b0316146109965760405162461bcd60e51b81526004016103bb906112d6565b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b6000546001600160a01b031690565b600254341015610a115760405162461bcd60e51b81526004016103bb906111a5565b6001546040516370a0823160e01b81526000916001600160a01b0316906370a0823190610a429033906004016110c3565b60206040518083038186803b158015610a5a57600080fd5b505afa158015610a6e573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a92919061105e565b11610aaf5760405162461bcd60e51b81526004016103bb906111e6565b6001546040516331a9108f60e11b815233916001600160a01b031690636352211e90610adf9085906004016113bd565b60206040518083038186803b158015610af757600080fd5b505afa158015610b0b573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610b2f9190610f87565b6001600160a01b031614610b555760405162461bcd60e51b81526004016103bb9061133b565b60008181526004602052604090205460ff1615610b845760405162461bcd60e51b81526004016103bb9061121d565b600081815260036020908152604080832080546001600160a01b0319163317905560049091529020805460ff19166001179055610bc081610d0f565b600082815260056020526040908190209190915560015490516323b872dd60e01b81526001600160a01b03909116906323b872dd90610c07903390309086906004016110d7565b600060405180830381600087803b158015610c2157600080fd5b505af1158015610c35573d6000803e3d6000fd5b5050506000828152600560205260409081902054600154915163c87b56dd60e01b815230935033927fb624922a878a4bda663d00559a8f8d05507df020a8fa5e39b872b8d768ea24d592869290916001600160a01b03169063c87b56dd90610ca19085906004016113bd565b60006040518083038186803b158015610cb957600080fd5b505afa158015610ccd573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052610cf59190810190610fa3565b604051610d04939291906113c6565b60405180910390a350565b60015460405163fa8f04fb60e01b81526000916001600160a01b03169063fa8f04fb906103359085906004016113bd565b60056020526000908152604090205481565b6003602052600090815260409020546001600160a01b031681565b610d75610eff565b6001600160a01b0316610d866109e0565b6001600160a01b031614610dac5760405162461bcd60e51b81526004016103bb906112d6565b6001600160a01b038116610dd25760405162461bcd60e51b81526004016103bb9061115f565b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b600082610e3c57506000610e75565b6000610e48838561141d565b905082610e5585836113fd565b14610e725760405162461bcd60e51b81526004016103bb90611254565b90505b92915050565b6000610e7283836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250610f03565b6000610e7283836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250610f3a565b3390565b60008183610f245760405162461bcd60e51b81526004016103bb9190611106565b506000610f3184866113fd565b95945050505050565b60008184841115610f5e5760405162461bcd60e51b81526004016103bb9190611106565b506000610f31848661143c565b600060208284031215610f7c578081fd5b8135610e72816114af565b600060208284031215610f98578081fd5b8151610e72816114af565b600060208284031215610fb4578081fd5b815167ffffffffffffffff80821115610fcb578283fd5b818401915084601f830112610fde578283fd5b815181811115610ff057610ff0611499565b604051601f8201601f19168101602001838111828210171561101457611014611499565b60405281815283820160200187101561102b578485fd5b61103c826020830160208701611453565b9695505050505050565b600060208284031215611057578081fd5b5035919050565b60006020828403121561106f578081fd5b5051919050565b60008060408385031215611088578081fd5b50508035926020909101359150565b600081518084526110af816020860160208601611453565b601f01601f19169290920160200192915050565b6001600160a01b0391909116815260200190565b6001600160a01b039384168152919092166020820152604081019190915260600190565b901515815260200190565b600060208252610e726020830184611097565b60208082526026908201527f4552524f523a20796f7520617265206e6f74206f776e6572206f662074686973604082015265103a37b5b2b760d11b606082015260800190565b60208082526026908201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160408201526564647265737360d01b606082015260800190565b60208082526021908201527f4552524f523a20796f7520646f6e2774206861766520656e6f756768206665656040820152607360f81b606082015260800190565b60208082526019908201527f4552524f523a206e6f7420656e6f7567682062616c616e636500000000000000604082015260600190565b6020808252601f908201527f4552524f523a20746f6b656e20616c7265616479207265676973746572656400604082015260600190565b60208082526021908201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6040820152607760f81b606082015260800190565b60208082526021908201527f4552524f523a206e6f7420656e6f75676820707269636520666f7220746f6b656040820152603760f91b606082015260800190565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b6020808252601690820152754552524f523a206e6f7420656e6f756768206665657360501b604082015260600190565b6020808252601f908201527f4552524f523a20796f7520646f6e2774206f776e207468697320746f6b656e00604082015260600190565b6020808252602b908201527f4552524f523a207468697320746f6b656e206973206e6f7420617661696c616260408201526a1b1948199bdc881cd95b1b60aa1b606082015260800190565b90815260200190565b600084825283602083015260606040830152610f316060830184611097565b600082198211156113f8576113f8611483565b500190565b60008261141857634e487b7160e01b81526012600452602481fd5b500490565b600081600019048311821515161561143757611437611483565b500290565b60008282101561144e5761144e611483565b500390565b60005b8381101561146e578181015183820152602001611456565b8381111561147d576000848401525b50505050565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052604160045260246000fd5b6001600160a01b038116811461082057600080fdfea26469706673582212201e32050774a05ddade331293187b4d6489cb744ab1b54c6d26f7045e664b43b264736f6c63430008000033

Deployed ByteCode Sourcemap

13089:3798:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;16515:116;;;;;;;;;;-1:-1:-1;16515:116:0;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;14519:956;;;;;;:::i;:::-;;:::i;:::-;;13267:43;;;;;;;;;;-1:-1:-1;13267:43:0;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;16643:119::-;;;;;;;;;;-1:-1:-1;16643:119:0;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;16281:103::-;;;;;;;;;;;;;:::i;15799:222::-;;;;;;;;;;-1:-1:-1;15799:222:0;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;16161:108::-;;;;;;;;;;;;;:::i;16396:107::-;;;;;;;;;;;;;:::i;15487:300::-;;;;;;:::i;:::-;;:::i;16062:87::-;;;;;;;;;;-1:-1:-1;16062:87:0;;;;;:::i;:::-;;:::i;12535:148::-;;;;;;;;;;;;;:::i;11884:87::-;;;;;;;;;;;;;:::i;13776:730::-;;;;;;:::i;:::-;;:::i;16774:110::-;;;;;;;;;;-1:-1:-1;16774:110:0;;;;;:::i;:::-;;:::i;13317:45::-;;;;;;;;;;-1:-1:-1;13317:45:0;;;;;:::i;:::-;;:::i;13210:50::-;;;;;;;;;;-1:-1:-1;13210:50:0;;;;;:::i;:::-;;:::i;12838:244::-;;;;;;;;;;-1:-1:-1;12838:244:0;;;;;:::i;:::-;;:::i;16515:116::-;16595:5;;:28;;-1:-1:-1;;;16595:28:0;;16568:7;;-1:-1:-1;;;;;16595:5:0;;:23;;:28;;16619:3;;16595:28;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;16588:35;;16515:116;;;;:::o;14519:956::-;14589:21;;;;:11;:21;;;;;;;;14581:76;;;;-1:-1:-1;;;14581:76:0;;;;;;;:::i;:::-;;;;;;;;;14696:20;;;;:10;:20;;;;;;14689:4;;:27;;14696:20;14689:27;:::i;:::-;14676:9;:40;;14668:85;;;;-1:-1:-1;;;14668:85:0;;;;;;;:::i;:::-;14774:15;14792:20;14803:8;14792:10;:20::i;:::-;14774:38;;14823:18;14844:23;14858:8;14844:13;:23::i;:::-;14878:15;14896:20;;;:10;:20;;;;;;;;;14944:15;:25;;;;;;14823:44;;-1:-1:-1;14896:20:0;-1:-1:-1;;;;;14944:25:0;;15005:29;15030:3;15005:20;14896;15017:7;15005:11;:20::i;:::-;:24;;:29::i;:::-;14980:54;-1:-1:-1;15055:27:0;:7;14980:54;15055:11;:27::i;:::-;15103:44;;15045:37;;-1:-1:-1;;;;;;15103:28:0;;;:44;;;;;15132:14;;15103:44;;;;15132:14;15103:28;:44;;;;;;;;;;;;;;;;;;;;-1:-1:-1;15158:33:0;;-1:-1:-1;;;;;15158:24:0;;;:33;;;;;15183:7;;15158:33;;;;15183:7;15158:24;:33;;;;;;;;;;;;;;;;;;;;-1:-1:-1;15212:5:0;;:53;;-1:-1:-1;;;15212:53:0;;-1:-1:-1;;;;;15212:5:0;;;;:18;;:53;;15239:4;;15245:10;;15256:8;;15212:53;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;15300:5:0;15276:21;;;:11;:21;;;;;;;;:29;;-1:-1:-1;;15276:29:0;;;15316:15;:25;;;;;:38;;-1:-1:-1;;;;;;15316:38:0;15344:10;15316:38;;;;;;15414:10;:20;;;;;;;;15276:29;15435:5;:24;;-1:-1:-1;;;15435:24:0;;-1:-1:-1;;;;;15370:97:0;;;;-1:-1:-1;15344:10:0;;15388:4;;15370:97;;15288:8;;15414:20;15435:5;;;:14;;:24;;15288:8;;15435:24;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;15435:24:0;;;;;;;;;;;;:::i;:::-;15370:97;;;;;;;;:::i;:::-;;;;;;;;14519:956;;;;;;:::o;13267:43::-;;;;;;;;;;;;;;;:::o;16643:119::-;16726:5;;:28;;-1:-1:-1;;;16726:28:0;;16699:7;;-1:-1:-1;;;;;16726:5:0;;:23;;:28;;16750:3;;16726:28;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;16281:103::-;16355:21;16281:103;:::o;15799:222::-;15889:21;;;;:11;:21;;;;;;15856:18;;15889:21;;15886:128;;;15933:5;;:24;;-1:-1:-1;;;15933:24:0;;-1:-1:-1;;;;;15933:5:0;;;;:14;;:24;;15948:8;;15933:24;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;15933:24:0;;;;;;;;;;;;:::i;:::-;15926:31;;;;15886:128;-1:-1:-1;15988:14:0;;;;;;;;;;;;-1:-1:-1;;;15988:14:0;;;;;;16161:108;12115:12;:10;:12::i;:::-;-1:-1:-1;;;;;12104:23:0;:7;:5;:7::i;:::-;-1:-1:-1;;;;;12104:23:0;;12096:68;;;;-1:-1:-1;;;12096:68:0;;;;;;;:::i;:::-;16221:7:::1;:5;:7::i;:::-;-1:-1:-1::0;;;;;16213:25:0::1;:48;16239:21;16213:48;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;16161:108::o:0;16396:107::-;16465:5;;:30;;-1:-1:-1;;;16465:30:0;;16438:7;;-1:-1:-1;;;;;16465:5:0;;:15;;:30;;16489:4;;16465:30;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;16458:37;;16396:107;:::o;15487:300::-;15602:25;;;;:15;:25;;;;;;-1:-1:-1;;;;;15602:25:0;15588:10;:39;15580:89;;;;-1:-1:-1;;;15580:89:0;;;;;;;:::i;:::-;15701:4;;15688:9;:17;;15680:51;;;;-1:-1:-1;;;15680:51:0;;;;;;;:::i;:::-;15742:20;;;;:10;:20;;;;;;:37;15487:300::o;16062:87::-;12115:12;:10;:12::i;:::-;-1:-1:-1;;;;;12104:23:0;:7;:5;:7::i;:::-;-1:-1:-1;;;;;12104:23:0;;12096:68;;;;-1:-1:-1;;;12096:68:0;;;;;;;:::i;:::-;16127:4:::1;:14:::0;16062:87::o;12535:148::-;12115:12;:10;:12::i;:::-;-1:-1:-1;;;;;12104:23:0;:7;:5;:7::i;:::-;-1:-1:-1;;;;;12104:23:0;;12096:68;;;;-1:-1:-1;;;12096:68:0;;;;;;;:::i;:::-;12642:1:::1;12626:6:::0;;12605:40:::1;::::0;-1:-1:-1;;;;;12626:6:0;;::::1;::::0;12605:40:::1;::::0;12642:1;;12605:40:::1;12673:1;12656:19:::0;;-1:-1:-1;;;;;;12656:19:0::1;::::0;;12535:148::o;11884:87::-;11930:7;11957:6;-1:-1:-1;;;;;11957:6:0;11884:87;:::o;13776:730::-;13862:4;;13849:9;:17;;13841:62;;;;-1:-1:-1;;;13841:62:0;;;;;;;:::i;:::-;13922:5;;:27;;-1:-1:-1;;;13922:27:0;;13952:1;;-1:-1:-1;;;;;13922:5:0;;:15;;:27;;13938:10;;13922:27;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;:31;13914:68;;;;-1:-1:-1;;;13914:68:0;;;;;;;:::i;:::-;14001:5;;:23;;-1:-1:-1;;;14001:23:0;;14028:10;;-1:-1:-1;;;;;14001:5:0;;:13;;:23;;14015:8;;14001:23;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1;;;;;14001:37:0;;13993:80;;;;-1:-1:-1;;;13993:80:0;;;;;;;:::i;:::-;14093:21;;;;:11;:21;;;;;;;;14092:22;14084:65;;;;-1:-1:-1;;;14084:65:0;;;;;;;:::i;:::-;14170:25;;;;:15;:25;;;;;;;;:38;;-1:-1:-1;;;;;;14170:38:0;14198:10;14170:38;;;14219:11;:21;;;;;:28;;-1:-1:-1;;14219:28:0;14170:38;14219:28;;;14281:23;14186:8;14281:13;:23::i;:::-;14258:20;;;;:10;:20;;;;;;;:46;;;;14325:5;;:53;;-1:-1:-1;;;14325:53:0;;-1:-1:-1;;;;;14325:5:0;;;;:18;;:53;;14344:10;;14363:4;;14269:8;;14325:53;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;14452:20:0;;;;:10;:20;;;;;;;;14473:5;;:24;;-1:-1:-1;;;14473:24:0;;14437:4;;-1:-1:-1;14418:10:0;;14404:94;;14443:8;;14452:20;;-1:-1:-1;;;;;14473:5:0;;:14;;:24;;14443:8;;14473:24;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;14473:24:0;;;;;;;;;;;;:::i;:::-;14404:94;;;;;;;;:::i;:::-;;;;;;;;13776:730;:::o;16774:110::-;16857:5;;:19;;-1:-1:-1;;;16857:19:0;;16830:7;;-1:-1:-1;;;;;16857:5:0;;:14;;:19;;16872:3;;16857:19;;;:::i;13317:45::-;;;;;;;;;;;;;:::o;13210:50::-;;;;;;;;;;;;-1:-1:-1;;;;;13210:50:0;;:::o;12838:244::-;12115:12;:10;:12::i;:::-;-1:-1:-1;;;;;12104:23:0;:7;:5;:7::i;:::-;-1:-1:-1;;;;;12104:23:0;;12096:68;;;;-1:-1:-1;;;12096:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;12927:22:0;::::1;12919:73;;;;-1:-1:-1::0;;;12919:73:0::1;;;;;;;:::i;:::-;13029:6;::::0;;13008:38:::1;::::0;-1:-1:-1;;;;;13008:38:0;;::::1;::::0;13029:6;::::1;::::0;13008:38:::1;::::0;::::1;13057:6;:17:::0;;-1:-1:-1;;;;;;13057:17:0::1;-1:-1:-1::0;;;;;13057:17:0;;;::::1;::::0;;;::::1;::::0;;12838:244::o;1644:471::-;1702:7;1947:6;1943:47;;-1:-1:-1;1977:1:0;1970:8;;1943:47;2002:9;2014:5;2018:1;2014;:5;:::i;:::-;2002:17;-1:-1:-1;2047:1:0;2038:5;2042:1;2002:17;2038:5;:::i;:::-;:10;2030:56;;;;-1:-1:-1;;;2030:56:0;;;;;;;:::i;:::-;2106:1;-1:-1:-1;1644:471:0;;;;;:::o;2591:132::-;2649:7;2676:39;2680:1;2683;2676:39;;;;;;;;;;;;;;;;;:3;:39::i;754:136::-;812:7;839:43;843:1;846;839:43;;;;;;;;;;;;;;;;;:3;:43::i;11035:98::-;11115:10;11035:98;:::o;3219:278::-;3305:7;3340:12;3333:5;3325:28;;;;-1:-1:-1;;;3325:28:0;;;;;;;;:::i;:::-;-1:-1:-1;3364:9:0;3376:5;3380:1;3376;:5;:::i;:::-;3364:17;3219:278;-1:-1:-1;;;;;3219:278:0:o;1193:192::-;1279:7;1315:12;1307:6;;;;1299:29;;;;-1:-1:-1;;;1299:29:0;;;;;;;;:::i;:::-;-1:-1:-1;1339:9:0;1351:5;1355:1;1351;:5;:::i;14:259:1:-;;126:2;114:9;105:7;101:23;97:32;94:2;;;147:6;139;132:22;94:2;191:9;178:23;210:33;237:5;210:33;:::i;278:263::-;;401:2;389:9;380:7;376:23;372:32;369:2;;;422:6;414;407:22;369:2;459:9;453:16;478:33;505:5;478:33;:::i;546:894::-;;679:2;667:9;658:7;654:23;650:32;647:2;;;700:6;692;685:22;647:2;738:9;732:16;767:18;808:2;800:6;797:14;794:2;;;829:6;821;814:22;794:2;872:6;861:9;857:22;847:32;;917:7;910:4;906:2;902:13;898:27;888:2;;944:6;936;929:22;888:2;978;972:9;1000:2;996;993:10;990:2;;;1006:18;;:::i;:::-;1055:2;1049:9;1124:2;1105:13;;-1:-1:-1;;1101:27:1;1089:40;;1131:2;1085:49;1149:18;;;1169:22;;;1146:46;1143:2;;;1195:18;;:::i;:::-;1231:2;1224:22;1255:18;;;1292:11;;;1305:2;1288:20;1285:33;-1:-1:-1;1282:2:1;;;1336:6;1328;1321:22;1282:2;1354:55;1406:2;1401;1393:6;1389:15;1384:2;1380;1376:11;1354:55;:::i;:::-;1428:6;637:803;-1:-1:-1;;;;;;637:803:1:o;1445:190::-;;1557:2;1545:9;1536:7;1532:23;1528:32;1525:2;;;1578:6;1570;1563:22;1525:2;-1:-1:-1;1606:23:1;;1515:120;-1:-1:-1;1515:120:1:o;1640:194::-;;1763:2;1751:9;1742:7;1738:23;1734:32;1731:2;;;1784:6;1776;1769:22;1731:2;-1:-1:-1;1812:16:1;;1721:113;-1:-1:-1;1721:113:1:o;1839:258::-;;;1968:2;1956:9;1947:7;1943:23;1939:32;1936:2;;;1989:6;1981;1974:22;1936:2;-1:-1:-1;;2017:23:1;;;2087:2;2072:18;;;2059:32;;-1:-1:-1;1926:171:1:o;2102:260::-;;2184:5;2178:12;2211:6;2206:3;2199:19;2227:63;2283:6;2276:4;2271:3;2267:14;2260:4;2253:5;2249:16;2227:63;:::i;:::-;2344:2;2323:15;-1:-1:-1;;2319:29:1;2310:39;;;;2351:4;2306:50;;2154:208;-1:-1:-1;;2154:208:1:o;2367:203::-;-1:-1:-1;;;;;2531:32:1;;;;2513:51;;2501:2;2486:18;;2468:102::o;2575:375::-;-1:-1:-1;;;;;2833:15:1;;;2815:34;;2885:15;;;;2880:2;2865:18;;2858:43;2932:2;2917:18;;2910:34;;;;2765:2;2750:18;;2732:218::o;2955:187::-;3120:14;;3113:22;3095:41;;3083:2;3068:18;;3050:92::o;3147:222::-;;3296:2;3285:9;3278:21;3316:47;3359:2;3348:9;3344:18;3336:6;3316:47;:::i;3374:402::-;3576:2;3558:21;;;3615:2;3595:18;;;3588:30;3654:34;3649:2;3634:18;;3627:62;-1:-1:-1;;;3720:2:1;3705:18;;3698:36;3766:3;3751:19;;3548:228::o;3781:402::-;3983:2;3965:21;;;4022:2;4002:18;;;3995:30;4061:34;4056:2;4041:18;;4034:62;-1:-1:-1;;;4127:2:1;4112:18;;4105:36;4173:3;4158:19;;3955:228::o;4188:397::-;4390:2;4372:21;;;4429:2;4409:18;;;4402:30;4468:34;4463:2;4448:18;;4441:62;-1:-1:-1;;;4534:2:1;4519:18;;4512:31;4575:3;4560:19;;4362:223::o;4590:349::-;4792:2;4774:21;;;4831:2;4811:18;;;4804:30;4870:27;4865:2;4850:18;;4843:55;4930:2;4915:18;;4764:175::o;4944:355::-;5146:2;5128:21;;;5185:2;5165:18;;;5158:30;5224:33;5219:2;5204:18;;5197:61;5290:2;5275:18;;5118:181::o;5304:397::-;5506:2;5488:21;;;5545:2;5525:18;;;5518:30;5584:34;5579:2;5564:18;;5557:62;-1:-1:-1;;;5650:2:1;5635:18;;5628:31;5691:3;5676:19;;5478:223::o;5706:397::-;5908:2;5890:21;;;5947:2;5927:18;;;5920:30;5986:34;5981:2;5966:18;;5959:62;-1:-1:-1;;;6052:2:1;6037:18;;6030:31;6093:3;6078:19;;5880:223::o;6108:356::-;6310:2;6292:21;;;6329:18;;;6322:30;6388:34;6383:2;6368:18;;6361:62;6455:2;6440:18;;6282:182::o;6469:346::-;6671:2;6653:21;;;6710:2;6690:18;;;6683:30;-1:-1:-1;;;6744:2:1;6729:18;;6722:52;6806:2;6791:18;;6643:172::o;6820:355::-;7022:2;7004:21;;;7061:2;7041:18;;;7034:30;7100:33;7095:2;7080:18;;7073:61;7166:2;7151:18;;6994:181::o;7180:407::-;7382:2;7364:21;;;7421:2;7401:18;;;7394:30;7460:34;7455:2;7440:18;;7433:62;-1:-1:-1;;;7526:2:1;7511:18;;7504:41;7577:3;7562:19;;7354:233::o;7592:177::-;7738:25;;;7726:2;7711:18;;7693:76::o;7774:364::-;;7979:6;7968:9;7961:25;8022:6;8017:2;8006:9;8002:18;7995:34;8065:2;8060;8049:9;8045:18;8038:30;8085:47;8128:2;8117:9;8113:18;8105:6;8085:47;:::i;8143:128::-;;8214:1;8210:6;8207:1;8204:13;8201:2;;;8220:18;;:::i;:::-;-1:-1:-1;8256:9:1;;8191:80::o;8276:217::-;;8342:1;8332:2;;-1:-1:-1;;;8367:31:1;;8421:4;8418:1;8411:15;8449:4;8374:1;8439:15;8332:2;-1:-1:-1;8478:9:1;;8322:171::o;8498:168::-;;8604:1;8600;8596:6;8592:14;8589:1;8586:21;8581:1;8574:9;8567:17;8563:45;8560:2;;;8611:18;;:::i;:::-;-1:-1:-1;8651:9:1;;8550:116::o;8671:125::-;;8739:1;8736;8733:8;8730:2;;;8744:18;;:::i;:::-;-1:-1:-1;8781:9:1;;8720:76::o;8801:258::-;8873:1;8883:113;8897:6;8894:1;8891:13;8883:113;;;8973:11;;;8967:18;8954:11;;;8947:39;8919:2;8912:10;8883:113;;;9014:6;9011:1;9008:13;9005:2;;;9049:1;9040:6;9035:3;9031:16;9024:27;9005:2;;8854:205;;;:::o;9064:127::-;9125:10;9120:3;9116:20;9113:1;9106:31;9156:4;9153:1;9146:15;9180:4;9177:1;9170:15;9196:127;9257:10;9252:3;9248:20;9245:1;9238:31;9288:4;9285:1;9278:15;9312:4;9309:1;9302:15;9328:133;-1:-1:-1;;;;;9405:31:1;;9395:42;;9385:2;;9451:1;9448;9441:12

Swarm Source

ipfs://1e32050774a05ddade331293187b4d6489cb744ab1b54c6d26f7045e664b43b2
Block Transaction Gas Used Reward
Age Block Fee Address BC Fee Address Voting Power Jailed Incoming
Block Uncle Number Difficulty Gas Used Reward
Loading
Loading
Make sure to use the "Vote Down" button for any spammy posts, and the "Vote Up" for interesting conversations.