ETH Price: $2,199.02 (+2.39%)

Token

GangsterCliffordInu (GCLIFF)
 

Overview

Max Total Supply

1,000,000,000,000,000,000,000 GCLIFF

Holders

8

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 9 Decimals)

Balance
0.275258741 GCLIFF

Value
$0.00
0xe874c5f16163d39376b1dadb51bd20d82b0d3e9b
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:
Shingeki

Compiler Version
v0.8.4+commit.c7e474f2

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, Unlicense license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2021-12-19
*/

pragma solidity >=0.5.0;

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;
}

// File: @uniswap/v2-periphery/contracts/interfaces/IUniswapV2Router01.sol

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;
}


pragma solidity ^0.8.0;

// CAUTION
// This version of SafeMath should only be used with Solidity 0.8 or later,
// because it relies on the compiler's built in overflow checks.

/**
 * @dev Wrappers over Solidity's arithmetic operations.
 *
 * NOTE: `SafeMath` is no longer needed starting with Solidity 0.8. The compiler
 * now has built in overflow checking.
 */
library SafeMath {
    /**
     * @dev Returns the addition of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function tryAdd(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            uint256 c = a + b;
            if (c < a) return (false, 0);
            return (true, c);
        }
    }

    /**
     * @dev Returns the substraction of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function trySub(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b > a) return (false, 0);
            return (true, a - b);
        }
    }

    /**
     * @dev Returns the multiplication of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function tryMul(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            // 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 (true, 0);
            uint256 c = a * b;
            if (c / a != b) return (false, 0);
            return (true, c);
        }
    }

    /**
     * @dev Returns the division of two unsigned integers, with a division by zero flag.
     *
     * _Available since v3.4._
     */
    function tryDiv(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a / b);
        }
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers, with a division by zero flag.
     *
     * _Available since v3.4._
     */
    function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a % b);
        }
    }

    /**
     * @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) {
        return a + b;
    }

    /**
     * @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 a - b;
    }

    /**
     * @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) {
        return a * b;
    }

    /**
     * @dev Returns the integer division of two unsigned integers, reverting on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator.
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return a / b;
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * reverting 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 a % b;
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting with custom message on
     * overflow (when the result is negative).
     *
     * CAUTION: This function is deprecated because it requires allocating memory for the error
     * message unnecessarily. For custom revert reasons use {trySub}.
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b <= a, errorMessage);
            return a - b;
        }
    }

    /**
     * @dev Returns the integer division of two unsigned integers, reverting 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) {
        unchecked {
            require(b > 0, errorMessage);
            return a / b;
        }
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * reverting with custom message when dividing by zero.
     *
     * CAUTION: This function is deprecated because it requires allocating memory for the error
     * message unnecessarily. For custom revert reasons use {tryMod}.
     *
     * 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) {
        unchecked {
            require(b > 0, errorMessage);
            return a % b;
        }
    }
}


pragma solidity ^0.8.0;

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

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


pragma solidity ^0.8.0;


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

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

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor() {
        _setOwner(_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 {
        _setOwner(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");
        _setOwner(newOwner);
    }

    function _setOwner(address newOwner) private {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}

pragma solidity ^0.8.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);
}

//SPDX-License-Identifier: UNLICENSED

pragma solidity 0.8.4;

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

  mapping (address => uint256) private _balances;
  mapping (address => mapping (address => uint256)) private _allowances;
  mapping (address => bool) private _isExcludedFromFee;
  
  bool public isTradingEnabled;
  bool private inSwapAndLiquify;
  bool public swapAndSellEnabled;
  
  IUniswapV2Router02 private immutable uniswapV2Router;
  address public immutable uniswapV2Pair;
  
  address payable private feeWallet1 = payable(0x6971d582d1dab79d5090D2054F92AA1990134cB7);
  address payable private feeWallet2 = payable(0x2783a80D6b3d5401F7D14baA184e5bD741394Dd9);

  uint256 private _totalSupply;
  uint8  private _decimals;
  string private _symbol;
  string private _name;
  
  uint256 public _maxTxAmount;
  uint256 private numTokensSoldToSendAsFee = 1000 * 10**6 * 10**18;
  
  event SwapAndSell(uint256 contractTokenBalance, uint256 newBalance, address wallet1, address wallet2);
  
  modifier lockTheSwap {
        inSwapAndLiquify = true;
        _;
        inSwapAndLiquify = false;
  }

  constructor() {
    _name = "GangsterCliffordInu";
    _symbol = "GCLIFF";
    _decimals = 9;
    _totalSupply = 1000000000000 * 10**18;
    _balances[msg.sender] = _totalSupply;
    
    IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
    uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory())
            .createPair(address(this), _uniswapV2Router.WETH());

    uniswapV2Router = _uniswapV2Router;
    
    _isExcludedFromFee[owner()] = true;
    _isExcludedFromFee[address(this)] = true;
    
    swapAndSellEnabled = false;
    
    _maxTxAmount = _totalSupply.mul(100).div(100);

    emit Transfer(address(0), msg.sender, _totalSupply);
  }
  
  receive() external payable {}

  function getOwner() external view returns (address) {
    return owner();
  }

  function decimals() external view returns (uint8) {
    return _decimals;
  }

  function symbol() external view returns (string memory) {
    return _symbol;
  }

  function name() external view returns (string memory) {
    return _name;
  }

  function totalSupply() external view override returns (uint256) {
    return _totalSupply;
  }

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

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

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

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

  function transferFrom(address sender, address recipient, uint256 amount) external override returns (bool) {
    _transfer(sender, recipient, amount);
    _approve(sender, _msgSender(), _allowances[sender][_msgSender()].sub(amount, "BEP20: transfer amount exceeds allowance"));
    return true;
  }

  function increaseAllowance(address spender, uint256 addedValue) public returns (bool) {
    _approve(_msgSender(), spender, _allowances[_msgSender()][spender].add(addedValue));
    return true;
  }

  function decreaseAllowance(address spender, uint256 subtractedValue) public returns (bool) {
    _approve(_msgSender(), spender, _allowances[_msgSender()][spender].sub(subtractedValue, "BEP20: decreased allowance below zero"));
    return true;
  }

  function burn(uint256 amount) public returns (bool) {
    _burn(_msgSender(), amount);
    return true;
  }
  
  function excludeFromFee(address account) public onlyOwner {
    _isExcludedFromFee[account] = true;
  }
    
  function includeInFee(address account) public onlyOwner {
    _isExcludedFromFee[account] = false;
  }
  
  function setMaxTxPercent(uint256 maxTxPercent) external onlyOwner {
    require(maxTxPercent <= 100, "Invalid max amount");  
    _maxTxAmount = _totalSupply.mul(maxTxPercent).div(
        10**2
    );
  }
  
  function setSellTokenThreshold(uint256 amount) external onlyOwner {
    require(amount < _totalSupply,"Invalid amount");  
    numTokensSoldToSendAsFee = amount;
  }
  
  function setTradingEnabled(bool value) public onlyOwner {
    isTradingEnabled = value;
  }
  
  function setSwapAndSellEnabled(bool value) public onlyOwner {
    swapAndSellEnabled = value;
  }
  

  function _transfer(address sender, address recipient, uint256 amount) internal {
    require(sender != address(0), "BEP20: transfer from the zero address");
    require(recipient != address(0), "BEP20: transfer to the zero address");
    
    _balances[sender] = _balances[sender].sub(amount, "BEP20: transfer amount exceeds balance");
    
    if(!_isExcludedFromFee[sender] && !_isExcludedFromFee[recipient]){
        require(amount <= _maxTxAmount,"Transfer amount exceeds maximum");
        
        if(sender == uniswapV2Pair || recipient == uniswapV2Pair){
            require(isTradingEnabled,"Trading is not enabled");
        }
        
        uint256 feeAmount = amount.mul(12).div(100);
        _balances[address(this)] = _balances[address(this)].add(feeAmount);
        amount = amount.sub(feeAmount);
        
        emit Transfer(sender, address(this), feeAmount);
        
    }
    
    uint256 contractTokenBalance = this.balanceOf(address(this));
        
    if(contractTokenBalance >= _maxTxAmount){
        contractTokenBalance = _maxTxAmount;
    }
        
    bool overMinTokenBalance = contractTokenBalance >= numTokensSoldToSendAsFee;
        
    if (
        overMinTokenBalance &&
        !inSwapAndLiquify &&
        sender != uniswapV2Pair &&
        swapAndSellEnabled
    ) {
        //add liquidity
        swapAndSell(contractTokenBalance);
    }
    _balances[recipient] = _balances[recipient].add(amount);    
        
    emit Transfer(sender, recipient, amount);
    
  }
  
  function swapAndSell(uint256 contractTokenBalance) private lockTheSwap {

        // capture the contract's current ETH balance.
        uint256 initialBalance = address(this).balance;

        // swap tokens for ETH
        swapTokensForEth(contractTokenBalance); // <- this breaks the ETH -> HATE swap when swap+liquify is triggered

        // how much ETH did we just swap into?
        uint256 newBalance = address(this).balance.sub(initialBalance);

        // add liquidity to uniswap
        feeWallet1.transfer(newBalance.div(2));
        feeWallet2.transfer(newBalance.div(2));
        
        emit SwapAndSell(contractTokenBalance, newBalance, feeWallet1, feeWallet2);
    }
  
  function swapTokensForEth(uint256 tokenAmount) private {
        // generate the uniswap pair path of token -> weth
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = uniswapV2Router.WETH();

        _approve(address(this), address(uniswapV2Router), tokenAmount);

        // make the swap
        uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0, // accept any amount of ETH
            path,
            address(this),
            block.timestamp
        );
    }

  function _mint(address account, uint256 amount) internal {
    require(account != address(0), "BEP20: mint to the zero address");

    _totalSupply = _totalSupply.add(amount);
    _balances[account] = _balances[account].add(amount);
    emit Transfer(address(0), account, amount);
  }

  function _burn(address account, uint256 amount) internal {
    require(account != address(0), "BEP20: burn from the zero address");

    _balances[account] = _balances[account].sub(amount, "BEP20: burn amount exceeds balance");
    _totalSupply = _totalSupply.sub(amount);
    emit Transfer(account, address(0), amount);
  }

  function _approve(address owner, address spender, uint256 amount) internal {
    require(owner != address(0), "BEP20: approve from the zero address");
    require(spender != address(0), "BEP20: approve to the zero address");

    _allowances[owner][spender] = amount;
    emit Approval(owner, spender, amount);
  }

  function _burnFrom(address account, uint256 amount) internal {
    _burn(account, amount);
    _approve(account, _msgSender(), _allowances[account][_msgSender()].sub(amount, "BEP20: burn amount exceeds allowance"));
  }
}

Contract Security Audit

Contract ABI

API
[{"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":false,"internalType":"uint256","name":"contractTokenBalance","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"newBalance","type":"uint256"},{"indexed":false,"internalType":"address","name":"wallet1","type":"address"},{"indexed":false,"internalType":"address","name":"wallet2","type":"address"}],"name":"SwapAndSell","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":"_maxTxAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"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":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"burn","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"excludeFromFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"getOwner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"includeInFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"isTradingEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"maxTxPercent","type":"uint256"}],"name":"setMaxTxPercent","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"setSellTokenThreshold","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"value","type":"bool"}],"name":"setSwapAndSellEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"value","type":"bool"}],"name":"setTradingEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapAndSellEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"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":[],"name":"uniswapV2Pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"stateMutability":"payable","type":"receive"}]

60c060405260048054766971d582d1dab79d5090d2054f92aa1990134cb70000006301000000600160b81b0319909116179055600580546001600160a01b031916732783a80d6b3d5401f7d14baa184e5bd741394dd91790556b033b2e3c9fd0803ce8000000600b553480156200007557600080fd5b506200008133620003b3565b6040805180820190915260138082527f47616e6773746572436c6966666f7264496e75000000000000000000000000006020909201918252620000c79160099162000426565b506040805180820190915260068082526523a1a624a32360d11b6020909201918252620000f79160089162000426565b506007805460ff191660091790556c0c9f2c9cd04674edea4000000060068190553360009081526001602090815260409182902092909255805163c45a015560e01b81529051737a250d5630b4cf539739df2c5dacb4c659f2488d92839263c45a01559260048083019392829003018186803b1580156200017757600080fd5b505afa1580156200018c573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620001b29190620004cc565b6001600160a01b031663c9c6539630836001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b158015620001fb57600080fd5b505afa15801562000210573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620002369190620004cc565b6040516001600160e01b031960e085901b1681526001600160a01b03928316600482015291166024820152604401602060405180830381600087803b1580156200027f57600080fd5b505af115801562000294573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620002ba9190620004cc565b6001600160601b0319606091821b811660a0529082901b16608052600160036000620002ee6000546001600160a01b031690565b6001600160a01b0316815260208082019290925260409081016000908120805494151560ff19958616179055308152600383522080549092166001179091556004805462ff0000191690556006546200036e916064916200035a918390620009ce62000403821b17901c565b6200041860201b620009e11790919060201c565b600a5560065460405190815233906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a3506200057f565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b600062000411828462000516565b9392505050565b6000620004118284620004f5565b828054620004349062000542565b90600052602060002090601f016020900481019282620004585760008555620004a3565b82601f106200047357805160ff1916838001178555620004a3565b82800160010185558215620004a3579182015b82811115620004a357825182559160200191906001019062000486565b50620004b1929150620004b5565b5090565b5b80821115620004b15760008155600101620004b6565b600060208284031215620004de578081fd5b81516001600160a01b038116811462000411578182fd5b6000826200051157634e487b7160e01b81526012600452602481fd5b500490565b60008160001904831182151516156200053d57634e487b7160e01b81526011600452602481fd5b500290565b600181811c908216806200055757607f821691505b602082108114156200057957634e487b7160e01b600052602260045260246000fd5b50919050565b60805160601c60a05160601c611806620005ce600039600081816102d701528181610cbb01528181610cf60152610eba0152600081816112be0152818161139401526113d001526118066000f3fe6080604052600436106101855760003560e01c8063893d20e8116100d1578063c2e5ec041161008a578063dd62ed3e11610064578063dd62ed3e14610465578063e316cfe5146104ab578063ea2f0b37146104cb578063f2fde38b146104eb57600080fd5b8063c2e5ec0414610405578063d543dbeb14610425578063d7b7a0dc1461044557600080fd5b8063893d20e8146103725780638da5cb5b1461037257806395d89b4114610390578063a457c2d7146103a5578063a9059cbb146103c5578063b6343b21146103e557600080fd5b8063395093511161013e57806349bd5a5e1161011857806349bd5a5e146102c557806370a0823114610311578063715018a6146103475780637d1db4a51461035c57600080fd5b8063395093511461026357806342966c6814610283578063437823ec146102a357600080fd5b8063064a59d01461019157806306fdde03146101c0578063095ea7b3146101e257806318160ddd1461020257806323b872dd14610221578063313ce5671461024157600080fd5b3661018c57005b600080fd5b34801561019d57600080fd5b506004546101ab9060ff1681565b60405190151581526020015b60405180910390f35b3480156101cc57600080fd5b506101d561050b565b6040516101b7919061156f565b3480156101ee57600080fd5b506101ab6101fd3660046114f4565b61059d565b34801561020e57600080fd5b506006545b6040519081526020016101b7565b34801561022d57600080fd5b506101ab61023c3660046114b4565b6105b3565b34801561024d57600080fd5b5060075460405160ff90911681526020016101b7565b34801561026f57600080fd5b506101ab61027e3660046114f4565b61061c565b34801561028f57600080fd5b506101ab61029e36600461153f565b610652565b3480156102af57600080fd5b506102c36102be366004611444565b610666565b005b3480156102d157600080fd5b506102f97f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b0390911681526020016101b7565b34801561031d57600080fd5b5061021361032c366004611444565b6001600160a01b031660009081526001602052604090205490565b34801561035357600080fd5b506102c36106bd565b34801561036857600080fd5b50610213600a5481565b34801561037e57600080fd5b506000546001600160a01b03166102f9565b34801561039c57600080fd5b506101d56106f3565b3480156103b157600080fd5b506101ab6103c03660046114f4565b610702565b3480156103d157600080fd5b506101ab6103e03660046114f4565b610751565b3480156103f157600080fd5b506102c361040036600461153f565b61075e565b34801561041157600080fd5b506102c361042036600461151f565b6107cf565b34801561043157600080fd5b506102c361044036600461153f565b61080c565b34801561045157600080fd5b506004546101ab9062010000900460ff1681565b34801561047157600080fd5b5061021361048036600461147c565b6001600160a01b03918216600090815260026020908152604080832093909416825291909152205490565b3480156104b757600080fd5b506102c36104c636600461151f565b6108a2565b3480156104d757600080fd5b506102c36104e6366004611444565b6108e8565b3480156104f757600080fd5b506102c3610506366004611444565b610933565b60606009805461051a906116d5565b80601f0160208091040260200160405190810160405280929190818152602001828054610546906116d5565b80156105935780601f1061056857610100808354040283529160200191610593565b820191906000526020600020905b81548152906001019060200180831161057657829003601f168201915b5050505050905090565b60006105aa3384846109ed565b50600192915050565b60006105c0848484610b11565b610612843361060d8560405180606001604052806028815260200161173c602891396001600160a01b038a1660009081526002602090815260408083203384529091529020549190610f97565b6109ed565b5060019392505050565b3360008181526002602090815260408083206001600160a01b038716845290915281205490916105aa91859061060d9086610fc3565b600061065e3383610fcf565b506001919050565b6000546001600160a01b031633146106995760405162461bcd60e51b8152600401610690906115c2565b60405180910390fd5b6001600160a01b03166000908152600360205260409020805460ff19166001179055565b6000546001600160a01b031633146106e75760405162461bcd60e51b8152600401610690906115c2565b6106f160006110da565b565b60606008805461051a906116d5565b60006105aa338461060d8560405180606001604052806025815260200161178a602591393360009081526002602090815260408083206001600160a01b038d1684529091529020549190610f97565b60006105aa338484610b11565b6000546001600160a01b031633146107885760405162461bcd60e51b8152600401610690906115c2565b60065481106107ca5760405162461bcd60e51b815260206004820152600e60248201526d125b9d985b1a5908185b5bdd5b9d60921b6044820152606401610690565b600b55565b6000546001600160a01b031633146107f95760405162461bcd60e51b8152600401610690906115c2565b6004805460ff1916911515919091179055565b6000546001600160a01b031633146108365760405162461bcd60e51b8152600401610690906115c2565b606481111561087c5760405162461bcd60e51b8152602060048201526012602482015271125b9d985b1a59081b585e08185b5bdd5b9d60721b6044820152606401610690565b61089c6064610896836006546109ce90919063ffffffff16565b906109e1565b600a5550565b6000546001600160a01b031633146108cc5760405162461bcd60e51b8152600401610690906115c2565b60048054911515620100000262ff000019909216919091179055565b6000546001600160a01b031633146109125760405162461bcd60e51b8152600401610690906115c2565b6001600160a01b03166000908152600360205260409020805460ff19169055565b6000546001600160a01b0316331461095d5760405162461bcd60e51b8152600401610690906115c2565b6001600160a01b0381166109c25760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610690565b6109cb816110da565b50565b60006109da828461169f565b9392505050565b60006109da828461167f565b6001600160a01b038316610a4f5760405162461bcd60e51b8152602060048201526024808201527f42455032303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610690565b6001600160a01b038216610ab05760405162461bcd60e51b815260206004820152602260248201527f42455032303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610690565b6001600160a01b0383811660008181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038316610b755760405162461bcd60e51b815260206004820152602560248201527f42455032303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610690565b6001600160a01b038216610bd75760405162461bcd60e51b815260206004820152602360248201527f42455032303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610690565b610c1481604051806060016040528060268152602001611764602691396001600160a01b0386166000908152600160205260409020549190610f97565b6001600160a01b03841660009081526001602090815260408083209390935560039052205460ff16158015610c6257506001600160a01b03821660009081526003602052604090205460ff16155b15610e1457600a54811115610cb95760405162461bcd60e51b815260206004820152601f60248201527f5472616e7366657220616d6f756e742065786365656473206d6178696d756d006044820152606401610690565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316836001600160a01b03161480610d2a57507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316826001600160a01b0316145b15610d7a5760045460ff16610d7a5760405162461bcd60e51b8152602060048201526016602482015275151c98591a5b99c81a5cc81b9bdd08195b98589b195960521b6044820152606401610690565b6000610d8c606461089684600c6109ce565b30600090815260016020526040902054909150610da99082610fc3565b30600090815260016020526040902055610dc3828261112a565b9150306001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051610e0a91815260200190565b60405180910390a3505b6040516370a0823160e01b815230600482018190526000916370a082319060240160206040518083038186803b158015610e4d57600080fd5b505afa158015610e61573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e859190611557565b9050600a548110610e955750600a545b600b5481108015908190610eb15750600454610100900460ff16155b8015610eef57507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316856001600160a01b031614155b8015610f03575060045462010000900460ff165b15610f1157610f1182611136565b6001600160a01b038416600090815260016020526040902054610f349084610fc3565b6001600160a01b0380861660008181526001602052604090819020939093559151908716907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90610f889087815260200190565b60405180910390a35050505050565b60008184841115610fbb5760405162461bcd60e51b8152600401610690919061156f565b505050900390565b60006109da8284611667565b6001600160a01b03821661102f5760405162461bcd60e51b815260206004820152602160248201527f42455032303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b6064820152608401610690565b61106c816040518060600160405280602281526020016117af602291396001600160a01b0385166000908152600160205260409020549190610f97565b6001600160a01b038316600090815260016020526040902055600654611092908261112a565b6006556040518181526000906001600160a01b038416907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35050565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b60006109da82846116be565b6004805461ff0019166101001790554761114f82611259565b600061115b478361112a565b600454909150630100000090046001600160a01b03166108fc61117f8360026109e1565b6040518115909202916000818181858888f193505050501580156111a7573d6000803e3d6000fd5b506005546001600160a01b03166108fc6111c28360026109e1565b6040518115909202916000818181858888f193505050501580156111ea573d6000803e3d6000fd5b5060045460055460408051868152602081018590526001600160a01b036301000000909404841681830152929091166060830152517f86c8a418ca900167dba44a9de9a7f7d8504021d589bf656066f8925595487c4b9181900360800190a150506004805461ff001916905550565b604080516002808252606082018352600092602083019080368337019050509050308160008151811061129c57634e487b7160e01b600052603260045260246000fd5b60200260200101906001600160a01b031690816001600160a01b0316815250507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b15801561131557600080fd5b505afa158015611329573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061134d9190611460565b8160018151811061136e57634e487b7160e01b600052603260045260246000fd5b60200260200101906001600160a01b031690816001600160a01b0316815250506113b9307f0000000000000000000000000000000000000000000000000000000000000000846109ed565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000169063791ac9479061140e9085906000908690309042906004016115f7565b600060405180830381600087803b15801561142857600080fd5b505af115801561143c573d6000803e3d6000fd5b505050505050565b600060208284031215611455578081fd5b81356109da81611726565b600060208284031215611471578081fd5b81516109da81611726565b6000806040838503121561148e578081fd5b823561149981611726565b915060208301356114a981611726565b809150509250929050565b6000806000606084860312156114c8578081fd5b83356114d381611726565b925060208401356114e381611726565b929592945050506040919091013590565b60008060408385031215611506578182fd5b823561151181611726565b946020939093013593505050565b600060208284031215611530578081fd5b813580151581146109da578182fd5b600060208284031215611550578081fd5b5035919050565b600060208284031215611568578081fd5b5051919050565b6000602080835283518082850152825b8181101561159b5785810183015185820160400152820161157f565b818111156115ac5783604083870101525b50601f01601f1916929092016040019392505050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b600060a082018783526020878185015260a0604085015281875180845260c0860191508289019350845b818110156116465784516001600160a01b031683529383019391830191600101611621565b50506001600160a01b03969096166060850152505050608001529392505050565b6000821982111561167a5761167a611710565b500190565b60008261169a57634e487b7160e01b81526012600452602481fd5b500490565b60008160001904831182151516156116b9576116b9611710565b500290565b6000828210156116d0576116d0611710565b500390565b600181811c908216806116e957607f821691505b6020821081141561170a57634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b6001600160a01b03811681146109cb57600080fdfe42455032303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636542455032303a207472616e7366657220616d6f756e7420657863656564732062616c616e636542455032303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726f42455032303a206275726e20616d6f756e7420657863656564732062616c616e6365a2646970667358221220fed4c0855635576f58e04b4adb9b1d9341d3b5299b69866cd0c5524a0b806e1e64736f6c63430008040033

Deployed Bytecode

0x6080604052600436106101855760003560e01c8063893d20e8116100d1578063c2e5ec041161008a578063dd62ed3e11610064578063dd62ed3e14610465578063e316cfe5146104ab578063ea2f0b37146104cb578063f2fde38b146104eb57600080fd5b8063c2e5ec0414610405578063d543dbeb14610425578063d7b7a0dc1461044557600080fd5b8063893d20e8146103725780638da5cb5b1461037257806395d89b4114610390578063a457c2d7146103a5578063a9059cbb146103c5578063b6343b21146103e557600080fd5b8063395093511161013e57806349bd5a5e1161011857806349bd5a5e146102c557806370a0823114610311578063715018a6146103475780637d1db4a51461035c57600080fd5b8063395093511461026357806342966c6814610283578063437823ec146102a357600080fd5b8063064a59d01461019157806306fdde03146101c0578063095ea7b3146101e257806318160ddd1461020257806323b872dd14610221578063313ce5671461024157600080fd5b3661018c57005b600080fd5b34801561019d57600080fd5b506004546101ab9060ff1681565b60405190151581526020015b60405180910390f35b3480156101cc57600080fd5b506101d561050b565b6040516101b7919061156f565b3480156101ee57600080fd5b506101ab6101fd3660046114f4565b61059d565b34801561020e57600080fd5b506006545b6040519081526020016101b7565b34801561022d57600080fd5b506101ab61023c3660046114b4565b6105b3565b34801561024d57600080fd5b5060075460405160ff90911681526020016101b7565b34801561026f57600080fd5b506101ab61027e3660046114f4565b61061c565b34801561028f57600080fd5b506101ab61029e36600461153f565b610652565b3480156102af57600080fd5b506102c36102be366004611444565b610666565b005b3480156102d157600080fd5b506102f97f000000000000000000000000f1f7ab654beaa82cf83f00473833d6bcfb0e169181565b6040516001600160a01b0390911681526020016101b7565b34801561031d57600080fd5b5061021361032c366004611444565b6001600160a01b031660009081526001602052604090205490565b34801561035357600080fd5b506102c36106bd565b34801561036857600080fd5b50610213600a5481565b34801561037e57600080fd5b506000546001600160a01b03166102f9565b34801561039c57600080fd5b506101d56106f3565b3480156103b157600080fd5b506101ab6103c03660046114f4565b610702565b3480156103d157600080fd5b506101ab6103e03660046114f4565b610751565b3480156103f157600080fd5b506102c361040036600461153f565b61075e565b34801561041157600080fd5b506102c361042036600461151f565b6107cf565b34801561043157600080fd5b506102c361044036600461153f565b61080c565b34801561045157600080fd5b506004546101ab9062010000900460ff1681565b34801561047157600080fd5b5061021361048036600461147c565b6001600160a01b03918216600090815260026020908152604080832093909416825291909152205490565b3480156104b757600080fd5b506102c36104c636600461151f565b6108a2565b3480156104d757600080fd5b506102c36104e6366004611444565b6108e8565b3480156104f757600080fd5b506102c3610506366004611444565b610933565b60606009805461051a906116d5565b80601f0160208091040260200160405190810160405280929190818152602001828054610546906116d5565b80156105935780601f1061056857610100808354040283529160200191610593565b820191906000526020600020905b81548152906001019060200180831161057657829003601f168201915b5050505050905090565b60006105aa3384846109ed565b50600192915050565b60006105c0848484610b11565b610612843361060d8560405180606001604052806028815260200161173c602891396001600160a01b038a1660009081526002602090815260408083203384529091529020549190610f97565b6109ed565b5060019392505050565b3360008181526002602090815260408083206001600160a01b038716845290915281205490916105aa91859061060d9086610fc3565b600061065e3383610fcf565b506001919050565b6000546001600160a01b031633146106995760405162461bcd60e51b8152600401610690906115c2565b60405180910390fd5b6001600160a01b03166000908152600360205260409020805460ff19166001179055565b6000546001600160a01b031633146106e75760405162461bcd60e51b8152600401610690906115c2565b6106f160006110da565b565b60606008805461051a906116d5565b60006105aa338461060d8560405180606001604052806025815260200161178a602591393360009081526002602090815260408083206001600160a01b038d1684529091529020549190610f97565b60006105aa338484610b11565b6000546001600160a01b031633146107885760405162461bcd60e51b8152600401610690906115c2565b60065481106107ca5760405162461bcd60e51b815260206004820152600e60248201526d125b9d985b1a5908185b5bdd5b9d60921b6044820152606401610690565b600b55565b6000546001600160a01b031633146107f95760405162461bcd60e51b8152600401610690906115c2565b6004805460ff1916911515919091179055565b6000546001600160a01b031633146108365760405162461bcd60e51b8152600401610690906115c2565b606481111561087c5760405162461bcd60e51b8152602060048201526012602482015271125b9d985b1a59081b585e08185b5bdd5b9d60721b6044820152606401610690565b61089c6064610896836006546109ce90919063ffffffff16565b906109e1565b600a5550565b6000546001600160a01b031633146108cc5760405162461bcd60e51b8152600401610690906115c2565b60048054911515620100000262ff000019909216919091179055565b6000546001600160a01b031633146109125760405162461bcd60e51b8152600401610690906115c2565b6001600160a01b03166000908152600360205260409020805460ff19169055565b6000546001600160a01b0316331461095d5760405162461bcd60e51b8152600401610690906115c2565b6001600160a01b0381166109c25760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610690565b6109cb816110da565b50565b60006109da828461169f565b9392505050565b60006109da828461167f565b6001600160a01b038316610a4f5760405162461bcd60e51b8152602060048201526024808201527f42455032303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610690565b6001600160a01b038216610ab05760405162461bcd60e51b815260206004820152602260248201527f42455032303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610690565b6001600160a01b0383811660008181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038316610b755760405162461bcd60e51b815260206004820152602560248201527f42455032303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610690565b6001600160a01b038216610bd75760405162461bcd60e51b815260206004820152602360248201527f42455032303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610690565b610c1481604051806060016040528060268152602001611764602691396001600160a01b0386166000908152600160205260409020549190610f97565b6001600160a01b03841660009081526001602090815260408083209390935560039052205460ff16158015610c6257506001600160a01b03821660009081526003602052604090205460ff16155b15610e1457600a54811115610cb95760405162461bcd60e51b815260206004820152601f60248201527f5472616e7366657220616d6f756e742065786365656473206d6178696d756d006044820152606401610690565b7f000000000000000000000000f1f7ab654beaa82cf83f00473833d6bcfb0e16916001600160a01b0316836001600160a01b03161480610d2a57507f000000000000000000000000f1f7ab654beaa82cf83f00473833d6bcfb0e16916001600160a01b0316826001600160a01b0316145b15610d7a5760045460ff16610d7a5760405162461bcd60e51b8152602060048201526016602482015275151c98591a5b99c81a5cc81b9bdd08195b98589b195960521b6044820152606401610690565b6000610d8c606461089684600c6109ce565b30600090815260016020526040902054909150610da99082610fc3565b30600090815260016020526040902055610dc3828261112a565b9150306001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051610e0a91815260200190565b60405180910390a3505b6040516370a0823160e01b815230600482018190526000916370a082319060240160206040518083038186803b158015610e4d57600080fd5b505afa158015610e61573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e859190611557565b9050600a548110610e955750600a545b600b5481108015908190610eb15750600454610100900460ff16155b8015610eef57507f000000000000000000000000f1f7ab654beaa82cf83f00473833d6bcfb0e16916001600160a01b0316856001600160a01b031614155b8015610f03575060045462010000900460ff165b15610f1157610f1182611136565b6001600160a01b038416600090815260016020526040902054610f349084610fc3565b6001600160a01b0380861660008181526001602052604090819020939093559151908716907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90610f889087815260200190565b60405180910390a35050505050565b60008184841115610fbb5760405162461bcd60e51b8152600401610690919061156f565b505050900390565b60006109da8284611667565b6001600160a01b03821661102f5760405162461bcd60e51b815260206004820152602160248201527f42455032303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b6064820152608401610690565b61106c816040518060600160405280602281526020016117af602291396001600160a01b0385166000908152600160205260409020549190610f97565b6001600160a01b038316600090815260016020526040902055600654611092908261112a565b6006556040518181526000906001600160a01b038416907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35050565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b60006109da82846116be565b6004805461ff0019166101001790554761114f82611259565b600061115b478361112a565b600454909150630100000090046001600160a01b03166108fc61117f8360026109e1565b6040518115909202916000818181858888f193505050501580156111a7573d6000803e3d6000fd5b506005546001600160a01b03166108fc6111c28360026109e1565b6040518115909202916000818181858888f193505050501580156111ea573d6000803e3d6000fd5b5060045460055460408051868152602081018590526001600160a01b036301000000909404841681830152929091166060830152517f86c8a418ca900167dba44a9de9a7f7d8504021d589bf656066f8925595487c4b9181900360800190a150506004805461ff001916905550565b604080516002808252606082018352600092602083019080368337019050509050308160008151811061129c57634e487b7160e01b600052603260045260246000fd5b60200260200101906001600160a01b031690816001600160a01b0316815250507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b15801561131557600080fd5b505afa158015611329573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061134d9190611460565b8160018151811061136e57634e487b7160e01b600052603260045260246000fd5b60200260200101906001600160a01b031690816001600160a01b0316815250506113b9307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d846109ed565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d169063791ac9479061140e9085906000908690309042906004016115f7565b600060405180830381600087803b15801561142857600080fd5b505af115801561143c573d6000803e3d6000fd5b505050505050565b600060208284031215611455578081fd5b81356109da81611726565b600060208284031215611471578081fd5b81516109da81611726565b6000806040838503121561148e578081fd5b823561149981611726565b915060208301356114a981611726565b809150509250929050565b6000806000606084860312156114c8578081fd5b83356114d381611726565b925060208401356114e381611726565b929592945050506040919091013590565b60008060408385031215611506578182fd5b823561151181611726565b946020939093013593505050565b600060208284031215611530578081fd5b813580151581146109da578182fd5b600060208284031215611550578081fd5b5035919050565b600060208284031215611568578081fd5b5051919050565b6000602080835283518082850152825b8181101561159b5785810183015185820160400152820161157f565b818111156115ac5783604083870101525b50601f01601f1916929092016040019392505050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b600060a082018783526020878185015260a0604085015281875180845260c0860191508289019350845b818110156116465784516001600160a01b031683529383019391830191600101611621565b50506001600160a01b03969096166060850152505050608001529392505050565b6000821982111561167a5761167a611710565b500190565b60008261169a57634e487b7160e01b81526012600452602481fd5b500490565b60008160001904831182151516156116b9576116b9611710565b500290565b6000828210156116d0576116d0611710565b500390565b600181811c908216806116e957607f821691505b6020821081141561170a57634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b6001600160a01b03811681146109cb57600080fdfe42455032303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636542455032303a207472616e7366657220616d6f756e7420657863656564732062616c616e636542455032303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726f42455032303a206275726e20616d6f756e7420657863656564732062616c616e6365a2646970667358221220fed4c0855635576f58e04b4adb9b1d9341d3b5299b69866cd0c5524a0b806e1e64736f6c63430008040033

Deployed Bytecode Sourcemap

18416:8691:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;18686:28;;;;;;;;;;-1:-1:-1;18686:28:0;;;;;;;;;;;2811:14:1;;2804:22;2786:41;;2774:2;2759:18;18686:28:0;;;;;;;;20561:79;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;21179:153::-;;;;;;;;;;-1:-1:-1;21179:153:0;;;;;:::i;:::-;;:::i;20646:96::-;;;;;;;;;;-1:-1:-1;20724:12:0;;20646:96;;;7781:25:1;;;7769:2;7754:18;20646:96:0;7736:76:1;21338:301:0;;;;;;;;;;-1:-1:-1;21338:301:0;;;;;:::i;:::-;;:::i;20387:79::-;;;;;;;;;;-1:-1:-1;20451:9:0;;20387:79;;20451:9;;;;9415:36:1;;9403:2;9388:18;20387:79:0;9370:87:1;21645:200:0;;;;;;;;;;-1:-1:-1;21645:200:0;;;;;:::i;:::-;;:::i;22108:110::-;;;;;;;;;;-1:-1:-1;22108:110:0;;;;;:::i;:::-;;:::i;22226:105::-;;;;;;;;;;-1:-1:-1;22226:105:0;;;;;:::i;:::-;;:::i;:::-;;18849:38;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;2602:32:1;;;2584:51;;2572:2;2557:18;18849:38:0;2539:102:1;20748:115:0;;;;;;;;;;-1:-1:-1;20748:115:0;;;;;:::i;:::-;-1:-1:-1;;;;;20839:18:0;20816:7;20839:18;;;:9;:18;;;;;;;20748:115;14946:94;;;;;;;;;;;;;:::i;19202:27::-;;;;;;;;;;;;;;;;20302:79;;;;;;;;;;-1:-1:-1;20345:7:0;14368:6;-1:-1:-1;;;;;14368:6:0;20302:79;;20472:83;;;;;;;;;;;;;:::i;21851:251::-;;;;;;;;;;-1:-1:-1;21851:251:0;;;;;:::i;:::-;;:::i;20869:159::-;;;;;;;;;;-1:-1:-1;20869:159:0;;;;;:::i;:::-;;:::i;22671:168::-;;;;;;;;;;-1:-1:-1;22671:168:0;;;;;:::i;:::-;;:::i;22847:93::-;;;;;;;;;;-1:-1:-1;22847:93:0;;;;;:::i;:::-;;:::i;22453:210::-;;;;;;;;;;-1:-1:-1;22453:210:0;;;;;:::i;:::-;;:::i;18753:30::-;;;;;;;;;;-1:-1:-1;18753:30:0;;;;;;;;;;;21034:139;;;;;;;;;;-1:-1:-1;21034:139:0;;;;;:::i;:::-;-1:-1:-1;;;;;21140:18:0;;;21117:7;21140:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;21034:139;22948:99;;;;;;;;;;-1:-1:-1;22948:99:0;;;;;:::i;:::-;;:::i;22341:104::-;;;;;;;;;;-1:-1:-1;22341:104:0;;;;;:::i;:::-;;:::i;15195:192::-;;;;;;;;;;-1:-1:-1;15195:192:0;;;;;:::i;:::-;;:::i;20561:79::-;20600:13;20629:5;20622:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;20561:79;:::o;21179:153::-;21256:4;21269:39;13220:10;21292:7;21301:6;21269:8;:39::i;:::-;-1:-1:-1;21322:4:0;21179:153;;;;:::o;21338:301::-;21438:4;21451:36;21461:6;21469:9;21480:6;21451:9;:36::i;:::-;21494:121;21503:6;13220:10;21525:89;21563:6;21525:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;21525:19:0;;;;;;:11;:19;;;;;;;;13220:10;21525:33;;;;;;;;;;:37;:89::i;:::-;21494:8;:121::i;:::-;-1:-1:-1;21629:4:0;21338:301;;;;;:::o;21645:200::-;13220:10;21725:4;21770:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;21770:34:0;;;;;;;;;;21725:4;;21738:83;;21761:7;;21770:50;;21809:10;21770:38;:50::i;22108:110::-;22154:4;22167:27;13220:10;22187:6;22167:5;:27::i;:::-;-1:-1:-1;22208:4:0;;22108:110;-1:-1:-1;22108:110:0:o;22226:105::-;14341:7;14368:6;-1:-1:-1;;;;;14368:6:0;13220:10;14515:23;14507:68;;;;-1:-1:-1;;;14507:68:0;;;;;;;:::i;:::-;;;;;;;;;-1:-1:-1;;;;;22291:27:0::1;;::::0;;;:18:::1;:27;::::0;;;;:34;;-1:-1:-1;;22291:34:0::1;22321:4;22291:34;::::0;;22226:105::o;14946:94::-;14341:7;14368:6;-1:-1:-1;;;;;14368:6:0;13220:10;14515:23;14507:68;;;;-1:-1:-1;;;14507:68:0;;;;;;;:::i;:::-;15011:21:::1;15029:1;15011:9;:21::i;:::-;14946:94::o:0;20472:83::-;20513:13;20542:7;20535:14;;;;;:::i;21851:251::-;21936:4;21949:129;13220:10;21972:7;21981:96;22020:15;21981:96;;;;;;;;;;;;;;;;;13220:10;21981:25;;;;:11;:25;;;;;;;;-1:-1:-1;;;;;21981:34:0;;;;;;;;;;;;:38;:96::i;20869:159::-;20949:4;20962:42;13220:10;20986:9;20997:6;20962:9;:42::i;22671:168::-;14341:7;14368:6;-1:-1:-1;;;;;14368:6:0;13220:10;14515:23;14507:68;;;;-1:-1:-1;;;14507:68:0;;;;;;;:::i;:::-;22761:12:::1;;22752:6;:21;22744:47;;;::::0;-1:-1:-1;;;22744:47:0;;4866:2:1;22744:47:0::1;::::0;::::1;4848:21:1::0;4905:2;4885:18;;;4878:30;-1:-1:-1;;;4924:18:1;;;4917:44;4978:18;;22744:47:0::1;4838:164:1::0;22744:47:0::1;22800:24;:33:::0;22671:168::o;22847:93::-;14341:7;14368:6;-1:-1:-1;;;;;14368:6:0;13220:10;14515:23;14507:68;;;;-1:-1:-1;;;14507:68:0;;;;;;;:::i;:::-;22910:16:::1;:24:::0;;-1:-1:-1;;22910:24:0::1;::::0;::::1;;::::0;;;::::1;::::0;;22847:93::o;22453:210::-;14341:7;14368:6;-1:-1:-1;;;;;14368:6:0;13220:10;14515:23;14507:68;;;;-1:-1:-1;;;14507:68:0;;;;;;;:::i;:::-;22550:3:::1;22534:12;:19;;22526:50;;;::::0;-1:-1:-1;;;22526:50:0;;6281:2:1;22526:50:0::1;::::0;::::1;6263:21:1::0;6320:2;6300:18;;;6293:30;-1:-1:-1;;;6339:18:1;;;6332:48;6397:18;;22526:50:0::1;6253:168:1::0;22526:50:0::1;22600:57;22645:5;22600:30;22617:12;22600;;:16;;:30;;;;:::i;:::-;:34:::0;::::1;:57::i;:::-;22585:12;:72:::0;-1:-1:-1;22453:210:0:o;22948:99::-;14341:7;14368:6;-1:-1:-1;;;;;14368:6:0;13220:10;14515:23;14507:68;;;;-1:-1:-1;;;14507:68:0;;;;;;;:::i;:::-;23015:18:::1;:26:::0;;;::::1;;::::0;::::1;-1:-1:-1::0;;23015:26:0;;::::1;::::0;;;::::1;::::0;;22948:99::o;22341:104::-;14341:7;14368:6;-1:-1:-1;;;;;14368:6:0;13220:10;14515:23;14507:68;;;;-1:-1:-1;;;14507:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;22404:27:0::1;22434:5;22404:27:::0;;;:18:::1;:27;::::0;;;;:35;;-1:-1:-1;;22404:35:0::1;::::0;;22341:104::o;15195:192::-;14341:7;14368:6;-1:-1:-1;;;;;14368:6:0;13220:10;14515:23;14507:68;;;;-1:-1:-1;;;14507:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;15284:22:0;::::1;15276:73;;;::::0;-1:-1:-1;;;15276:73:0;;4459:2:1;15276:73:0::1;::::0;::::1;4441:21:1::0;4498:2;4478:18;;;4471:30;4537:34;4517:18;;;4510:62;-1:-1:-1;;;4588:18:1;;;4581:36;4634:19;;15276:73:0::1;4431:228:1::0;15276:73:0::1;15360:19;15370:8;15360:9;:19::i;:::-;15195:192:::0;:::o;9145:98::-;9203:7;9230:5;9234:1;9230;:5;:::i;:::-;9223:12;9145:98;-1:-1:-1;;;9145:98:0:o;9544:::-;9602:7;9629:5;9633:1;9629;:5;:::i;26556:320::-;-1:-1:-1;;;;;26646:19:0;;26638:68;;;;-1:-1:-1;;;26638:68:0;;4054:2:1;26638:68:0;;;4036:21:1;4093:2;4073:18;;;4066:30;4132:34;4112:18;;;4105:62;-1:-1:-1;;;4183:18:1;;;4176:34;4227:19;;26638:68:0;4026:226:1;26638:68:0;-1:-1:-1;;;;;26721:21:0;;26713:68;;;;-1:-1:-1;;;26713:68:0;;7434:2:1;26713:68:0;;;7416:21:1;7473:2;7453:18;;;7446:30;7512:34;7492:18;;;7485:62;-1:-1:-1;;;7563:18:1;;;7556:32;7605:19;;26713:68:0;7406:224:1;26713:68:0;-1:-1:-1;;;;;26790:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;26838:32;;7781:25:1;;;26838:32:0;;7754:18:1;26838:32:0;;;;;;;26556:320;;;:::o;23057:1554::-;-1:-1:-1;;;;;23151:20:0;;23143:70;;;;-1:-1:-1;;;23143:70:0;;3648:2:1;23143:70:0;;;3630:21:1;3687:2;3667:18;;;3660:30;3726:34;3706:18;;;3699:62;-1:-1:-1;;;3777:18:1;;;3770:35;3822:19;;23143:70:0;3620:227:1;23143:70:0;-1:-1:-1;;;;;23228:23:0;;23220:71;;;;-1:-1:-1;;;23220:71:0;;6628:2:1;23220:71:0;;;6610:21:1;6667:2;6647:18;;;6640:30;6706:34;6686:18;;;6679:62;-1:-1:-1;;;6757:18:1;;;6750:33;6800:19;;23220:71:0;6600:225:1;23220:71:0;23324;23346:6;23324:71;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;23324:17:0;;;;;;:9;:17;;;;;;;:71;:21;:71::i;:::-;-1:-1:-1;;;;;23304:17:0;;;;;;:9;:17;;;;;;;;:91;;;;23412:18;:26;;;;;;23411:27;:61;;;;-1:-1:-1;;;;;;23443:29:0;;;;;;:18;:29;;;;;;;;23442:30;23411:61;23408:563;;;23502:12;;23492:6;:22;;23484:65;;;;-1:-1:-1;;;23484:65:0;;5560:2:1;23484:65:0;;;5542:21:1;5599:2;5579:18;;;5572:30;5638:33;5618:18;;;5611:61;5689:18;;23484:65:0;5532:181:1;23484:65:0;23583:13;-1:-1:-1;;;;;23573:23:0;:6;-1:-1:-1;;;;;23573:23:0;;:53;;;;23613:13;-1:-1:-1;;;;;23600:26:0;:9;-1:-1:-1;;;;;23600:26:0;;23573:53;23570:134;;;23650:16;;;;23642:50;;;;-1:-1:-1;;;23642:50:0;;5209:2:1;23642:50:0;;;5191:21:1;5248:2;5228:18;;;5221:30;-1:-1:-1;;;5267:18:1;;;5260:52;5329:18;;23642:50:0;5181:172:1;23642:50:0;23724:17;23744:23;23763:3;23744:14;:6;23755:2;23744:10;:14::i;:23::-;23823:4;23805:24;;;;:9;:24;;;;;;23724:43;;-1:-1:-1;23805:39:0;;23724:43;23805:28;:39::i;:::-;23796:4;23778:24;;;;:9;:24;;;;;:66;23864:21;:6;23875:9;23864:10;:21::i;:::-;23855:30;;23936:4;-1:-1:-1;;;;;23911:42:0;23920:6;-1:-1:-1;;;;;23911:42:0;;23943:9;23911:42;;;;7781:25:1;;7769:2;7754:18;;7736:76;23911:42:0;;;;;;;;23408:563;;24014:29;;-1:-1:-1;;;24014:29:0;;:4;:29;;;2584:51:1;;;23983:28:0;;24014:14;;2557:18:1;;24014:29:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;23983:60;;24087:12;;24063:20;:36;24060:94;;-1:-1:-1;24134:12:0;;24060:94;24221:24;;24197:48;;;;;;;24276:49;;-1:-1:-1;24309:16:0;;;;;;;24308:17;24276:49;:85;;;;;24348:13;-1:-1:-1;;;;;24338:23:0;:6;-1:-1:-1;;;;;24338:23:0;;;24276:85;:116;;;;-1:-1:-1;24374:18:0;;;;;;;24276:116;24262:215;;;24436:33;24448:20;24436:11;:33::i;:::-;-1:-1:-1;;;;;24506:20:0;;;;;;:9;:20;;;;;;:32;;24531:6;24506:24;:32::i;:::-;-1:-1:-1;;;;;24483:20:0;;;;;;;:9;:20;;;;;;;:55;;;;24564:35;;;;;;;;;;24592:6;7781:25:1;;7769:2;7754:18;;7736:76;24564:35:0;;;;;;;;23057:1554;;;;;:::o;10686:240::-;10806:7;10867:12;10859:6;;;;10851:29;;;;-1:-1:-1;;;10851:29:0;;;;;;;;:::i;:::-;-1:-1:-1;;;10902:5:0;;;10686:240::o;8407:98::-;8465:7;8492:5;8496:1;8492;:5;:::i;26220:330::-;-1:-1:-1;;;;;26292:21:0;;26284:67;;;;-1:-1:-1;;;26284:67:0;;7032:2:1;26284:67:0;;;7014:21:1;7071:2;7051:18;;;7044:30;7110:34;7090:18;;;7083:62;-1:-1:-1;;;7161:18:1;;;7154:31;7202:19;;26284:67:0;7004:223:1;26284:67:0;26381:68;26404:6;26381:68;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;26381:18:0;;;;;;:9;:18;;;;;;;:68;:22;:68::i;:::-;-1:-1:-1;;;;;26360:18:0;;;;;;:9;:18;;;;;:89;26471:12;;:24;;26488:6;26471:16;:24::i;:::-;26456:12;:39;26507:37;;7781:25:1;;;26533:1:0;;-1:-1:-1;;;;;26507:37:0;;;;;7769:2:1;7754:18;26507:37:0;;;;;;;26220:330;;:::o;15395:173::-;15451:16;15470:6;;-1:-1:-1;;;;;15487:17:0;;;-1:-1:-1;;;;;;15487:17:0;;;;;;15520:40;;15470:6;;;;;;;15520:40;;15451:16;15520:40;15395:173;;:::o;8788:98::-;8846:7;8873:5;8877:1;8873;:5;:::i;24619:702::-;19449:16;:23;;-1:-1:-1;;19449:23:0;;;;;24784:21:::1;24850:38;24867:20:::0;24850:16:::1;:38::i;:::-;25019:18;25040:41;:21;25066:14:::0;25040:25:::1;:41::i;:::-;25131:10;::::0;25019:62;;-1:-1:-1;25131:10:0;;::::1;-1:-1:-1::0;;;;;25131:10:0::1;:38;25151:17;25019:62:::0;25166:1:::1;25151:14;:17::i;:::-;25131:38;::::0;;::::1;::::0;;::::1;::::0;::::1;::::0;;;;;;::::1;;;;;;;;;;;;;::::0;::::1;;;;;-1:-1:-1::0;25180:10:0::1;::::0;-1:-1:-1;;;;;25180:10:0::1;:38;25200:17;:10:::0;25215:1:::1;25200:14;:17::i;:::-;25180:38;::::0;;::::1;::::0;;::::1;::::0;::::1;::::0;;;;;;::::1;;;;;;;;;;;;;::::0;::::1;;;;;-1:-1:-1::0;25290:10:0::1;::::0;25302::::1;::::0;25244:69:::1;::::0;;9052:25:1;;;9108:2;9093:18;;9086:34;;;-1:-1:-1;;;;;25290:10:0;;;::::1;::::0;::::1;9174:18:1::0;;;9167:43;25302:10:0;;;::::1;9241:2:1::0;9226:18;;9219:43;25244:69:0;::::1;::::0;;;;9039:3:1;25244:69:0;;::::1;-1:-1:-1::0;;19495:16:0;:24;;-1:-1:-1;;19495:24:0;;;-1:-1:-1;24619:702:0:o;25329:589::-;25479:16;;;25493:1;25479:16;;;;;;;;25455:21;;25479:16;;;;;;;;;;-1:-1:-1;25479:16:0;25455:40;;25524:4;25506;25511:1;25506:7;;;;;;-1:-1:-1;;;25506:7:0;;;;;;;;;;;;;;:23;-1:-1:-1;;;;;25506:23:0;;;-1:-1:-1;;;;;25506:23:0;;;;;25550:15;-1:-1:-1;;;;;25550:20:0;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;25540:4;25545:1;25540:7;;;;;;-1:-1:-1;;;25540:7:0;;;;;;;;;;;;;;:32;-1:-1:-1;;;;;25540:32:0;;;-1:-1:-1;;;;;25540:32:0;;;;;25585:62;25602:4;25617:15;25635:11;25585:8;:62::i;:::-;25686:224;;-1:-1:-1;;;25686:224:0;;-1:-1:-1;;;;;25686:15:0;:66;;;;:224;;25767:11;;25793:1;;25837:4;;25864;;25884:15;;25686:224;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;25329:589;;:::o;14:257:1:-;73:6;126:2;114:9;105:7;101:23;97:32;94:2;;;147:6;139;132:22;94:2;191:9;178:23;210:31;235:5;210:31;:::i;276:261::-;346:6;399:2;387:9;378:7;374:23;370:32;367:2;;;420:6;412;405:22;367:2;457:9;451:16;476:31;501:5;476:31;:::i;542:398::-;610:6;618;671:2;659:9;650:7;646:23;642:32;639:2;;;692:6;684;677:22;639:2;736:9;723:23;755:31;780:5;755:31;:::i;:::-;805:5;-1:-1:-1;862:2:1;847:18;;834:32;875:33;834:32;875:33;:::i;:::-;927:7;917:17;;;629:311;;;;;:::o;945:466::-;1022:6;1030;1038;1091:2;1079:9;1070:7;1066:23;1062:32;1059:2;;;1112:6;1104;1097:22;1059:2;1156:9;1143:23;1175:31;1200:5;1175:31;:::i;:::-;1225:5;-1:-1:-1;1282:2:1;1267:18;;1254:32;1295:33;1254:32;1295:33;:::i;:::-;1049:362;;1347:7;;-1:-1:-1;;;1401:2:1;1386:18;;;;1373:32;;1049:362::o;1416:325::-;1484:6;1492;1545:2;1533:9;1524:7;1520:23;1516:32;1513:2;;;1566:6;1558;1551:22;1513:2;1610:9;1597:23;1629:31;1654:5;1629:31;:::i;:::-;1679:5;1731:2;1716:18;;;;1703:32;;-1:-1:-1;;;1503:238:1:o;1746:293::-;1802:6;1855:2;1843:9;1834:7;1830:23;1826:32;1823:2;;;1876:6;1868;1861:22;1823:2;1920:9;1907:23;1973:5;1966:13;1959:21;1952:5;1949:32;1939:2;;2000:6;1992;1985:22;2044:190;2103:6;2156:2;2144:9;2135:7;2131:23;2127:32;2124:2;;;2177:6;2169;2162:22;2124:2;-1:-1:-1;2205:23:1;;2114:120;-1:-1:-1;2114:120:1:o;2239:194::-;2309:6;2362:2;2350:9;2341:7;2337:23;2333:32;2330:2;;;2383:6;2375;2368:22;2330:2;-1:-1:-1;2411:16:1;;2320:113;-1:-1:-1;2320:113:1:o;2838:603::-;2950:4;2979:2;3008;2997:9;2990:21;3040:6;3034:13;3083:6;3078:2;3067:9;3063:18;3056:34;3108:4;3121:140;3135:6;3132:1;3129:13;3121:140;;;3230:14;;;3226:23;;3220:30;3196:17;;;3215:2;3192:26;3185:66;3150:10;;3121:140;;;3279:6;3276:1;3273:13;3270:2;;;3349:4;3344:2;3335:6;3324:9;3320:22;3316:31;3309:45;3270:2;-1:-1:-1;3425:2:1;3404:15;-1:-1:-1;;3400:29:1;3385:45;;;;3432:2;3381:54;;2959:482;-1:-1:-1;;;2959:482:1:o;5718:356::-;5920:2;5902:21;;;5939:18;;;5932:30;5998:34;5993:2;5978:18;;5971:62;6065:2;6050:18;;5892:182::o;7817:983::-;8079:4;8127:3;8116:9;8112:19;8158:6;8147:9;8140:25;8184:2;8222:6;8217:2;8206:9;8202:18;8195:34;8265:3;8260:2;8249:9;8245:18;8238:31;8289:6;8324;8318:13;8355:6;8347;8340:22;8393:3;8382:9;8378:19;8371:26;;8432:2;8424:6;8420:15;8406:29;;8453:4;8466:195;8480:6;8477:1;8474:13;8466:195;;;8545:13;;-1:-1:-1;;;;;8541:39:1;8529:52;;8636:15;;;;8601:12;;;;8577:1;8495:9;8466:195;;;-1:-1:-1;;;;;;;8717:32:1;;;;8712:2;8697:18;;8690:60;-1:-1:-1;;;8781:3:1;8766:19;8759:35;8678:3;8088:712;-1:-1:-1;;;8088:712:1:o;9462:128::-;9502:3;9533:1;9529:6;9526:1;9523:13;9520:2;;;9539:18;;:::i;:::-;-1:-1:-1;9575:9:1;;9510:80::o;9595:217::-;9635:1;9661;9651:2;;-1:-1:-1;;;9686:31:1;;9740:4;9737:1;9730:15;9768:4;9693:1;9758:15;9651:2;-1:-1:-1;9797:9:1;;9641:171::o;9817:168::-;9857:7;9923:1;9919;9915:6;9911:14;9908:1;9905:21;9900:1;9893:9;9886:17;9882:45;9879:2;;;9930:18;;:::i;:::-;-1:-1:-1;9970:9:1;;9869:116::o;9990:125::-;10030:4;10058:1;10055;10052:8;10049:2;;;10063:18;;:::i;:::-;-1:-1:-1;10100:9:1;;10039:76::o;10120:380::-;10199:1;10195:12;;;;10242;;;10263:2;;10317:4;10309:6;10305:17;10295:27;;10263:2;10370;10362:6;10359:14;10339:18;10336:38;10333:2;;;10416:10;10411:3;10407:20;10404:1;10397:31;10451:4;10448:1;10441:15;10479:4;10476:1;10469:15;10333:2;;10175:325;;;:::o;10505:127::-;10566:10;10561:3;10557:20;10554:1;10547:31;10597:4;10594:1;10587:15;10621:4;10618:1;10611:15;10637:131;-1:-1:-1;;;;;10712:31:1;;10702:42;;10692:2;;10758:1;10755;10748:12

Swarm Source

ipfs://fed4c0855635576f58e04b4adb9b1d9341d3b5299b69866cd0c5524a0b806e1e
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.