ETH Price: $2,346.76 (-2.94%)

Token

StellarLoom (SL)
 

Overview

Max Total Supply

100,000,000 SL

Holders

40

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
1,107,532.356262849074922834 SL

Value
$0.00
0xa418fa83f7768714bd11533971fe041ac5128ef3
Loading...
Loading
Loading...
Loading
Loading...
Loading

Click here to update the token information / general information
# Exchange Pair Price  24H Volume % Volume

Contract Source Code Verified (Exact Match)

Contract Name:
StellarLoom

Compiler Version
v0.8.19+commit.7dd6d404

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2023-11-27
*/

/**
Website:   https://www.stellarloom.loan
Docs:      https://docs.stellarloom.loan

Telegram:  https://t.me/stellarloom
Twitter:   https://twitter.com/stellarloom
*/

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.11;

// pragma solidity >=0.5.0;

interface IUniswapV2Pair {
    event Approval(address indexed owner, address indexed spender, uint value);
    event Transfer(address indexed from, address indexed to, uint value);

    function name() external pure returns (string memory);

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

    function decimals() external pure returns (uint8);

    function totalSupply() external view returns (uint);

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

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

    function approve(address spender, uint value) external returns (bool);

    function transfer(address to, uint value) external returns (bool);

    function transferFrom(
        address from,
        address to,
        uint value
    ) external returns (bool);

    function DOMAIN_SEPARATOR() external view returns (bytes32);

    function PERMIT_TYPEHASH() external pure returns (bytes32);

    function nonces(address owner) external view returns (uint);

    function permit(
        address owner,
        address spender,
        uint value,
        uint deadline,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external;

    function sync() external;
}

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

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

// Dependency file: https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/access/Ownable.sol

// pragma solidity ^0.6.0;

// import "@openzeppelin/contracts/GSN/Context.sol";
/**
 * @dev Contract module which provides a basic access control mechanism, where
 * there is an account (an owner) that can be granted exclusive access to
 * specific functions.
 *
 * By default, the owner account will be the one that deploys the contract. This
 * can later be changed with {transferOwnership}.
 *
 * This module is used through inheritance. It will make available the modifier
 * `onlyOwner`, which can be applied to your functions to restrict their use to
 * the owner.
 */
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 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;
    }
}

// Dependency file: https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/token/ERC20/IERC20.sol

// pragma solidity ^0.6.0;

/**
 * @dev Interface of the ERC20 standard as defined in the EIP.
 */
interface IERC20 {
    /**
     * @dev Returns the amount of tokens in existence.
     */
    function totalSupply() external view returns (uint256);

    /**
     * @dev Returns the amount of tokens owned by `account`.
     */
    function balanceOf(address account) external view returns (uint256);

    /**
     * @dev Moves `amount` tokens from the caller's account to `recipient`.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transfer(
        address recipient,
        uint256 amount
    ) external returns (bool);

    /**
     * @dev Returns the remaining number of tokens that `spender` will be
     * allowed to spend on behalf of `owner` through {transferFrom}. This is
     * zero by default.
     *
     * This value changes when {approve} or {transferFrom} are called.
     */
    function allowance(
        address owner,
        address spender
    ) external view returns (uint256);

    /**
     * @dev Sets `amount` as the allowance of `spender` over the caller's tokens.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * // importANT: Beware that changing an allowance with this method brings the risk
     * that someone may use both the old and the new allowance by unfortunate
     * transaction ordering. One possible solution to mitigate this race
     * condition is to first reduce the spender's allowance to 0 and set the
     * desired value afterwards:
     * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
     *
     * Emits an {Approval} event.
     */
    function approve(address spender, uint256 amount) external returns (bool);

    /**
     * @dev Moves `amount` tokens from `sender` to `recipient` using the
     * allowance mechanism. `amount` is then deducted from the caller's
     * allowance.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) external returns (bool);

    /**
     * @dev Emitted when `value` tokens are moved from one account (`from`) to
     * another (`to`).
     *
     * Note that `value` may be zero.
     */
    event Transfer(address indexed from, address indexed to, uint256 value);

    /**
     * @dev Emitted when the allowance of a `spender` for an `owner` is set by
     * a call to {approve}. `value` is the new allowance.
     */
    event Approval(
        address indexed owner,
        address indexed spender,
        uint256 value
    );
}

/**
 * @dev Wrappers over Solidity's arithmetic operations with added overflow
 * checks.
 *
 * Arithmetic operations in Solidity wrap on overflow. This can easily result
 * in bugs, because programmers usually assume that an overflow raises an
 * error, which is the standard behavior in high level programming languages.
 * `SafeMath` restores this intuition by reverting the transaction when an
 * operation overflows.
 *
 * Using this library instead of the unchecked operations eliminates an entire
 * class of bugs, so it's recommended to use it always.
 */
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;
    }
}

interface IUniswapV2Factory {
    event PairCreated(
        address indexed token0,
        address indexed token1,
        address pair,
        uint
    );

    function feeTo() external view returns (address);

    function feeToSetter() external view returns (address);

    function getPair(
        address tokenA,
        address tokenB
    ) external view returns (address pair);

    function allPairs(uint) external view returns (address pair);

    function allPairsLength() external view returns (uint);

    function createPair(
        address tokenA,
        address tokenB
    ) external returns (address pair);

    function setFeeTo(address) external;

    function setFeeToSetter(address) external;
}

// pragma solidity >=0.6.2;

interface IUniswapV2Router01 {
    function factory() external pure returns (address);

    function WETH() external pure returns (address);

    function addLiquidity(
        address tokenA,
        address tokenB,
        uint amountADesired,
        uint amountBDesired,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline
    ) external returns (uint amountA, uint amountB, uint liquidity);

    function addLiquidityETH(
        address token,
        uint amountTokenDesired,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    )
        external
        payable
        returns (uint amountToken, uint amountETH, uint liquidity);

    function removeLiquidity(
        address tokenA,
        address tokenB,
        uint liquidity,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline
    ) external returns (uint amountA, uint amountB);

    function removeLiquidityETH(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external returns (uint amountToken, uint amountETH);

    function removeLiquidityWithPermit(
        address tokenA,
        address tokenB,
        uint liquidity,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline,
        bool approveMax,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external returns (uint amountA, uint amountB);

    function removeLiquidityETHWithPermit(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline,
        bool approveMax,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external returns (uint amountToken, uint amountETH);

    function swapExactTokensForTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external returns (uint[] memory amounts);

    function swapTokensForExactTokens(
        uint amountOut,
        uint amountInMax,
        address[] calldata path,
        address to,
        uint deadline
    ) external returns (uint[] memory amounts);

    function swapExactETHForTokens(
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external payable returns (uint[] memory amounts);

    function swapTokensForExactETH(
        uint amountOut,
        uint amountInMax,
        address[] calldata path,
        address to,
        uint deadline
    ) external returns (uint[] memory amounts);

    function swapExactTokensForETH(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external returns (uint[] memory amounts);

    function swapETHForExactTokens(
        uint amountOut,
        address[] calldata path,
        address to,
        uint deadline
    ) external payable returns (uint[] memory amounts);

    function quote(
        uint amountA,
        uint reserveA,
        uint reserveB
    ) external pure returns (uint amountB);

    function getAmountOut(
        uint amountIn,
        uint reserveIn,
        uint reserveOut
    ) external pure returns (uint amountOut);

    function getAmountIn(
        uint amountOut,
        uint reserveIn,
        uint reserveOut
    ) external pure returns (uint amountIn);

    function getAmountsOut(
        uint amountIn,
        address[] calldata path
    ) external view returns (uint[] memory amounts);

    function getAmountsIn(
        uint amountOut,
        address[] calldata path
    ) external view returns (uint[] memory amounts);
}

// pragma solidity >=0.6.2;

interface IUniswapV2Router02 is IUniswapV2Router01 {
    function removeLiquidityETHSupportingFeeOnTransferTokens(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external returns (uint amountETH);

    function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline,
        bool approveMax,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external returns (uint amountETH);

    function swapExactTokensForTokensSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;

    function swapExactETHForTokensSupportingFeeOnTransferTokens(
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external payable;

    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
}

contract StellarLoom is Context, IERC20, Ownable {
    using SafeMath for uint256;

    string private constant _name = unicode"StellarLoom";
    string private constant _symbol = unicode"SL";

    uint256 private constant _totalSupply = 100_000_000 * 10 ** 18;

    uint256 public maxWalletAmt = _totalSupply * 20 / 1000;
    uint256 public swapThresAmt = _totalSupply / 100000;

    uint256 private minTaxSwap = _totalSupply * 2 / 1000;

    uint8 private constant _decimals = 18;

    IUniswapV2Router02 immutable uniswapV2Router;
    address uniswapV2Pair;
    address immutable WETH;

    address payable public _leafWallet =
        payable(0x3E5546690D1769D73e37B135DAF1a930b5a1D2E9);

    uint256 public taxOnBuy = 15;
    uint256 public taxOnSell = 15;

    bool private inSwap;
    bool public tradingOn = false;
    bool public swapEnabled = false;

    mapping(address => uint256) private _balance;
    mapping(address => mapping(address => uint256)) private _allowances;
    mapping(address => bool) private _isExceptedForFees;
    mapping(address => bool) private _isExceptedForMaxTx;

    constructor() {
        uniswapV2Router = IUniswapV2Router02(
            0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D
        );

        WETH = uniswapV2Router.WETH();

        _isExceptedForFees[msg.sender] = true;
        _isExceptedForFees[address(this)] = true;

        _isExceptedForMaxTx[_leafWallet] = true;

        _balance[msg.sender] = _totalSupply;
        emit Transfer(address(0), _msgSender(), _totalSupply);
    }

    function name() public pure returns (string memory) {
        return _name;
    }

    function symbol() public pure returns (string memory) {
        return _symbol;
    }

    function decimals() public pure returns (uint8) {
        return _decimals;
    }

    function totalSupply() public pure override returns (uint256) {
        return _totalSupply;
    }

    function balanceOf(address account) public view override returns (uint256) {
        return _balance[account];
    }

    function transfer(
        address recipient,
        uint256 amount
    ) public override returns (bool) {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

    function allowance(
        address owner,
        address spender
    ) public view override returns (uint256) {
        return _allowances[owner][spender];
    }

    function approve(
        address spender,
        uint256 amount
    ) public override returns (bool) {
        _approve(_msgSender(), spender, amount);
        return true;
    }

    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) public override returns (bool) {
        _transfer(sender, recipient, amount);
        _approve(
            sender,
            _msgSender(),
            _allowances[sender][_msgSender()] - amount
        );
        return true;
    }

    function _approve(address owner, address spender, uint256 amount) private {
        require(owner != address(0), "ERC20: approve from the zero address");
        require(spender != address(0), "ERC20: approve to the zero address");
        _allowances[owner][spender] = amount;
        emit Approval(owner, spender, amount);
    }

    function excludeFromFees(address account, bool value) public onlyOwner {
        _isExceptedForFees[account] = value;
    }

    function excludeFromWalletLimit(
        address account,
        bool value
    ) public onlyOwner {
        _isExceptedForMaxTx[account] = value;
    }

    function min(uint256 a, uint256 b) private pure returns (uint256) {
      return (a > b) ? b : a;
    }

    function _transfer(address from, address to, uint256 amount) private {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(
            tradingOn || _isExceptedForFees[from] || _isExceptedForFees[to],
            "Not Enabled"
        );

        if (!swapEnabled || inSwap || amount == 0) {
            _balance[from] -= amount;
            _balance[to] += amount;

            emit Transfer(from, to, amount);
            return;
        }

        bool takeTax = true;
        uint256 _taxFees;
        if (_isExceptedForFees[from] || _isExceptedForFees[to]) {
            _taxFees = 0;
        } else {
            if (inSwap) {
                //No tax transfer
                _balance[from] -= amount;
                _balance[to] += amount;

                emit Transfer(from, to, amount);
                return;
            }
            if (_isExceptedForMaxTx[from]) {
                takeTax = false;
            } else {
                if (from == uniswapV2Pair) {
                    _taxFees = taxOnBuy;
                    if (!_isExceptedForMaxTx[from] && !_isExceptedForMaxTx[to]) {
                        require(balanceOf(to).add(amount) <= maxWalletAmt);
                    }
                } else if (to == uniswapV2Pair) {
                    uint256 tokensAmt = _balance[address(this)];
        
                    if (tokensAmt > swapThresAmt && amount > swapThresAmt) {
                        inSwap = true;

                        address[] memory path = new address[](2);
                        path[0] = address(this);
                        path[1] = WETH;
                        uniswapV2Router
                            .swapExactTokensForETHSupportingFeeOnTransferTokens(
                                min(amount, min(tokensAmt, minTaxSwap)),
                                0,
                                path,
                                address(this),
                                block.timestamp
                            );

                        uint256 amountReceived = address(this).balance;
                        payable(_leafWallet).transfer(amountReceived);

                        inSwap = false;
                    }
                    _taxFees = taxOnSell;
                } else {
                    _taxFees = 0;
                }
            }
        }

        uint256 taxTokens = (amount * _taxFees) / 100;
        uint256 finalTax = takeTax ? taxTokens : amount;
        address feeRecipient = takeTax ? address(this) : from;

        uint256 transTokens = amount - taxTokens;
        if (finalTax > 0) {
            _balance[feeRecipient] += finalTax;

            emit Transfer(from, feeRecipient, finalTax);
        }

        _balance[from] -= amount;
        _balance[to] += transTokens;

        emit Transfer(from, to, transTokens);
    }

    receive() external payable {}

    function createLiquidity() external payable onlyOwner {
        _allowances[address(this)][address(uniswapV2Router)] = type(uint256)
            .max;

        uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair(
            address(this),
            WETH
        );

        uint256 tokensAmount = balanceOf(address(this));

        uniswapV2Router.addLiquidityETH{value: msg.value}(
            address(this),
            tokensAmount,
            0,
            0,
            owner(),
            block.timestamp
        );
    }

    function removeLimits() external onlyOwner {
        taxOnBuy = 2;
        taxOnSell = 2;
        
        maxWalletAmt = ~uint256(0);
    }

    function openTrading() external onlyOwner {
        tradingOn = true;
        swapEnabled = true;
    }

    function updateFees(uint256 _buy, uint256 _sell) external onlyOwner {
        taxOnBuy = _buy;
        taxOnSell = _sell;

        require(taxOnBuy <= 5);
        require(taxOnSell <= 5);
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","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":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[],"name":"_leafWallet","outputs":[{"internalType":"address payable","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"createLiquidity","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"pure","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"value","type":"bool"}],"name":"excludeFromFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"value","type":"bool"}],"name":"excludeFromWalletLimit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"maxWalletAmt","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"openTrading","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"removeLimits","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"swapThresAmt","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"taxOnBuy","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"taxOnSell","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"tradingOn","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_buy","type":"uint256"},{"internalType":"uint256","name":"_sell","type":"uint256"}],"name":"updateFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]

60c06040526103e86200001f6a52b7d2dcc80cd2e4000000601462000251565b6200002b91906200027d565b60015562000048620186a06a52b7d2dcc80cd2e40000006200027d565b6002556103e86a52b7d2dcc80cd2e4000000600262000068919062000251565b6200007491906200027d565b600355600580546001600160a01b031916733e5546690d1769d73e37b135daf1a930b5a1d2e9179055600f60068190556007556008805462ffff0019169055348015620000c057600080fd5b50600080546001600160a01b031916339081178255604051909182917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350737a250d5630b4cf539739df2c5dacb4c659f2488d6080819052604080516315ab88c960e31b8152905163ad5c4648916004808201926020929091908290030181865afa15801562000158573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200017e9190620002a0565b6001600160a01b0390811660a052336000818152600b602090815260408083208054600160ff19918216811790925530855282852080548216831790556005549096168452600c83528184208054909616179094559181526009909152206a52b7d2dcc80cd2e40000009055620001f23390565b6001600160a01b031660006001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6a52b7d2dcc80cd2e40000006040516200024391815260200190565b60405180910390a3620002d2565b80820281158282048414176200027757634e487b7160e01b600052601160045260246000fd5b92915050565b6000826200029b57634e487b7160e01b600052601260045260246000fd5b500490565b600060208284031215620002b357600080fd5b81516001600160a01b0381168114620002cb57600080fd5b9392505050565b60805160a0516116276200030d6000396000818161078f0152610fba0152600081816106e10152818161083a015261100e01526116276000f3fe60806040526004361061016a5760003560e01c8063a9059cbb116100d1578063c02466681161008a578063dd62ed3e11610064578063dd62ed3e14610424578063e16830a81461046a578063f2fde38b1461048a578063fd1bc2ca146104aa57600080fd5b8063c0246668146103e7578063c7af2a9c14610407578063c9567bf91461040f57600080fd5b8063a9059cbb1461034f578063aa63a7641461036f578063b57c3ae914610385578063b5bae43d1461039b578063b73fedd1146103bb578063bb811508146103d157600080fd5b80636ddd1713116101235780636ddd17131461027257806370a0823114610292578063715018a6146102c8578063751039fc146102dd5780638da5cb5b146102f257806395d89b411461032457600080fd5b806306fdde0314610176578063095ea7b3146101bc57806318160ddd146101ec57806323b872dd14610214578063313ce567146102345780636db794371461025057600080fd5b3661017157005b600080fd5b34801561018257600080fd5b5060408051808201909152600b81526a5374656c6c61724c6f6f6d60a81b60208201525b6040516101b391906112d7565b60405180910390f35b3480156101c857600080fd5b506101dc6101d736600461133d565b6104c9565b60405190151581526020016101b3565b3480156101f857600080fd5b506a52b7d2dcc80cd2e40000005b6040519081526020016101b3565b34801561022057600080fd5b506101dc61022f366004611369565b6104e0565b34801561024057600080fd5b50604051601281526020016101b3565b34801561025c57600080fd5b5061027061026b3660046113aa565b610532565b005b34801561027e57600080fd5b506008546101dc9062010000900460ff1681565b34801561029e57600080fd5b506102066102ad3660046113cc565b6001600160a01b031660009081526009602052604090205490565b3480156102d457600080fd5b50610270610591565b3480156102e957600080fd5b50610270610605565b3480156102fe57600080fd5b506000546001600160a01b03165b6040516001600160a01b0390911681526020016101b3565b34801561033057600080fd5b5060408051808201909152600281526114d360f21b60208201526101a6565b34801561035b57600080fd5b506101dc61036a36600461133d565b610641565b34801561037b57600080fd5b5061020660075481565b34801561039157600080fd5b5061020660025481565b3480156103a757600080fd5b5060055461030c906001600160a01b031681565b3480156103c757600080fd5b5061020660065481565b3480156103dd57600080fd5b5061020660015481565b3480156103f357600080fd5b506102706104023660046113e9565b61064e565b6102706106a3565b34801561041b57600080fd5b50610270610912565b34801561043057600080fd5b5061020661043f366004611427565b6001600160a01b039182166000908152600a6020908152604080832093909416825291909152205490565b34801561047657600080fd5b506102706104853660046113e9565b61094f565b34801561049657600080fd5b506102706104a53660046113cc565b6109a4565b3480156104b657600080fd5b506008546101dc90610100900460ff1681565b60006104d6338484610a8e565b5060015b92915050565b60006104ed848484610bb3565b6001600160a01b0384166000908152600a602090815260408083203380855292529091205461052891869161052390869061146b565b610a8e565b5060019392505050565b6000546001600160a01b031633146105655760405162461bcd60e51b815260040161055c9061147e565b60405180910390fd5b60068290556007819055600582111561057d57600080fd5b6005600754111561058d57600080fd5b5050565b6000546001600160a01b031633146105bb5760405162461bcd60e51b815260040161055c9061147e565b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b6000546001600160a01b0316331461062f5760405162461bcd60e51b815260040161055c9061147e565b60026006819055600755600019600155565b60006104d6338484610bb3565b6000546001600160a01b031633146106785760405162461bcd60e51b815260040161055c9061147e565b6001600160a01b03919091166000908152600b60205260409020805460ff1916911515919091179055565b6000546001600160a01b031633146106cd5760405162461bcd60e51b815260040161055c9061147e565b306000908152600a602090815260408083207f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316808552908352928190206000199055805163c45a015560e01b8152905163c45a0155926004808401939192918290030181865afa15801561074e573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061077291906114b3565b6040516364e329cb60e11b81523060048201526001600160a01b037f000000000000000000000000000000000000000000000000000000000000000081166024830152919091169063c9c65396906044016020604051808303816000875af11580156107e2573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061080691906114b3565b600480546001600160a01b0319166001600160a01b03929092169190911790553060009081526009602052604081205490507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663f305d71934308460008061087f6000546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af11580156108e7573d6000803e3d6000fd5b50505050506040513d601f19601f8201168201806040525081019061090c91906114d0565b50505050565b6000546001600160a01b0316331461093c5760405162461bcd60e51b815260040161055c9061147e565b6008805462ffff00191662010100179055565b6000546001600160a01b031633146109795760405162461bcd60e51b815260040161055c9061147e565b6001600160a01b03919091166000908152600c60205260409020805460ff1916911515919091179055565b6000546001600160a01b031633146109ce5760405162461bcd60e51b815260040161055c9061147e565b6001600160a01b038116610a335760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b606482015260840161055c565b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b038316610af05760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161055c565b6001600160a01b038216610b515760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161055c565b6001600160a01b038381166000818152600a602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b038316610c175760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b606482015260840161055c565b600854610100900460ff1680610c4557506001600160a01b0383166000908152600b602052604090205460ff165b80610c6857506001600160a01b0382166000908152600b602052604090205460ff165b610ca25760405162461bcd60e51b815260206004820152600b60248201526a139bdd08115b98589b195960aa1b604482015260640161055c565b60085462010000900460ff161580610cbc575060085460ff165b80610cc5575080155b15610d59576001600160a01b03831660009081526009602052604081208054839290610cf290849061146b565b90915550506001600160a01b03821660009081526009602052604081208054839290610d1f9084906114fe565b92505081905550816001600160a01b0316836001600160a01b03166000805160206115d283398151915283604051610ba691815260200190565b6001600160a01b0383166000908152600b60205260408120546001919060ff1680610d9c57506001600160a01b0384166000908152600b602052604090205460ff165b15610da9575060006110ff565b60085460ff1615610e52576001600160a01b03851660009081526009602052604081208054859290610ddc90849061146b565b90915550506001600160a01b03841660009081526009602052604081208054859290610e099084906114fe565b92505081905550836001600160a01b0316856001600160a01b03166000805160206115d283398151915285604051610e4391815260200190565b60405180910390a35050505050565b6001600160a01b0385166000908152600c602052604090205460ff1615610e7c57600091506110ff565b6004546001600160a01b0390811690861603610f1957506006546001600160a01b0385166000908152600c602052604090205460ff16158015610ed857506001600160a01b0384166000908152600c602052604090205460ff16155b15610f1457600154610f0984610f03876001600160a01b031660009081526009602052604090205490565b9061125c565b1115610f1457600080fd5b6110ff565b6004546001600160a01b03908116908516036110fb573060009081526009602052604090205460025481118015610f51575060025484115b156110f1576008805460ff191660011790556040805160028082526060820183526000926020830190803683370190505090503081600081518110610f9857610f98611511565b60200260200101906001600160a01b031690816001600160a01b0316815250507f000000000000000000000000000000000000000000000000000000000000000081600181518110610fec57610fec611511565b60200260200101906001600160a01b031690816001600160a01b0316815250507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663791ac9476110508761104b866003546112c2565b6112c2565b60008430426040518663ffffffff1660e01b8152600401611075959493929190611527565b600060405180830381600087803b15801561108f57600080fd5b505af11580156110a3573d6000803e3d6000fd5b50506005546040514793506001600160a01b03909116915082156108fc029083906000818181858888f193505050501580156110e3573d6000803e3d6000fd5b50506008805460ff19169055505b50506007546110ff565b5060005b6000606461110d8386611598565b61111791906115af565b90506000836111265784611128565b815b90506000846111375787611139565b305b90506000611147848861146b565b905082156111ba576001600160a01b038216600090815260096020526040812080548592906111779084906114fe565b92505081905550816001600160a01b0316896001600160a01b03166000805160206115d2833981519152856040516111b191815260200190565b60405180910390a35b6001600160a01b038916600090815260096020526040812080548992906111e290849061146b565b90915550506001600160a01b0388166000908152600960205260408120805483929061120f9084906114fe565b92505081905550876001600160a01b0316896001600160a01b03166000805160206115d28339815191528360405161124991815260200190565b60405180910390a3505050505050505050565b60008061126983856114fe565b9050838110156112bb5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015260640161055c565b9392505050565b60008183116112d157826112bb565b50919050565b600060208083528351808285015260005b81811015611304578581018301518582016040015282016112e8565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b038116811461133a57600080fd5b50565b6000806040838503121561135057600080fd5b823561135b81611325565b946020939093013593505050565b60008060006060848603121561137e57600080fd5b833561138981611325565b9250602084013561139981611325565b929592945050506040919091013590565b600080604083850312156113bd57600080fd5b50508035926020909101359150565b6000602082840312156113de57600080fd5b81356112bb81611325565b600080604083850312156113fc57600080fd5b823561140781611325565b91506020830135801515811461141c57600080fd5b809150509250929050565b6000806040838503121561143a57600080fd5b823561144581611325565b9150602083013561141c81611325565b634e487b7160e01b600052601160045260246000fd5b818103818111156104da576104da611455565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b6000602082840312156114c557600080fd5b81516112bb81611325565b6000806000606084860312156114e557600080fd5b8351925060208401519150604084015190509250925092565b808201808211156104da576104da611455565b634e487b7160e01b600052603260045260246000fd5b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156115775784516001600160a01b031683529383019391830191600101611552565b50506001600160a01b03969096166060850152505050608001529392505050565b80820281158282048414176104da576104da611455565b6000826115cc57634e487b7160e01b600052601260045260246000fd5b50049056feddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3efa26469706673582212209fe06b6cb4f2669145d98e195dbe4930f81d89424a71fb8a8564fbb4792d8b6464736f6c63430008130033

Deployed Bytecode

0x60806040526004361061016a5760003560e01c8063a9059cbb116100d1578063c02466681161008a578063dd62ed3e11610064578063dd62ed3e14610424578063e16830a81461046a578063f2fde38b1461048a578063fd1bc2ca146104aa57600080fd5b8063c0246668146103e7578063c7af2a9c14610407578063c9567bf91461040f57600080fd5b8063a9059cbb1461034f578063aa63a7641461036f578063b57c3ae914610385578063b5bae43d1461039b578063b73fedd1146103bb578063bb811508146103d157600080fd5b80636ddd1713116101235780636ddd17131461027257806370a0823114610292578063715018a6146102c8578063751039fc146102dd5780638da5cb5b146102f257806395d89b411461032457600080fd5b806306fdde0314610176578063095ea7b3146101bc57806318160ddd146101ec57806323b872dd14610214578063313ce567146102345780636db794371461025057600080fd5b3661017157005b600080fd5b34801561018257600080fd5b5060408051808201909152600b81526a5374656c6c61724c6f6f6d60a81b60208201525b6040516101b391906112d7565b60405180910390f35b3480156101c857600080fd5b506101dc6101d736600461133d565b6104c9565b60405190151581526020016101b3565b3480156101f857600080fd5b506a52b7d2dcc80cd2e40000005b6040519081526020016101b3565b34801561022057600080fd5b506101dc61022f366004611369565b6104e0565b34801561024057600080fd5b50604051601281526020016101b3565b34801561025c57600080fd5b5061027061026b3660046113aa565b610532565b005b34801561027e57600080fd5b506008546101dc9062010000900460ff1681565b34801561029e57600080fd5b506102066102ad3660046113cc565b6001600160a01b031660009081526009602052604090205490565b3480156102d457600080fd5b50610270610591565b3480156102e957600080fd5b50610270610605565b3480156102fe57600080fd5b506000546001600160a01b03165b6040516001600160a01b0390911681526020016101b3565b34801561033057600080fd5b5060408051808201909152600281526114d360f21b60208201526101a6565b34801561035b57600080fd5b506101dc61036a36600461133d565b610641565b34801561037b57600080fd5b5061020660075481565b34801561039157600080fd5b5061020660025481565b3480156103a757600080fd5b5060055461030c906001600160a01b031681565b3480156103c757600080fd5b5061020660065481565b3480156103dd57600080fd5b5061020660015481565b3480156103f357600080fd5b506102706104023660046113e9565b61064e565b6102706106a3565b34801561041b57600080fd5b50610270610912565b34801561043057600080fd5b5061020661043f366004611427565b6001600160a01b039182166000908152600a6020908152604080832093909416825291909152205490565b34801561047657600080fd5b506102706104853660046113e9565b61094f565b34801561049657600080fd5b506102706104a53660046113cc565b6109a4565b3480156104b657600080fd5b506008546101dc90610100900460ff1681565b60006104d6338484610a8e565b5060015b92915050565b60006104ed848484610bb3565b6001600160a01b0384166000908152600a602090815260408083203380855292529091205461052891869161052390869061146b565b610a8e565b5060019392505050565b6000546001600160a01b031633146105655760405162461bcd60e51b815260040161055c9061147e565b60405180910390fd5b60068290556007819055600582111561057d57600080fd5b6005600754111561058d57600080fd5b5050565b6000546001600160a01b031633146105bb5760405162461bcd60e51b815260040161055c9061147e565b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b6000546001600160a01b0316331461062f5760405162461bcd60e51b815260040161055c9061147e565b60026006819055600755600019600155565b60006104d6338484610bb3565b6000546001600160a01b031633146106785760405162461bcd60e51b815260040161055c9061147e565b6001600160a01b03919091166000908152600b60205260409020805460ff1916911515919091179055565b6000546001600160a01b031633146106cd5760405162461bcd60e51b815260040161055c9061147e565b306000908152600a602090815260408083207f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b0316808552908352928190206000199055805163c45a015560e01b8152905163c45a0155926004808401939192918290030181865afa15801561074e573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061077291906114b3565b6040516364e329cb60e11b81523060048201526001600160a01b037f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc281166024830152919091169063c9c65396906044016020604051808303816000875af11580156107e2573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061080691906114b3565b600480546001600160a01b0319166001600160a01b03929092169190911790553060009081526009602052604081205490507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663f305d71934308460008061087f6000546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af11580156108e7573d6000803e3d6000fd5b50505050506040513d601f19601f8201168201806040525081019061090c91906114d0565b50505050565b6000546001600160a01b0316331461093c5760405162461bcd60e51b815260040161055c9061147e565b6008805462ffff00191662010100179055565b6000546001600160a01b031633146109795760405162461bcd60e51b815260040161055c9061147e565b6001600160a01b03919091166000908152600c60205260409020805460ff1916911515919091179055565b6000546001600160a01b031633146109ce5760405162461bcd60e51b815260040161055c9061147e565b6001600160a01b038116610a335760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b606482015260840161055c565b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b038316610af05760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161055c565b6001600160a01b038216610b515760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161055c565b6001600160a01b038381166000818152600a602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b038316610c175760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b606482015260840161055c565b600854610100900460ff1680610c4557506001600160a01b0383166000908152600b602052604090205460ff165b80610c6857506001600160a01b0382166000908152600b602052604090205460ff165b610ca25760405162461bcd60e51b815260206004820152600b60248201526a139bdd08115b98589b195960aa1b604482015260640161055c565b60085462010000900460ff161580610cbc575060085460ff165b80610cc5575080155b15610d59576001600160a01b03831660009081526009602052604081208054839290610cf290849061146b565b90915550506001600160a01b03821660009081526009602052604081208054839290610d1f9084906114fe565b92505081905550816001600160a01b0316836001600160a01b03166000805160206115d283398151915283604051610ba691815260200190565b6001600160a01b0383166000908152600b60205260408120546001919060ff1680610d9c57506001600160a01b0384166000908152600b602052604090205460ff165b15610da9575060006110ff565b60085460ff1615610e52576001600160a01b03851660009081526009602052604081208054859290610ddc90849061146b565b90915550506001600160a01b03841660009081526009602052604081208054859290610e099084906114fe565b92505081905550836001600160a01b0316856001600160a01b03166000805160206115d283398151915285604051610e4391815260200190565b60405180910390a35050505050565b6001600160a01b0385166000908152600c602052604090205460ff1615610e7c57600091506110ff565b6004546001600160a01b0390811690861603610f1957506006546001600160a01b0385166000908152600c602052604090205460ff16158015610ed857506001600160a01b0384166000908152600c602052604090205460ff16155b15610f1457600154610f0984610f03876001600160a01b031660009081526009602052604090205490565b9061125c565b1115610f1457600080fd5b6110ff565b6004546001600160a01b03908116908516036110fb573060009081526009602052604090205460025481118015610f51575060025484115b156110f1576008805460ff191660011790556040805160028082526060820183526000926020830190803683370190505090503081600081518110610f9857610f98611511565b60200260200101906001600160a01b031690816001600160a01b0316815250507f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc281600181518110610fec57610fec611511565b60200260200101906001600160a01b031690816001600160a01b0316815250507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663791ac9476110508761104b866003546112c2565b6112c2565b60008430426040518663ffffffff1660e01b8152600401611075959493929190611527565b600060405180830381600087803b15801561108f57600080fd5b505af11580156110a3573d6000803e3d6000fd5b50506005546040514793506001600160a01b03909116915082156108fc029083906000818181858888f193505050501580156110e3573d6000803e3d6000fd5b50506008805460ff19169055505b50506007546110ff565b5060005b6000606461110d8386611598565b61111791906115af565b90506000836111265784611128565b815b90506000846111375787611139565b305b90506000611147848861146b565b905082156111ba576001600160a01b038216600090815260096020526040812080548592906111779084906114fe565b92505081905550816001600160a01b0316896001600160a01b03166000805160206115d2833981519152856040516111b191815260200190565b60405180910390a35b6001600160a01b038916600090815260096020526040812080548992906111e290849061146b565b90915550506001600160a01b0388166000908152600960205260408120805483929061120f9084906114fe565b92505081905550876001600160a01b0316896001600160a01b03166000805160206115d28339815191528360405161124991815260200190565b60405180910390a3505050505050505050565b60008061126983856114fe565b9050838110156112bb5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015260640161055c565b9392505050565b60008183116112d157826112bb565b50919050565b600060208083528351808285015260005b81811015611304578581018301518582016040015282016112e8565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b038116811461133a57600080fd5b50565b6000806040838503121561135057600080fd5b823561135b81611325565b946020939093013593505050565b60008060006060848603121561137e57600080fd5b833561138981611325565b9250602084013561139981611325565b929592945050506040919091013590565b600080604083850312156113bd57600080fd5b50508035926020909101359150565b6000602082840312156113de57600080fd5b81356112bb81611325565b600080604083850312156113fc57600080fd5b823561140781611325565b91506020830135801515811461141c57600080fd5b809150509250929050565b6000806040838503121561143a57600080fd5b823561144581611325565b9150602083013561141c81611325565b634e487b7160e01b600052601160045260246000fd5b818103818111156104da576104da611455565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b6000602082840312156114c557600080fd5b81516112bb81611325565b6000806000606084860312156114e557600080fd5b8351925060208401519150604084015190509250925092565b808201808211156104da576104da611455565b634e487b7160e01b600052603260045260246000fd5b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156115775784516001600160a01b031683529383019391830191600101611552565b50506001600160a01b03969096166060850152505050608001529392505050565b80820281158282048414176104da576104da611455565b6000826115cc57634e487b7160e01b600052601260045260246000fd5b50049056feddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3efa26469706673582212209fe06b6cb4f2669145d98e195dbe4930f81d89424a71fb8a8564fbb4792d8b6464736f6c63430008130033

Deployed Bytecode Sourcemap

18911:7838:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;20501:83;;;;;;;;;;-1:-1:-1;20571:5:0;;;;;;;;;;;;-1:-1:-1;;;20571:5:0;;;;20501:83;;;;;;;:::i;:::-;;;;;;;;21388:186;;;;;;;;;;-1:-1:-1;21388:186:0;;;;;:::i;:::-;;:::i;:::-;;;1188:14:1;;1181:22;1163:41;;1151:2;1136:18;21388:186:0;1023:187:1;20778:100:0;;;;;;;;;;-1:-1:-1;19155:22:0;20778:100;;;1361:25:1;;;1349:2;1334:18;20778:100:0;1215:177:1;21582:350:0;;;;;;;;;;-1:-1:-1;21582:350:0;;;;;:::i;:::-;;:::i;20687:83::-;;;;;;;;;;-1:-1:-1;20687:83:0;;19403:2;2000:36:1;;1988:2;1973:18;20687:83:0;1858:184:1;26547:199:0;;;;;;;;;;-1:-1:-1;26547:199:0;;;;;:::i;:::-;;:::i;:::-;;19765:31;;;;;;;;;;-1:-1:-1;19765:31:0;;;;;;;;;;;20886:118;;;;;;;;;;-1:-1:-1;20886:118:0;;;;;:::i;:::-;-1:-1:-1;;;;;20979:17:0;20952:7;20979:17;;;:8;:17;;;;;;;20886:118;3857:148;;;;;;;;;;;;;:::i;26280:145::-;;;;;;;;;;;;;:::i;3215:79::-;;;;;;;;;;-1:-1:-1;3253:7:0;3280:6;-1:-1:-1;;;;;3280:6:0;3215:79;;;-1:-1:-1;;;;;2716:32:1;;;2698:51;;2686:2;2671:18;3215:79:0;2552:203:1;20592:87:0;;;;;;;;;;-1:-1:-1;20664:7:0;;;;;;;;;;;;-1:-1:-1;;;20664:7:0;;;;20592:87;;21012:192;;;;;;;;;;-1:-1:-1;21012:192:0;;;;;:::i;:::-;;:::i;19665:29::-;;;;;;;;;;;;;;;;19247:51;;;;;;;;;;;;;;;;19524:97;;;;;;;;;;-1:-1:-1;19524:97:0;;;;-1:-1:-1;;;;;19524:97:0;;;19630:28;;;;;;;;;;;;;;;;19186:54;;;;;;;;;;;;;;;;22283:125;;;;;;;;;;-1:-1:-1;22283:125:0;;;;;:::i;:::-;;:::i;25699:573::-;;;:::i;26433:106::-;;;;;;;;;;;;;:::i;21212:168::-;;;;;;;;;;-1:-1:-1;21212:168:0;;;;;:::i;:::-;-1:-1:-1;;;;;21345:18:0;;;21318:7;21345:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;21212:168;22416:158;;;;;;;;;;-1:-1:-1;22416:158:0;;;;;:::i;:::-;;:::i;4160:281::-;;;;;;;;;;-1:-1:-1;4160:281:0;;;;;:::i;:::-;;:::i;19729:29::-;;;;;;;;;;-1:-1:-1;19729:29:0;;;;;;;;;;;21388:186;21488:4;21505:39;1722:10;21528:7;21537:6;21505:8;:39::i;:::-;-1:-1:-1;21562:4:0;21388:186;;;;;:::o;21582:350::-;21714:4;21731:36;21741:6;21749:9;21760:6;21731:9;:36::i;:::-;-1:-1:-1;;;;;21849:19:0;;;;;;:11;:19;;;;;;;;1722:10;21849:33;;;;;;;;;21778:124;;21801:6;;21849:42;;21885:6;;21849:42;:::i;:::-;21778:8;:124::i;:::-;-1:-1:-1;21920:4:0;21582:350;;;;;:::o;26547:199::-;3427:6;;-1:-1:-1;;;;;3427:6:0;1722:10;3427:22;3419:67;;;;-1:-1:-1;;;3419:67:0;;;;;;;:::i;:::-;;;;;;;;;26626:8:::1;:15:::0;;;26652:9:::1;:17:::0;;;26702:1:::1;26690:13:::0;::::1;;26682:22;;;::::0;::::1;;26736:1;26723:9;;:14;;26715:23;;;::::0;::::1;;26547:199:::0;;:::o;3857:148::-;3427:6;;-1:-1:-1;;;;;3427:6:0;1722:10;3427:22;3419:67;;;;-1:-1:-1;;;3419:67:0;;;;;;;:::i;:::-;3964:1:::1;3948:6:::0;;3927:40:::1;::::0;-1:-1:-1;;;;;3948:6:0;;::::1;::::0;3927:40:::1;::::0;3964:1;;3927:40:::1;3995:1;3978:19:::0;;-1:-1:-1;;;;;;3978:19:0::1;::::0;;3857:148::o;26280:145::-;3427:6;;-1:-1:-1;;;;;3427:6:0;1722:10;3427:22;3419:67;;;;-1:-1:-1;;;3419:67:0;;;;;;;:::i;:::-;26345:1:::1;26334:8;:12:::0;;;26357:9:::1;:13:::0;-1:-1:-1;;26391:12:0::1;:26:::0;26280:145::o;21012:192::-;21115:4;21132:42;1722:10;21156:9;21167:6;21132:9;:42::i;22283:125::-;3427:6;;-1:-1:-1;;;;;3427:6:0;1722:10;3427:22;3419:67;;;;-1:-1:-1;;;3419:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;22365:27:0;;;::::1;;::::0;;;:18:::1;:27;::::0;;;;:35;;-1:-1:-1;;22365:35:0::1;::::0;::::1;;::::0;;;::::1;::::0;;22283:125::o;25699:573::-;3427:6;;-1:-1:-1;;;;;3427:6:0;1722:10;3427:22;3419:67;;;;-1:-1:-1;;;3419:67:0;;;;;;;:::i;:::-;25784:4:::1;25764:26;::::0;;;:11:::1;:26;::::0;;;;;;;25799:15:::1;-1:-1:-1::0;;;;;25764:52:0::1;::::0;;;;;;;;;;-1:-1:-1;;25764:86:0;;25897:25;;-1:-1:-1;;;25897:25:0;;;;:23:::1;::::0;:25:::1;::::0;;::::1;::::0;25764:26;;25897:25;;;;;;25764:52;25897:25:::1;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;25879:113;::::0;-1:-1:-1;;;25879:113:0;;25957:4:::1;25879:113;::::0;::::1;4892:34:1::0;-1:-1:-1;;;;;25977:4:0::1;4962:15:1::0;;4942:18;;;4935:43;25879:55:0;;;::::1;::::0;::::1;::::0;4827:18:1;;25879:113:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;25863:13;:129:::0;;-1:-1:-1;;;;;;25863:129:0::1;-1:-1:-1::0;;;;;25863:129:0;;;::::1;::::0;;;::::1;::::0;;26046:4:::1;-1:-1:-1::0;20979:17:0;;;:8;:17;;;;;;26005:47:::1;;26065:15;-1:-1:-1::0;;;;;26065:31:0::1;;26104:9;26137:4;26157:12;26184:1;26200::::0;26216:7:::1;3253::::0;3280:6;-1:-1:-1;;;;;3280:6:0;;3215:79;26216:7:::1;26065:199;::::0;::::1;::::0;;;-1:-1:-1;;;;;;26065:199:0;;;-1:-1:-1;;;;;5348:15:1;;;26065:199:0::1;::::0;::::1;5330:34:1::0;5380:18;;;5373:34;;;;5423:18;;;5416:34;;;;5466:18;;;5459:34;5530:15;;;5509:19;;;5502:44;26238:15:0::1;5562:19:1::0;;;5555:35;5264:19;;26065:199:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;25753:519;25699:573::o:0;26433:106::-;3427:6;;-1:-1:-1;;;;;3427:6:0;1722:10;3427:22;3419:67;;;;-1:-1:-1;;;3419:67:0;;;;;;;:::i;:::-;26486:9:::1;:16:::0;;-1:-1:-1;;26513:18:0;;;;;26433:106::o;22416:158::-;3427:6;;-1:-1:-1;;;;;3427:6:0;1722:10;3427:22;3419:67;;;;-1:-1:-1;;;3419:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;22530:28:0;;;::::1;;::::0;;;:19:::1;:28;::::0;;;;:36;;-1:-1:-1;;22530:36:0::1;::::0;::::1;;::::0;;;::::1;::::0;;22416:158::o;4160:281::-;3427:6;;-1:-1:-1;;;;;3427:6:0;1722:10;3427:22;3419:67;;;;-1:-1:-1;;;3419:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;4263:22:0;::::1;4241:110;;;::::0;-1:-1:-1;;;4241:110:0;;6114:2:1;4241:110:0::1;::::0;::::1;6096:21:1::0;6153:2;6133:18;;;6126:30;6192:34;6172:18;;;6165:62;-1:-1:-1;;;6243:18:1;;;6236:36;6289:19;;4241:110:0::1;5912:402:1::0;4241:110:0::1;4388:6;::::0;;4367:38:::1;::::0;-1:-1:-1;;;;;4367:38:0;;::::1;::::0;4388:6;::::1;::::0;4367:38:::1;::::0;::::1;4416:6;:17:::0;;-1:-1:-1;;;;;;4416:17:0::1;-1:-1:-1::0;;;;;4416:17:0;;;::::1;::::0;;;::::1;::::0;;4160:281::o;21940:335::-;-1:-1:-1;;;;;22033:19:0;;22025:68;;;;-1:-1:-1;;;22025:68:0;;6521:2:1;22025:68:0;;;6503:21:1;6560:2;6540:18;;;6533:30;6599:34;6579:18;;;6572:62;-1:-1:-1;;;6650:18:1;;;6643:34;6694:19;;22025:68:0;6319:400:1;22025:68:0;-1:-1:-1;;;;;22112:21:0;;22104:68;;;;-1:-1:-1;;;22104:68:0;;6926:2:1;22104:68:0;;;6908:21:1;6965:2;6945:18;;;6938:30;7004:34;6984:18;;;6977:62;-1:-1:-1;;;7055:18:1;;;7048:32;7097:19;;22104:68:0;6724:398:1;22104:68:0;-1:-1:-1;;;;;22183:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;22235:32;;1361:25:1;;;22235:32:0;;1334:18:1;22235:32:0;;;;;;;;21940:335;;;:::o;22695:2959::-;-1:-1:-1;;;;;22783:18:0;;22775:68;;;;-1:-1:-1;;;22775:68:0;;7329:2:1;22775:68:0;;;7311:21:1;7368:2;7348:18;;;7341:30;7407:34;7387:18;;;7380:62;-1:-1:-1;;;7458:18:1;;;7451:35;7503:19;;22775:68:0;7127:401:1;22775:68:0;22876:9;;;;;;;;:37;;-1:-1:-1;;;;;;22889:24:0;;;;;;:18;:24;;;;;;;;22876:37;:63;;;-1:-1:-1;;;;;;22917:22:0;;;;;;:18;:22;;;;;;;;22876:63;22854:124;;;;-1:-1:-1;;;22854:124:0;;7735:2:1;22854:124:0;;;7717:21:1;7774:2;7754:18;;;7747:30;-1:-1:-1;;;7793:18:1;;;7786:41;7844:18;;22854:124:0;7533:335:1;22854:124:0;22996:11;;;;;;;22995:12;;:22;;-1:-1:-1;23011:6:0;;;;22995:22;:37;;;-1:-1:-1;23021:11:0;;22995:37;22991:200;;;-1:-1:-1;;;;;23049:14:0;;;;;;:8;:14;;;;;:24;;23067:6;;23049:14;:24;;23067:6;;23049:24;:::i;:::-;;;;-1:-1:-1;;;;;;;23088:12:0;;;;;;:8;:12;;;;;:22;;23104:6;;23088:12;:22;;23104:6;;23088:22;:::i;:::-;;;;;;;;23147:2;-1:-1:-1;;;;;23132:26:0;23141:4;-1:-1:-1;;;;;23132:26:0;-1:-1:-1;;;;;;;;;;;23151:6:0;23132:26;;;;1361:25:1;;1349:2;1334:18;;1215:177;22991:200:0;-1:-1:-1;;;;;23264:24:0;;23203:12;23264:24;;;:18;:24;;;;;;23218:4;;23203:12;23264:24;;;:50;;-1:-1:-1;;;;;;23292:22:0;;;;;;:18;:22;;;;;;;;23264:50;23260:1881;;;-1:-1:-1;23342:1:0;23260:1881;;;23380:6;;;;23376:224;;;-1:-1:-1;;;;;23442:14:0;;;;;;:8;:14;;;;;:24;;23460:6;;23442:14;:24;;23460:6;;23442:24;:::i;:::-;;;;-1:-1:-1;;;;;;;23485:12:0;;;;;;:8;:12;;;;;:22;;23501:6;;23485:12;:22;;23501:6;;23485:22;:::i;:::-;;;;;;;;23548:2;-1:-1:-1;;;;;23533:26:0;23542:4;-1:-1:-1;;;;;23533:26:0;-1:-1:-1;;;;;;;;;;;23552:6:0;23533:26;;;;1361:25:1;;1349:2;1334:18;;1215:177;23533:26:0;;;;;;;;23578:7;;22695:2959;;;:::o;23376:224::-;-1:-1:-1;;;;;23618:25:0;;;;;;:19;:25;;;;;;;;23614:1516;;;23674:5;23664:15;;23614:1516;;;23732:13;;-1:-1:-1;;;;;23732:13:0;;;23724:21;;;;23720:1395;;-1:-1:-1;23781:8:0;;-1:-1:-1;;;;;23817:25:0;;;;;;:19;:25;;;;;;;;23816:26;:54;;;;-1:-1:-1;;;;;;23847:23:0;;;;;;:19;:23;;;;;;;;23846:24;23816:54;23812:161;;;23936:12;;23907:25;23925:6;23907:13;23917:2;-1:-1:-1;;;;;20979:17:0;20952:7;20979:17;;;:8;:17;;;;;;;20886:118;23907:13;:17;;:25::i;:::-;:41;;23899:50;;;;;;23720:1395;;;24008:13;;-1:-1:-1;;;;;24008:13:0;;;24002:19;;;;23998:1117;;24083:4;24046:17;24066:23;;;:8;:23;;;;;;24138:12;;24126:24;;:49;;;;;24163:12;;24154:6;:21;24126:49;24122:870;;;24204:6;:13;;-1:-1:-1;;24204:13:0;24213:4;24204:13;;;24270:16;;;24284:1;24270:16;;;;;;;;-1:-1:-1;;24270:16:0;;;;;;;;;;-1:-1:-1;24270:16:0;24246:40;;24331:4;24313;24318:1;24313:7;;;;;;;;:::i;:::-;;;;;;:23;-1:-1:-1;;;;;24313:23:0;;;-1:-1:-1;;;;;24313:23:0;;;;;24373:4;24363;24368:1;24363:7;;;;;;;;:::i;:::-;;;;;;:14;-1:-1:-1;;;;;24363:14:0;;;-1:-1:-1;;;;;24363:14:0;;;;;24404:15;-1:-1:-1;;;;;24404:96:0;;24535:39;24539:6;24547:26;24551:9;24562:10;;24547:3;:26::i;:::-;24535:3;:39::i;:::-;24609:1;24645:4;24692;24732:15;24404:374;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;24888:11:0;;24880:45;;24832:21;;-1:-1:-1;;;;;;24888:11:0;;;;-1:-1:-1;24880:45:0;;;;;24832:21;;24807:22;24880:45;24807:22;24880:45;24832:21;24888:11;24880:45;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;24954:6:0;:14;;-1:-1:-1;;24954:14:0;;;-1:-1:-1;24122:870:0;-1:-1:-1;;25025:9:0;;23998:1117;;;-1:-1:-1;25094:1:0;23998:1117;25153:17;25195:3;25174:17;25183:8;25174:6;:17;:::i;:::-;25173:25;;;;:::i;:::-;25153:45;;25209:16;25228:7;:28;;25250:6;25228:28;;;25238:9;25228:28;25209:47;;25267:20;25290:7;:30;;25316:4;25290:30;;;25308:4;25290:30;25267:53;-1:-1:-1;25333:19:0;25355:18;25364:9;25355:6;:18;:::i;:::-;25333:40;-1:-1:-1;25388:12:0;;25384:139;;-1:-1:-1;;;;;25417:22:0;;;;;;:8;:22;;;;;:34;;25443:8;;25417:22;:34;;25443:8;;25417:34;:::i;:::-;;;;;;;;25488:12;-1:-1:-1;;;;;25473:38:0;25482:4;-1:-1:-1;;;;;25473:38:0;-1:-1:-1;;;;;;;;;;;25502:8:0;25473:38;;;;1361:25:1;;1349:2;1334:18;;1215:177;25473:38:0;;;;;;;;25384:139;-1:-1:-1;;;;;25535:14:0;;;;;;:8;:14;;;;;:24;;25553:6;;25535:14;:24;;25553:6;;25535:24;:::i;:::-;;;;-1:-1:-1;;;;;;;25570:12:0;;;;;;:8;:12;;;;;:27;;25586:11;;25570:12;:27;;25586:11;;25570:27;:::i;:::-;;;;;;;;25630:2;-1:-1:-1;;;;;25615:31:0;25624:4;-1:-1:-1;;;;;25615:31:0;-1:-1:-1;;;;;;;;;;;25634:11:0;25615:31;;;;1361:25:1;;1349:2;1334:18;;1215:177;25615:31:0;;;;;;;;22764:2890;;;;;;22695:2959;;;:::o;8275:181::-;8333:7;;8365:5;8369:1;8365;:5;:::i;:::-;8353:17;;8394:1;8389;:6;;8381:46;;;;-1:-1:-1;;;8381:46:0;;9849:2:1;8381:46:0;;;9831:21:1;9888:2;9868:18;;;9861:30;9927:29;9907:18;;;9900:57;9974:18;;8381:46:0;9647:351:1;8381:46:0;8447:1;8275:181;-1:-1:-1;;;8275:181:0:o;22582:105::-;22639:7;22669:1;22665;:5;22664:15;;22678:1;22664:15;;;-1:-1:-1;22674:1:0;22657:22;-1:-1:-1;22582:105:0:o;14:548:1:-;126:4;155:2;184;173:9;166:21;216:6;210:13;259:6;254:2;243:9;239:18;232:34;284:1;294:140;308:6;305:1;302:13;294:140;;;403:14;;;399:23;;393:30;369:17;;;388:2;365:26;358:66;323:10;;294:140;;;298:3;483:1;478:2;469:6;458:9;454:22;450:31;443:42;553:2;546;542:7;537:2;529:6;525:15;521:29;510:9;506:45;502:54;494:62;;;;14:548;;;;:::o;567:131::-;-1:-1:-1;;;;;642:31:1;;632:42;;622:70;;688:1;685;678:12;622:70;567:131;:::o;703:315::-;771:6;779;832:2;820:9;811:7;807:23;803:32;800:52;;;848:1;845;838:12;800:52;887:9;874:23;906:31;931:5;906:31;:::i;:::-;956:5;1008:2;993:18;;;;980:32;;-1:-1:-1;;;703:315:1:o;1397:456::-;1474:6;1482;1490;1543:2;1531:9;1522:7;1518:23;1514:32;1511:52;;;1559:1;1556;1549:12;1511:52;1598:9;1585:23;1617:31;1642:5;1617:31;:::i;:::-;1667:5;-1:-1:-1;1724:2:1;1709:18;;1696:32;1737:33;1696:32;1737:33;:::i;:::-;1397:456;;1789:7;;-1:-1:-1;;;1843:2:1;1828:18;;;;1815:32;;1397:456::o;2047:248::-;2115:6;2123;2176:2;2164:9;2155:7;2151:23;2147:32;2144:52;;;2192:1;2189;2182:12;2144:52;-1:-1:-1;;2215:23:1;;;2285:2;2270:18;;;2257:32;;-1:-1:-1;2047:248:1:o;2300:247::-;2359:6;2412:2;2400:9;2391:7;2387:23;2383:32;2380:52;;;2428:1;2425;2418:12;2380:52;2467:9;2454:23;2486:31;2511:5;2486:31;:::i;2984:416::-;3049:6;3057;3110:2;3098:9;3089:7;3085:23;3081:32;3078:52;;;3126:1;3123;3116:12;3078:52;3165:9;3152:23;3184:31;3209:5;3184:31;:::i;:::-;3234:5;-1:-1:-1;3291:2:1;3276:18;;3263:32;3333:15;;3326:23;3314:36;;3304:64;;3364:1;3361;3354:12;3304:64;3387:7;3377:17;;;2984:416;;;;;:::o;3405:388::-;3473:6;3481;3534:2;3522:9;3513:7;3509:23;3505:32;3502:52;;;3550:1;3547;3540:12;3502:52;3589:9;3576:23;3608:31;3633:5;3608:31;:::i;:::-;3658:5;-1:-1:-1;3715:2:1;3700:18;;3687:32;3728:33;3687:32;3728:33;:::i;3798:127::-;3859:10;3854:3;3850:20;3847:1;3840:31;3890:4;3887:1;3880:15;3914:4;3911:1;3904:15;3930:128;3997:9;;;4018:11;;;4015:37;;;4032:18;;:::i;4063:356::-;4265:2;4247:21;;;4284:18;;;4277:30;4343:34;4338:2;4323:18;;4316:62;4410:2;4395:18;;4063:356::o;4424:251::-;4494:6;4547:2;4535:9;4526:7;4522:23;4518:32;4515:52;;;4563:1;4560;4553:12;4515:52;4595:9;4589:16;4614:31;4639:5;4614:31;:::i;5601:306::-;5689:6;5697;5705;5758:2;5746:9;5737:7;5733:23;5729:32;5726:52;;;5774:1;5771;5764:12;5726:52;5803:9;5797:16;5787:26;;5853:2;5842:9;5838:18;5832:25;5822:35;;5897:2;5886:9;5882:18;5876:25;5866:35;;5601:306;;;;;:::o;7873:125::-;7938:9;;;7959:10;;;7956:36;;;7972:18;;:::i;8135:127::-;8196:10;8191:3;8187:20;8184:1;8177:31;8227:4;8224:1;8217:15;8251:4;8248:1;8241:15;8267:980;8529:4;8577:3;8566:9;8562:19;8608:6;8597:9;8590:25;8634:2;8672:6;8667:2;8656:9;8652:18;8645:34;8715:3;8710:2;8699:9;8695:18;8688:31;8739:6;8774;8768:13;8805:6;8797;8790:22;8843:3;8832:9;8828:19;8821:26;;8882:2;8874:6;8870:15;8856:29;;8903:1;8913:195;8927:6;8924:1;8921:13;8913:195;;;8992:13;;-1:-1:-1;;;;;8988:39:1;8976:52;;9083:15;;;;9048:12;;;;9024:1;8942:9;8913:195;;;-1:-1:-1;;;;;;;9164:32:1;;;;9159:2;9144:18;;9137:60;-1:-1:-1;;;9228:3:1;9213:19;9206:35;9125:3;8267:980;-1:-1:-1;;;8267:980:1:o;9252:168::-;9325:9;;;9356;;9373:15;;;9367:22;;9353:37;9343:71;;9394:18;;:::i;9425:217::-;9465:1;9491;9481:132;;9535:10;9530:3;9526:20;9523:1;9516:31;9570:4;9567:1;9560:15;9598:4;9595:1;9588:15;9481:132;-1:-1:-1;9627:9:1;;9425:217::o

Swarm Source

ipfs://9fe06b6cb4f2669145d98e195dbe4930f81d89424a71fb8a8564fbb4792d8b64
Loading...
Loading
Loading...
Loading
[ Download: CSV Export  ]
[ Download: CSV Export  ]

A token is a representation of an on-chain or off-chain asset. The token page shows information such as price, total supply, holders, transfers and social links. Learn more about this page in our Knowledge Base.