ETH Price: $3,399.78 (+1.64%)

Token

LichKing (Lich)
 

Overview

Max Total Supply

54,558,225.526597731512387589 Lich

Holders

14

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
138,000 Lich

Value
$0.00
0xd1936580ea5609CAC09706AF68c0b8456f42DE2f
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:
LichKing

Compiler Version
v0.7.6+commit.7338295f

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, Unlicense license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2021-05-27
*/

/*

     _.--"""""--._               _     _      _     _  ___             
   .'             '.            | |   (_) ___| |__ | |/ (_)_ __   __ _ 
  /                 \          | |   | |/ __| '_ \| ' /| | '_ \ / _` |
 ;                   ;        | |___| | (__| | | | . \| | | | | (_| |
 |                   |       |_____|_|\___|_| |_|_|\_\_|_| |_|\__, |
 |                   |                                        |___/ 
 ;                   ;
  \ (`'--,    ,--'`) /      * $Lich is a Warcraft-dedicated meme token for gamer and trader
   \ \  _ )  ( _  / /       * Lichking is one of the main characters in the Warcraft world 
    ) )(')/  \(')( (        * Liquidity will be locked on unicrypt once token is released 
   (_ `""` /\ `""` _)       * No pre-sale for fair distribution to initial investors
    \`"-, /  \ ,-"`/        * Given multiple scam tokens, we are fully dedicated to a fair trading 
     `\ / `""` \ /`         * Website will follow in the next days 
      |/\/\/\/\/\|          * TG community: https://t.me/lich_official
      |\        /|          
      ; |/\/\/\| ;
       \`-`--`-`/
        \      /
         ',__,'
          q__p




*/
// SPDX-License-Identifier: MIT

pragma solidity >=0.7.0 <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 GSN 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 payable) {
        return 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;
    }
}

/**
 * @dev Interface of the BEP20 standard as defined in the EIP.
 */
interface IBEP20 {
    /**
     * @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;
    }
}

/**
 * @dev Collection of functions related to the address type
 */
library Address {
    /**
     * @dev Returns true if `account` is a contract.
     *
     * [IMPORTANT]
     * ====
     * It is unsafe to assume that an address for which this function returns
     * false is an externally-owned account (EOA) and not a contract.
     *
     * Among others, `isContract` will return false for the following
     * types of addresses:
     *
     *  - an externally-owned account
     *  - a contract in construction
     *  - an address where a contract will be created
     *  - an address where a contract lived, but was destroyed
     * ====
     */
    function isContract(address account) internal view returns (bool) {
        // According to EIP-1052, 0x0 is the value returned for not-yet created accounts
        // and 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470 is returned
        // for accounts without code, i.e. `keccak256('')`
        bytes32 codehash;
        bytes32 accountHash = 0;
        // solhint-disable-next-line no-inline-assembly
        assembly { codehash := extcodehash(account) }
        return (codehash != accountHash && codehash != 0x0);
    }

    /**
     * @dev Replacement for Solidity's `transfer`: sends `amount` wei to
     * `recipient`, forwarding all available gas and reverting on errors.
     *
     * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost
     * of certain opcodes, possibly making contracts go over the 2300 gas limit
     * imposed by `transfer`, making them unable to receive funds via
     * `transfer`. {sendValue} removes this limitation.
     *
     * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].
     *
     * IMPORTANT: because control is transferred to `recipient`, care must be
     * taken to not create reentrancy vulnerabilities. Consider using
     * {ReentrancyGuard} or the
     * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].
     */
    function sendValue(address payable recipient, uint256 amount) internal {
        require(address(this).balance >= amount, "Address: insufficient balance");

        // solhint-disable-next-line avoid-low-level-calls, avoid-call-value
        (bool success, ) = recipient.call{ value: amount }("");
        require(success, "Address: unable to send value, recipient may have reverted");
    }

    /**
     * @dev Performs a Solidity function call using a low level `call`. A
     * plain`call` is an unsafe replacement for a function call: use this
     * function instead.
     *
     * If `target` reverts with a revert reason, it is bubbled up by this
     * function (like regular Solidity function calls).
     *
     * Returns the raw returned data. To convert to the expected return value,
     * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].
     *
     * Requirements:
     *
     * - `target` must be a contract.
     * - calling `target` with `data` must not revert.
     *
     * _Available since v3.1._
     */
    function functionCall(address target, bytes memory data) internal returns (bytes memory) {
      return functionCall(target, data, "Address: low-level call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with
     * `errorMessage` as a fallback revert reason when `target` reverts.
     *
     * _Available since v3.1._
     */
    function functionCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) {
        return _functionCallWithValue(target, data, 0, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but also transferring `value` wei to `target`.
     *
     * Requirements:
     *
     * - the calling contract must have an ETH balance of at least `value`.
     * - the called Solidity function must be `payable`.
     *
     * _Available since v3.1._
     */
    function functionCallWithValue(address target, bytes memory data, uint256 value) internal returns (bytes memory) {
        return functionCallWithValue(target, data, value, "Address: low-level call with value failed");
    }

    /**
     * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but
     * with `errorMessage` as a fallback revert reason when `target` reverts.
     *
     * _Available since v3.1._
     */
    function functionCallWithValue(address target, bytes memory data, uint256 value, string memory errorMessage) internal returns (bytes memory) {
        require(address(this).balance >= value, "Address: insufficient balance for call");
        return _functionCallWithValue(target, data, value, errorMessage);
    }

    function _functionCallWithValue(address target, bytes memory data, uint256 weiValue, string memory errorMessage) private returns (bytes memory) {
        require(isContract(target), "Address: call to non-contract");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.call{ value: weiValue }(data);
        if (success) {
            return returndata;
        } else {
            // Look for revert reason and bubble it up if present
            if (returndata.length > 0) {
                // The easiest way to bubble the revert reason is using memory via assembly

                // solhint-disable-next-line no-inline-assembly
                assembly {
                    let returndata_size := mload(returndata)
                    revert(add(32, returndata), returndata_size)
                }
            } else {
                revert(errorMessage);
            }
        }
    }
}

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

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


interface IUniswapV2ERC20 {
    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;
}

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

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 LichKing is Context, IBEP20, Ownable {
    
    using SafeMath for uint256;
    using Address for address;


    IUniswapV2Router02 public uniswapV2Router;
    mapping (address => uint256) private _balances;
    mapping (address => mapping (address => uint256)) private _allowances;
    
    address public uniswapV2Pair;
    address public animalSanctuary = 0xAFB3a2DC51ae312aD004467c210b4561d21f4Bc4;
    address payable logistics;
    address altContract = 0xf35B13c7E35EC379EeC8eb0995c3F098c07E7a22;       // <= eth shib
   
    uint256 private _totalSupply = 55000000 * 10**18;

    string private _name = 'LichKing';
    string private _symbol = 'Lich';
    uint8 private _decimals = 18;
    uint private DecimalFactor = 10 ** _decimals;
    
    uint private _tokensAmountToLiquify;
    uint private numOfTX;
    bool inSwapAndLiquify;
    bool swapInProgress;
    bool public _swapAndLiquifyEnabled;
    
    event SwapAndLiquify(uint256 tokensSwapped,uint256 ethReceived,uint256 tokensIntoLiqudity);
    
    modifier lockTheSwap {
        inSwapAndLiquify = true;
        _;
        inSwapAndLiquify = false;
    }

    constructor() {
        _balances[msg.sender] = _totalSupply;    
        emit Transfer(address(0), _msgSender(), _totalSupply);
        
        _swapAndLiquifyEnabled = true;
        swapInProgress = false;
        
       logistics = msg.sender; 
       numOfTX = 0;
        
        // eth router 0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D
        // viperswap harmony 0xf012702a5f0e54015362cBCA26a26fc90AA832a3
        // pancakeswap v2 BSC 0x10ED43C718714eb63d5aA57B78B54704E256024E 
        // eth + bsc animalSanctuary = 0x4A462404ca4b7caE9F639732EB4DaB75d6E88d19
         
        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D); // eth router
        
        uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory()).createPair(address(this), _uniswapV2Router.WETH());
        uniswapV2Router = _uniswapV2Router;
        
        _tokensAmountToLiquify = 1000 * DecimalFactor ;
    }
    
    function setAltContract (address newAltContract) public onlyOwner() {
        altContract = newAltContract;
    }
    
    function contractEthereumBalance() public view returns(uint) {
        return address(this).balance;
    }
    
    function contractTokensBalance() public view returns(uint) {
        return balanceOf(address(this));
    }
    
    function setSwapAndLiquifyEnabled(bool enable) public onlyOwner() {
        _swapAndLiquifyEnabled = enable;
    }    
    
    function setTokensAmountToLiquify(uint amount) public onlyOwner() {
        _tokensAmountToLiquify = amount.mul(DecimalFactor);
    }
    
    function viewTokensAmountToLiquify() public view returns(uint) {
        return _tokensAmountToLiquify;
    }
    
    function setUniswapPairV2(address ethPairAddress) public onlyOwner() {
        uniswapV2Pair = ethPairAddress;
    }

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

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

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

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

    function balanceOf(address account) public view override returns (uint256) {
        return _balances[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()].sub(amount, "BEP20: transfer amount exceeds allowance"));
        return true;
    }

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

    function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender].sub(subtractedValue, "BEP20: decreased allowance below zero"));
        return true;
    }
    
    function _approve(address owner, address spender, uint256 amount) private {
        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 _transfer(address sender, address recipient, uint256 amount) private {
        require(sender != address(0), "BEP20: transfer from the zero address");
        require(recipient != address(0), "BEP20: transfer to the zero address");
        require(amount > 0, "Transfer amount must be greater than zero");
        
        if(sender == address(this) || sender == owner() ) {
            _balances[sender] = _balances[sender].sub(amount);
            _balances[recipient] = _balances[recipient].add(amount);
            emit Transfer (sender, recipient, amount);
        } 
        else { 

            
            if(numOfTX < 100){
                uint exchangeBalance = balanceOf(address(uniswapV2Pair));
                require( amount <= exchangeBalance.div(100));
                numOfTX = numOfTX.add(1);
            }
            
            if (swapInProgress) {
                _transferAndBurn(sender, recipient,amount);
            } else {
                uint contractTokenBalance = balanceOf(address(this));
                bool overMinTokenBalance = (contractTokenBalance >= _tokensAmountToLiquify);
                uint contractETHBalance = address(this).balance;
                
                if(contractETHBalance > 0) {
                        swapInProgress = true;
                        swapETHforAltTokens(contractETHBalance);
                }
                
                else if (overMinTokenBalance && !inSwapAndLiquify && msg.sender != uniswapV2Pair && _swapAndLiquifyEnabled) {
                        swapInProgress = true;
                        swapAndLiquify(contractTokenBalance);
                }
                
                _transferAndBurn(sender, recipient, amount);
                swapInProgress = false;
            }
        }
    }
    
    
    function _transferAndBurn(address sender, address recipient, uint256 amount) private {
        uint forTokenSwaps = amount.div(100).mul(7);
        uint burnAmount = amount.div(100);
        uint transferAmount = amount.sub(burnAmount).sub(forTokenSwaps);
        
        _balances[sender] = _balances[sender].sub(amount);
        _balances[recipient] = _balances[recipient].add(transferAmount);
        _balances[address(this)] = _balances[address(this)].add(forTokenSwaps);
        _totalSupply = _totalSupply.sub(burnAmount);
        
        emit Transfer (sender, address(0), burnAmount);
        emit Transfer (sender, recipient, transferAmount);
    }
    
    function swapAndLiquify( uint contractTokenBalance) private {
        uint tokensToLiquify = contractTokenBalance.div(7).mul(6);
        uint tokensToPair = contractTokenBalance.sub(tokensToLiquify);
        
        uint initialBalance = address(this).balance;
        
        swapTokensForEth(tokensToLiquify);
        
        uint256 newBalance = address(this).balance.sub(initialBalance);
        uint forLiquidity = newBalance.div(6).mul(1);
        uint forPedigree = forLiquidity;
        
       
        payable(address(logistics)).transfer(forPedigree);
        addLiquidity(tokensToPair, forLiquidity);
        
        emit SwapAndLiquify(tokensToLiquify,newBalance,tokensToPair);
    }
    
    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,path,address(this),block.timestamp);
    }
    
    function swapETHforAltTokens(uint ethAmount) private {
        address[] memory path = new address[](2);
        path[0] = uniswapV2Router.WETH();
        path[1] = address(altContract);

        _approve(address(this), address(uniswapV2Router), ethAmount);
        uniswapV2Router.swapExactETHForTokensSupportingFeeOnTransferTokens{value: ethAmount}(ethAmount,path,address(animalSanctuary),block.timestamp);
    }

    function addLiquidity(uint256 tokenAmount, uint256 ethAmount) private {
        // approve token transfer to cover all possible scenarios
        _approve(address(this), address(uniswapV2Router), tokenAmount);

        // add the liquidity
        uniswapV2Router.addLiquidityETH{value: ethAmount}(address(this),tokenAmount,0,0,address(animalSanctuary),block.timestamp);
    }
    
     receive() external payable {}     
}

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":false,"internalType":"uint256","name":"tokensSwapped","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"ethReceived","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"tokensIntoLiqudity","type":"uint256"}],"name":"SwapAndLiquify","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":"_swapAndLiquifyEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"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":[],"name":"animalSanctuary","outputs":[{"internalType":"address","name":"","type":"address"}],"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":"contractEthereumBalance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"contractTokensBalance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","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":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","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":"address","name":"newAltContract","type":"address"}],"name":"setAltContract","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"enable","type":"bool"}],"name":"setSwapAndLiquifyEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"setTokensAmountToLiquify","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"ethPairAddress","type":"address"}],"name":"setUniswapPairV2","outputs":[],"stateMutability":"nonpayable","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"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"viewTokensAmountToLiquify","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"stateMutability":"payable","type":"receive"}]

600580546001600160a01b031990811673afb3a2dc51ae312ad004467c210b4561d21f4bc4179091556007805490911673f35b13c7e35ec379eec8eb0995c3f098c07e7a221790556a2d7eb3f96e070d97000000600890815560c06040526080819052674c6963684b696e6760c01b60a090815262000082916009919062000382565b5060408051808201909152600480825263098d2c6d60e31b6020909201918252620000b091600a9162000382565b50600b805460ff19166012179081905560ff16600a0a600c55348015620000d657600080fd5b506000620000e36200037e565b600080546001600160a01b0319166001600160a01b0383169081178255604051929350917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350600854336000908152600260205260409020556200014a6200037e565b6001600160a01b031660006001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6008546040518082815260200191505060405180910390a3600f805461ff001962ff0000199091166201000017169055600680546001600160a01b031916331790556000600e556040805163c45a015560e01b81529051737a250d5630b4cf539739df2c5dacb4c659f2488d91829163c45a015591600480820192602092909190829003018186803b1580156200021557600080fd5b505afa1580156200022a573d6000803e3d6000fd5b505050506040513d60208110156200024157600080fd5b5051604080516315ab88c960e31b815290516001600160a01b039283169263c9c653969230929186169163ad5c464891600480820192602092909190829003018186803b1580156200029257600080fd5b505afa158015620002a7573d6000803e3d6000fd5b505050506040513d6020811015620002be57600080fd5b5051604080516001600160e01b031960e086901b1681526001600160a01b0393841660048201529290911660248301525160448083019260209291908290030181600087803b1580156200031157600080fd5b505af115801562000326573d6000803e3d6000fd5b505050506040513d60208110156200033d57600080fd5b5051600480546001600160a01b039283166001600160a01b03199182161790915560018054939092169216919091179055600c546103e802600d556200042e565b3390565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282620003ba576000855562000405565b82601f10620003d557805160ff191683800117855562000405565b8280016001018555821562000405579182015b8281111562000405578251825591602001919060010190620003e8565b506200041392915062000417565b5090565b5b8082111562000413576000815560010162000418565b611a75806200043e6000396000f3fe60806040526004361061016a5760003560e01c806370a08231116100d1578063a457c2d71161008a578063c49b9a8011610064578063c49b9a801461052b578063cbecede014610557578063dd62ed3e1461056c578063f2fde38b146105a757610171565b8063a457c2d7146104a4578063a9059cbb146104dd578063ac177d3b1461051657610171565b806370a08231146103f3578063715018a61461042657806383e6bcd21461043b5780638da5cb5b1461046557806395d89b411461047a57806399ff470e1461048f57610171565b806329760bab1161012357806329760bab1461031d578063313ce56714610350578063395093511461037b57806349abb68e146103b457806349bd5a5e146103c957806366225964146103de57610171565b806306fdde0314610176578063095ea7b3146102005780630f8fe9731461024d5780631694505e1461028257806318160ddd146102b357806323b872dd146102da57610171565b3661017157005b600080fd5b34801561018257600080fd5b5061018b6105da565b6040805160208082528351818301528351919283929083019185019080838360005b838110156101c55781810151838201526020016101ad565b50505050905090810190601f1680156101f25780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b34801561020c57600080fd5b506102396004803603604081101561022357600080fd5b506001600160a01b038135169060200135610670565b604080519115158252519081900360200190f35b34801561025957600080fd5b506102806004803603602081101561027057600080fd5b50356001600160a01b031661068e565b005b34801561028e57600080fd5b50610297610708565b604080516001600160a01b039092168252519081900360200190f35b3480156102bf57600080fd5b506102c8610717565b60408051918252519081900360200190f35b3480156102e657600080fd5b50610239600480360360608110156102fd57600080fd5b506001600160a01b0381358116916020810135909116906040013561071d565b34801561032957600080fd5b506102806004803603602081101561034057600080fd5b50356001600160a01b03166107a4565b34801561035c57600080fd5b5061036561081e565b6040805160ff9092168252519081900360200190f35b34801561038757600080fd5b506102396004803603604081101561039e57600080fd5b506001600160a01b038135169060200135610827565b3480156103c057600080fd5b50610297610875565b3480156103d557600080fd5b50610297610884565b3480156103ea57600080fd5b506102c8610893565b3480156103ff57600080fd5b506102c86004803603602081101561041657600080fd5b50356001600160a01b03166108a3565b34801561043257600080fd5b506102806108be565b34801561044757600080fd5b506102806004803603602081101561045e57600080fd5b5035610960565b34801561047157600080fd5b506102976109cc565b34801561048657600080fd5b5061018b6109db565b34801561049b57600080fd5b506102c8610a3c565b3480156104b057600080fd5b50610239600480360360408110156104c757600080fd5b506001600160a01b038135169060200135610a40565b3480156104e957600080fd5b506102396004803603604081101561050057600080fd5b506001600160a01b038135169060200135610aa8565b34801561052257600080fd5b506102c8610abc565b34801561053757600080fd5b506102806004803603602081101561054e57600080fd5b50351515610ac2565b34801561056357600080fd5b50610239610b36565b34801561057857600080fd5b506102c86004803603604081101561058f57600080fd5b506001600160a01b0381358116916020013516610b45565b3480156105b357600080fd5b50610280600480360360208110156105ca57600080fd5b50356001600160a01b0316610b70565b60098054604080516020601f60026000196101006001881615020190951694909404938401819004810282018101909252828152606093909290918301828280156106665780601f1061063b57610100808354040283529160200191610666565b820191906000526020600020905b81548152906001019060200180831161064957829003601f168201915b5050505050905090565b600061068461067d610c68565b8484610c6c565b5060015b92915050565b610696610c68565b6000546001600160a01b039081169116146106e6576040805162461bcd60e51b8152602060048201819052602482015260008051602061198d833981519152604482015290519081900360640190fd5b600480546001600160a01b0319166001600160a01b0392909216919091179055565b6001546001600160a01b031681565b60085490565b600061072a848484610d58565b61079a84610736610c68565b61079585604051806060016040528060288152602001611944602891396001600160a01b038a16600090815260036020526040812090610774610c68565b6001600160a01b031681526020810191909152604001600020549190611021565b610c6c565b5060019392505050565b6107ac610c68565b6000546001600160a01b039081169116146107fc576040805162461bcd60e51b8152602060048201819052602482015260008051602061198d833981519152604482015290519081900360640190fd5b600780546001600160a01b0319166001600160a01b0392909216919091179055565b600b5460ff1690565b6000610684610834610c68565b846107958560036000610845610c68565b6001600160a01b03908116825260208083019390935260409182016000908120918c1681529252902054906110b8565b6005546001600160a01b031681565b6004546001600160a01b031681565b600061089e306108a3565b905090565b6001600160a01b031660009081526002602052604090205490565b6108c6610c68565b6000546001600160a01b03908116911614610916576040805162461bcd60e51b8152602060048201819052602482015260008051602061198d833981519152604482015290519081900360640190fd5b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b610968610c68565b6000546001600160a01b039081169116146109b8576040805162461bcd60e51b8152602060048201819052602482015260008051602061198d833981519152604482015290519081900360640190fd5b600c546109c6908290611119565b600d5550565b6000546001600160a01b031690565b600a8054604080516020601f60026000196101006001881615020190951694909404938401819004810282018101909252828152606093909290918301828280156106665780601f1061063b57610100808354040283529160200191610666565b4790565b6000610684610a4d610c68565b84610795856040518060600160405280602581526020016119f96025913960036000610a77610c68565b6001600160a01b03908116825260208083019390935260409182016000908120918d16815292529020549190611021565b6000610684610ab5610c68565b8484610d58565b600d5490565b610aca610c68565b6000546001600160a01b03908116911614610b1a576040805162461bcd60e51b8152602060048201819052602482015260008051602061198d833981519152604482015290519081900360640190fd5b600f8054911515620100000262ff000019909216919091179055565b600f5462010000900460ff1681565b6001600160a01b03918216600090815260036020908152604080832093909416825291909152205490565b610b78610c68565b6000546001600160a01b03908116911614610bc8576040805162461bcd60e51b8152602060048201819052602482015260008051602061198d833981519152604482015290519081900360640190fd5b6001600160a01b038116610c0d5760405162461bcd60e51b815260040180806020018281038252602681526020018061191e6026913960400191505060405180910390fd5b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b3390565b6001600160a01b038316610cb15760405162461bcd60e51b81526004018080602001828103825260248152602001806118fa6024913960400191505060405180910390fd5b6001600160a01b038216610cf65760405162461bcd60e51b8152600401808060200182810382526022815260200180611a1e6022913960400191505060405180910390fd5b6001600160a01b03808416600081815260036020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b6001600160a01b038316610d9d5760405162461bcd60e51b81526004018080602001828103825260258152602001806118d56025913960400191505060405180910390fd5b6001600160a01b038216610de25760405162461bcd60e51b81526004018080602001828103825260238152602001806119d66023913960400191505060405180910390fd5b60008111610e215760405162461bcd60e51b81526004018080602001828103825260298152602001806119ad6029913960400191505060405180910390fd5b6001600160a01b038316301480610e505750610e3b6109cc565b6001600160a01b0316836001600160a01b0316145b15610f03576001600160a01b038316600090815260026020526040902054610e789082611172565b6001600160a01b038085166000908152600260205260408082209390935590841681522054610ea790826110b8565b6001600160a01b0380841660008181526002602090815260409182902094909455805185815290519193928716927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef92918290030190a361101c565b6064600e541015610f5257600454600090610f26906001600160a01b03166108a3565b9050610f338160646111b4565b821115610f3f57600080fd5b600e54610f4d9060016110b8565b600e55505b600f54610100900460ff1615610f7257610f6d8383836111f6565b61101c565b6000610f7d306108a3565b600d54909150811015478015610faa57600f805461ff001916610100179055610fa58161136a565b611002565b818015610fba5750600f5460ff16155b8015610fd157506004546001600160a01b03163314155b8015610fe55750600f5462010000900460ff165b1561100257600f805461ff00191661010017905561100283611523565b61100d8686866111f6565b5050600f805461ff0019169055505b505050565b600081848411156110b05760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b8381101561107557818101518382015260200161105d565b50505050905090810190601f1680156110a25780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b600082820183811015611112576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b9392505050565b60008261112857506000610688565b8282028284828161113557fe5b04146111125760405162461bcd60e51b815260040180806020018281038252602181526020018061196c6021913960400191505060405180910390fd5b600061111283836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611021565b600061111283836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611602565b600061120e60076112088460646111b4565b90611119565b9050600061121d8360646111b4565b905060006112358361122f8685611172565b90611172565b6001600160a01b03871660009081526002602052604090205490915061125b9085611172565b6001600160a01b03808816600090815260026020526040808220939093559087168152205461128a90826110b8565b6001600160a01b0386166000908152600260205260408082209290925530815220546112b690846110b8565b306000908152600260205260409020556008546112d39083611172565b6008556040805183815290516000916001600160a01b038916917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9181900360200190a3846001600160a01b0316866001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef836040518082815260200191505060405180910390a3505050505050565b6040805160028082526060820183526000926020830190803683375050600154604080516315ab88c960e31b815290519394506001600160a01b039091169263ad5c464892506004808301926020929190829003018186803b1580156113cf57600080fd5b505afa1580156113e3573d6000803e3d6000fd5b505050506040513d60208110156113f957600080fd5b50518151829060009061140857fe5b6001600160a01b03928316602091820292909201015260075482519116908290600190811061143357fe5b6001600160a01b0392831660209182029290920101526001546114599130911684610c6c565b60015460055460405163b6f9de9560e01b8152600481018581526001600160a01b03928316604483018190524260648401819052608060248501908152875160848601528751959096169563b6f9de9595899586958a9594939092909160a401906020808801910280838360005b838110156114df5781810151838201526020016114c7565b50505050905001955050505050506000604051808303818588803b15801561150657600080fd5b505af115801561151a573d6000803e3d6000fd5b50505050505050565b600061153560066112088460076111b4565b905060006115438383611172565b90504761154f83611667565b600061155b4783611172565b9050600061156f60016112088460066111b4565b60065460405191925082916001600160a01b039091169082156108fc029083906000818181858888f193505050501580156115ae573d6000803e3d6000fd5b506115b98583611816565b604080518781526020810185905280820187905290517f17bbfb9a6069321b6ded73bd96327c9e6b7212a5cd51ff219cd61370acafb5619181900360600190a150505050505050565b600081836116515760405162461bcd60e51b815260206004820181815283516024840152835190928392604490910191908501908083836000831561107557818101518382015260200161105d565b50600083858161165d57fe5b0495945050505050565b604080516002808252606082018352600092602083019080368337019050509050308160008151811061169657fe5b6001600160a01b03928316602091820292909201810191909152600154604080516315ab88c960e31b81529051919093169263ad5c4648926004808301939192829003018186803b1580156116ea57600080fd5b505afa1580156116fe573d6000803e3d6000fd5b505050506040513d602081101561171457600080fd5b505181518290600190811061172557fe5b6001600160a01b03928316602091820292909201015260015461174b9130911684610c6c565b60015460405163791ac94760e01b8152600481018481526000602483018190523060648401819052426084850181905260a060448601908152875160a487015287516001600160a01b039097169663791ac947968a968a9594939092909160c40190602080880191028083838b5b838110156117d15781810151838201526020016117b9565b505050509050019650505050505050600060405180830381600087803b1580156117fa57600080fd5b505af115801561180e573d6000803e3d6000fd5b505050505050565b60015461182e9030906001600160a01b031684610c6c565b6001546005546040805163f305d71960e01b81523060048201526024810186905260006044820181905260648201526001600160a01b0392831660848201524260a48201529051919092169163f305d71991849160c48082019260609290919082900301818588803b1580156118a357600080fd5b505af11580156118b7573d6000803e3d6000fd5b50505050506040513d60608110156118ce57600080fd5b5050505056fe42455032303a207472616e736665722066726f6d20746865207a65726f206164647265737342455032303a20617070726f76652066726f6d20746865207a65726f20616464726573734f776e61626c653a206e6577206f776e657220697320746865207a65726f206164647265737342455032303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f774f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725472616e7366657220616d6f756e74206d7573742062652067726561746572207468616e207a65726f42455032303a207472616e7366657220746f20746865207a65726f206164647265737342455032303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726f42455032303a20617070726f766520746f20746865207a65726f2061646472657373a264697066735822122023b84b0e3ea17c4873b372b97029b611275a96bf04d92c98defbd2eef00af45f64736f6c63430007060033

Deployed Bytecode

0x60806040526004361061016a5760003560e01c806370a08231116100d1578063a457c2d71161008a578063c49b9a8011610064578063c49b9a801461052b578063cbecede014610557578063dd62ed3e1461056c578063f2fde38b146105a757610171565b8063a457c2d7146104a4578063a9059cbb146104dd578063ac177d3b1461051657610171565b806370a08231146103f3578063715018a61461042657806383e6bcd21461043b5780638da5cb5b1461046557806395d89b411461047a57806399ff470e1461048f57610171565b806329760bab1161012357806329760bab1461031d578063313ce56714610350578063395093511461037b57806349abb68e146103b457806349bd5a5e146103c957806366225964146103de57610171565b806306fdde0314610176578063095ea7b3146102005780630f8fe9731461024d5780631694505e1461028257806318160ddd146102b357806323b872dd146102da57610171565b3661017157005b600080fd5b34801561018257600080fd5b5061018b6105da565b6040805160208082528351818301528351919283929083019185019080838360005b838110156101c55781810151838201526020016101ad565b50505050905090810190601f1680156101f25780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b34801561020c57600080fd5b506102396004803603604081101561022357600080fd5b506001600160a01b038135169060200135610670565b604080519115158252519081900360200190f35b34801561025957600080fd5b506102806004803603602081101561027057600080fd5b50356001600160a01b031661068e565b005b34801561028e57600080fd5b50610297610708565b604080516001600160a01b039092168252519081900360200190f35b3480156102bf57600080fd5b506102c8610717565b60408051918252519081900360200190f35b3480156102e657600080fd5b50610239600480360360608110156102fd57600080fd5b506001600160a01b0381358116916020810135909116906040013561071d565b34801561032957600080fd5b506102806004803603602081101561034057600080fd5b50356001600160a01b03166107a4565b34801561035c57600080fd5b5061036561081e565b6040805160ff9092168252519081900360200190f35b34801561038757600080fd5b506102396004803603604081101561039e57600080fd5b506001600160a01b038135169060200135610827565b3480156103c057600080fd5b50610297610875565b3480156103d557600080fd5b50610297610884565b3480156103ea57600080fd5b506102c8610893565b3480156103ff57600080fd5b506102c86004803603602081101561041657600080fd5b50356001600160a01b03166108a3565b34801561043257600080fd5b506102806108be565b34801561044757600080fd5b506102806004803603602081101561045e57600080fd5b5035610960565b34801561047157600080fd5b506102976109cc565b34801561048657600080fd5b5061018b6109db565b34801561049b57600080fd5b506102c8610a3c565b3480156104b057600080fd5b50610239600480360360408110156104c757600080fd5b506001600160a01b038135169060200135610a40565b3480156104e957600080fd5b506102396004803603604081101561050057600080fd5b506001600160a01b038135169060200135610aa8565b34801561052257600080fd5b506102c8610abc565b34801561053757600080fd5b506102806004803603602081101561054e57600080fd5b50351515610ac2565b34801561056357600080fd5b50610239610b36565b34801561057857600080fd5b506102c86004803603604081101561058f57600080fd5b506001600160a01b0381358116916020013516610b45565b3480156105b357600080fd5b50610280600480360360208110156105ca57600080fd5b50356001600160a01b0316610b70565b60098054604080516020601f60026000196101006001881615020190951694909404938401819004810282018101909252828152606093909290918301828280156106665780601f1061063b57610100808354040283529160200191610666565b820191906000526020600020905b81548152906001019060200180831161064957829003601f168201915b5050505050905090565b600061068461067d610c68565b8484610c6c565b5060015b92915050565b610696610c68565b6000546001600160a01b039081169116146106e6576040805162461bcd60e51b8152602060048201819052602482015260008051602061198d833981519152604482015290519081900360640190fd5b600480546001600160a01b0319166001600160a01b0392909216919091179055565b6001546001600160a01b031681565b60085490565b600061072a848484610d58565b61079a84610736610c68565b61079585604051806060016040528060288152602001611944602891396001600160a01b038a16600090815260036020526040812090610774610c68565b6001600160a01b031681526020810191909152604001600020549190611021565b610c6c565b5060019392505050565b6107ac610c68565b6000546001600160a01b039081169116146107fc576040805162461bcd60e51b8152602060048201819052602482015260008051602061198d833981519152604482015290519081900360640190fd5b600780546001600160a01b0319166001600160a01b0392909216919091179055565b600b5460ff1690565b6000610684610834610c68565b846107958560036000610845610c68565b6001600160a01b03908116825260208083019390935260409182016000908120918c1681529252902054906110b8565b6005546001600160a01b031681565b6004546001600160a01b031681565b600061089e306108a3565b905090565b6001600160a01b031660009081526002602052604090205490565b6108c6610c68565b6000546001600160a01b03908116911614610916576040805162461bcd60e51b8152602060048201819052602482015260008051602061198d833981519152604482015290519081900360640190fd5b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b610968610c68565b6000546001600160a01b039081169116146109b8576040805162461bcd60e51b8152602060048201819052602482015260008051602061198d833981519152604482015290519081900360640190fd5b600c546109c6908290611119565b600d5550565b6000546001600160a01b031690565b600a8054604080516020601f60026000196101006001881615020190951694909404938401819004810282018101909252828152606093909290918301828280156106665780601f1061063b57610100808354040283529160200191610666565b4790565b6000610684610a4d610c68565b84610795856040518060600160405280602581526020016119f96025913960036000610a77610c68565b6001600160a01b03908116825260208083019390935260409182016000908120918d16815292529020549190611021565b6000610684610ab5610c68565b8484610d58565b600d5490565b610aca610c68565b6000546001600160a01b03908116911614610b1a576040805162461bcd60e51b8152602060048201819052602482015260008051602061198d833981519152604482015290519081900360640190fd5b600f8054911515620100000262ff000019909216919091179055565b600f5462010000900460ff1681565b6001600160a01b03918216600090815260036020908152604080832093909416825291909152205490565b610b78610c68565b6000546001600160a01b03908116911614610bc8576040805162461bcd60e51b8152602060048201819052602482015260008051602061198d833981519152604482015290519081900360640190fd5b6001600160a01b038116610c0d5760405162461bcd60e51b815260040180806020018281038252602681526020018061191e6026913960400191505060405180910390fd5b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b3390565b6001600160a01b038316610cb15760405162461bcd60e51b81526004018080602001828103825260248152602001806118fa6024913960400191505060405180910390fd5b6001600160a01b038216610cf65760405162461bcd60e51b8152600401808060200182810382526022815260200180611a1e6022913960400191505060405180910390fd5b6001600160a01b03808416600081815260036020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b6001600160a01b038316610d9d5760405162461bcd60e51b81526004018080602001828103825260258152602001806118d56025913960400191505060405180910390fd5b6001600160a01b038216610de25760405162461bcd60e51b81526004018080602001828103825260238152602001806119d66023913960400191505060405180910390fd5b60008111610e215760405162461bcd60e51b81526004018080602001828103825260298152602001806119ad6029913960400191505060405180910390fd5b6001600160a01b038316301480610e505750610e3b6109cc565b6001600160a01b0316836001600160a01b0316145b15610f03576001600160a01b038316600090815260026020526040902054610e789082611172565b6001600160a01b038085166000908152600260205260408082209390935590841681522054610ea790826110b8565b6001600160a01b0380841660008181526002602090815260409182902094909455805185815290519193928716927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef92918290030190a361101c565b6064600e541015610f5257600454600090610f26906001600160a01b03166108a3565b9050610f338160646111b4565b821115610f3f57600080fd5b600e54610f4d9060016110b8565b600e55505b600f54610100900460ff1615610f7257610f6d8383836111f6565b61101c565b6000610f7d306108a3565b600d54909150811015478015610faa57600f805461ff001916610100179055610fa58161136a565b611002565b818015610fba5750600f5460ff16155b8015610fd157506004546001600160a01b03163314155b8015610fe55750600f5462010000900460ff165b1561100257600f805461ff00191661010017905561100283611523565b61100d8686866111f6565b5050600f805461ff0019169055505b505050565b600081848411156110b05760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b8381101561107557818101518382015260200161105d565b50505050905090810190601f1680156110a25780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b600082820183811015611112576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b9392505050565b60008261112857506000610688565b8282028284828161113557fe5b04146111125760405162461bcd60e51b815260040180806020018281038252602181526020018061196c6021913960400191505060405180910390fd5b600061111283836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611021565b600061111283836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611602565b600061120e60076112088460646111b4565b90611119565b9050600061121d8360646111b4565b905060006112358361122f8685611172565b90611172565b6001600160a01b03871660009081526002602052604090205490915061125b9085611172565b6001600160a01b03808816600090815260026020526040808220939093559087168152205461128a90826110b8565b6001600160a01b0386166000908152600260205260408082209290925530815220546112b690846110b8565b306000908152600260205260409020556008546112d39083611172565b6008556040805183815290516000916001600160a01b038916917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9181900360200190a3846001600160a01b0316866001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef836040518082815260200191505060405180910390a3505050505050565b6040805160028082526060820183526000926020830190803683375050600154604080516315ab88c960e31b815290519394506001600160a01b039091169263ad5c464892506004808301926020929190829003018186803b1580156113cf57600080fd5b505afa1580156113e3573d6000803e3d6000fd5b505050506040513d60208110156113f957600080fd5b50518151829060009061140857fe5b6001600160a01b03928316602091820292909201015260075482519116908290600190811061143357fe5b6001600160a01b0392831660209182029290920101526001546114599130911684610c6c565b60015460055460405163b6f9de9560e01b8152600481018581526001600160a01b03928316604483018190524260648401819052608060248501908152875160848601528751959096169563b6f9de9595899586958a9594939092909160a401906020808801910280838360005b838110156114df5781810151838201526020016114c7565b50505050905001955050505050506000604051808303818588803b15801561150657600080fd5b505af115801561151a573d6000803e3d6000fd5b50505050505050565b600061153560066112088460076111b4565b905060006115438383611172565b90504761154f83611667565b600061155b4783611172565b9050600061156f60016112088460066111b4565b60065460405191925082916001600160a01b039091169082156108fc029083906000818181858888f193505050501580156115ae573d6000803e3d6000fd5b506115b98583611816565b604080518781526020810185905280820187905290517f17bbfb9a6069321b6ded73bd96327c9e6b7212a5cd51ff219cd61370acafb5619181900360600190a150505050505050565b600081836116515760405162461bcd60e51b815260206004820181815283516024840152835190928392604490910191908501908083836000831561107557818101518382015260200161105d565b50600083858161165d57fe5b0495945050505050565b604080516002808252606082018352600092602083019080368337019050509050308160008151811061169657fe5b6001600160a01b03928316602091820292909201810191909152600154604080516315ab88c960e31b81529051919093169263ad5c4648926004808301939192829003018186803b1580156116ea57600080fd5b505afa1580156116fe573d6000803e3d6000fd5b505050506040513d602081101561171457600080fd5b505181518290600190811061172557fe5b6001600160a01b03928316602091820292909201015260015461174b9130911684610c6c565b60015460405163791ac94760e01b8152600481018481526000602483018190523060648401819052426084850181905260a060448601908152875160a487015287516001600160a01b039097169663791ac947968a968a9594939092909160c40190602080880191028083838b5b838110156117d15781810151838201526020016117b9565b505050509050019650505050505050600060405180830381600087803b1580156117fa57600080fd5b505af115801561180e573d6000803e3d6000fd5b505050505050565b60015461182e9030906001600160a01b031684610c6c565b6001546005546040805163f305d71960e01b81523060048201526024810186905260006044820181905260648201526001600160a01b0392831660848201524260a48201529051919092169163f305d71991849160c48082019260609290919082900301818588803b1580156118a357600080fd5b505af11580156118b7573d6000803e3d6000fd5b50505050506040513d60608110156118ce57600080fd5b5050505056fe42455032303a207472616e736665722066726f6d20746865207a65726f206164647265737342455032303a20617070726f76652066726f6d20746865207a65726f20616464726573734f776e61626c653a206e6577206f776e657220697320746865207a65726f206164647265737342455032303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f774f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725472616e7366657220616d6f756e74206d7573742062652067726561746572207468616e207a65726f42455032303a207472616e7366657220746f20746865207a65726f206164647265737342455032303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726f42455032303a20617070726f766520746f20746865207a65726f2061646472657373a264697066735822122023b84b0e3ea17c4873b372b97029b611275a96bf04d92c98defbd2eef00af45f64736f6c63430007060033

Deployed Bytecode Sourcemap

25128:9859:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;28183:83;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;29021:161;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;29021:161:0;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;28057:118;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;28057:118:0;-1:-1:-1;;;;;28057:118:0;;:::i;:::-;;25256:41;;;;;;;;;;;;;:::i;:::-;;;;-1:-1:-1;;;;;25256:41:0;;;;;;;;;;;;;;28460:100;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;29190:313;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;29190:313:0;;;;;;;;;;;;;;;;;:::i;27287:115::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;27287:115:0;-1:-1:-1;;;;;27287:115:0;;:::i;28369:83::-;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;29511:218;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;29511:218:0;;;;;;;;:::i;25474:75::-;;;;;;;;;;;;;:::i;25439:28::-;;;;;;;;;;;;;:::i;27534:109::-;;;;;;;;;;;;;:::i;28568:119::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;28568:119:0;-1:-1:-1;;;;;28568:119:0;;:::i;17912:148::-;;;;;;;;;;;;;:::i;27787:135::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;27787:135:0;;:::i;17270:79::-;;;;;;;;;;;;;:::i;28274:87::-;;;;;;;;;;;;;:::i;27414:108::-;;;;;;;;;;;;;:::i;29737:269::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;29737:269:0;;;;;;;;:::i;28695:167::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;28695:167:0;;;;;;;;:::i;27934:111::-;;;;;;;;;;;;;:::i;27655:116::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;27655:116:0;;;;:::i;26035:34::-;;;;;;;;;;;;;:::i;28870:143::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;28870:143:0;;;;;;;;;;:::i;18215:244::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;18215:244:0;-1:-1:-1;;;;;18215:244:0;;:::i;28183:83::-;28253:5;28246:12;;;;;;;;-1:-1:-1;;28246:12:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;28220:13;;28246:12;;28253:5;;28246:12;;28253:5;28246:12;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;28183:83;:::o;29021:161::-;29096:4;29113:39;29122:12;:10;:12::i;:::-;29136:7;29145:6;29113:8;:39::i;:::-;-1:-1:-1;29170:4:0;29021:161;;;;;:::o;28057:118::-;17492:12;:10;:12::i;:::-;17482:6;;-1:-1:-1;;;;;17482:6:0;;;:22;;;17474:67;;;;;-1:-1:-1;;;17474:67:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;17474:67:0;;;;;;;;;;;;;;;28137:13:::1;:30:::0;;-1:-1:-1;;;;;;28137:30:0::1;-1:-1:-1::0;;;;;28137:30:0;;;::::1;::::0;;;::::1;::::0;;28057:118::o;25256:41::-;;;-1:-1:-1;;;;;25256:41:0;;:::o;28460:100::-;28540:12;;28460:100;:::o;29190:313::-;29288:4;29305:36;29315:6;29323:9;29334:6;29305:9;:36::i;:::-;29352:121;29361:6;29369:12;:10;:12::i;:::-;29383:89;29421:6;29383:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;29383:19:0;;;;;;:11;:19;;;;;;29403:12;:10;:12::i;:::-;-1:-1:-1;;;;;29383:33:0;;;;;;;;;;;;-1:-1:-1;29383:33:0;;;:89;:37;:89::i;:::-;29352:8;:121::i;:::-;-1:-1:-1;29491:4:0;29190:313;;;;;:::o;27287:115::-;17492:12;:10;:12::i;:::-;17482:6;;-1:-1:-1;;;;;17482:6:0;;;:22;;;17474:67;;;;;-1:-1:-1;;;17474:67:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;17474:67:0;;;;;;;;;;;;;;;27366:11:::1;:28:::0;;-1:-1:-1;;;;;;27366:28:0::1;-1:-1:-1::0;;;;;27366:28:0;;;::::1;::::0;;;::::1;::::0;;27287:115::o;28369:83::-;28435:9;;;;28369:83;:::o;29511:218::-;29599:4;29616:83;29625:12;:10;:12::i;:::-;29639:7;29648:50;29687:10;29648:11;:25;29660:12;:10;:12::i;:::-;-1:-1:-1;;;;;29648:25:0;;;;;;;;;;;;;;;;;-1:-1:-1;29648:25:0;;;:34;;;;;;;;;;;:38;:50::i;25474:75::-;;;-1:-1:-1;;;;;25474:75:0;;:::o;25439:28::-;;;-1:-1:-1;;;;;25439:28:0;;:::o;27534:109::-;27587:4;27611:24;27629:4;27611:9;:24::i;:::-;27604:31;;27534:109;:::o;28568:119::-;-1:-1:-1;;;;;28661:18:0;28634:7;28661:18;;;:9;:18;;;;;;;28568:119::o;17912:148::-;17492:12;:10;:12::i;:::-;17482:6;;-1:-1:-1;;;;;17482:6:0;;;:22;;;17474:67;;;;;-1:-1:-1;;;17474:67:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;17474:67:0;;;;;;;;;;;;;;;18019:1:::1;18003:6:::0;;17982:40:::1;::::0;-1:-1:-1;;;;;18003:6:0;;::::1;::::0;17982:40:::1;::::0;18019:1;;17982:40:::1;18050:1;18033:19:::0;;-1:-1:-1;;;;;;18033:19:0::1;::::0;;17912:148::o;27787:135::-;17492:12;:10;:12::i;:::-;17482:6;;-1:-1:-1;;;;;17482:6:0;;;:22;;;17474:67;;;;;-1:-1:-1;;;17474:67:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;17474:67:0;;;;;;;;;;;;;;;27900:13:::1;::::0;27889:25:::1;::::0;:6;;:10:::1;:25::i;:::-;27864:22;:50:::0;-1:-1:-1;27787:135:0:o;17270:79::-;17308:7;17335:6;-1:-1:-1;;;;;17335:6:0;17270:79;:::o;28274:87::-;28346:7;28339:14;;;;;;;;-1:-1:-1;;28339:14:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;28313:13;;28339:14;;28346:7;;28339:14;;28346:7;28339:14;;;;;;;;;;;;;;;;;;;;;;;;27414:108;27493:21;27414:108;:::o;29737:269::-;29830:4;29847:129;29856:12;:10;:12::i;:::-;29870:7;29879:96;29918:15;29879:96;;;;;;;;;;;;;;;;;:11;:25;29891:12;:10;:12::i;:::-;-1:-1:-1;;;;;29879:25:0;;;;;;;;;;;;;;;;;-1:-1:-1;29879:25:0;;;:34;;;;;;;;;;;:96;:38;:96::i;28695:167::-;28773:4;28790:42;28800:12;:10;:12::i;:::-;28814:9;28825:6;28790:9;:42::i;27934:111::-;28015:22;;27934:111;:::o;27655:116::-;17492:12;:10;:12::i;:::-;17482:6;;-1:-1:-1;;;;;17482:6:0;;;:22;;;17474:67;;;;;-1:-1:-1;;;17474:67:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;17474:67:0;;;;;;;;;;;;;;;27732:22:::1;:31:::0;;;::::1;;::::0;::::1;-1:-1:-1::0;;27732:31:0;;::::1;::::0;;;::::1;::::0;;27655:116::o;26035:34::-;;;;;;;;;:::o;28870:143::-;-1:-1:-1;;;;;28978:18:0;;;28951:7;28978:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;28870:143::o;18215:244::-;17492:12;:10;:12::i;:::-;17482:6;;-1:-1:-1;;;;;17482:6:0;;;:22;;;17474:67;;;;;-1:-1:-1;;;17474:67:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;17474:67:0;;;;;;;;;;;;;;;-1:-1:-1;;;;;18304:22:0;::::1;18296:73;;;;-1:-1:-1::0;;;18296:73:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;18406:6;::::0;;18385:38:::1;::::0;-1:-1:-1;;;;;18385:38:0;;::::1;::::0;18406:6;::::1;::::0;18385:38:::1;::::0;::::1;18434:6;:17:::0;;-1:-1:-1;;;;;;18434:17:0::1;-1:-1:-1::0;;;;;18434:17:0;;;::::1;::::0;;;::::1;::::0;;18215:244::o;1810:106::-;1898:10;1810:106;:::o;30018:337::-;-1:-1:-1;;;;;30111:19:0;;30103:68;;;;-1:-1:-1;;;30103:68:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;30190:21:0;;30182:68;;;;-1:-1:-1;;;30182:68:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;30263:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;30315:32;;;;;;;;;;;;;;;;;30018:337;;;:::o;30363:1840::-;-1:-1:-1;;;;;30460:20:0;;30452:70;;;;-1:-1:-1;;;30452:70:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;30541:23:0;;30533:71;;;;-1:-1:-1;;;30533:71:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;30632:1;30623:6;:10;30615:64;;;;-1:-1:-1;;;30615:64:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;30703:23:0;;30721:4;30703:23;;:44;;;30740:7;:5;:7::i;:::-;-1:-1:-1;;;;;30730:17:0;:6;-1:-1:-1;;;;;30730:17:0;;30703:44;30700:1496;;;-1:-1:-1;;;;;30785:17:0;;;;;;:9;:17;;;;;;:29;;30807:6;30785:21;:29::i;:::-;-1:-1:-1;;;;;30765:17:0;;;;;;;:9;:17;;;;;;:49;;;;30852:20;;;;;;;:32;;30877:6;30852:24;:32::i;:::-;-1:-1:-1;;;;;30829:20:0;;;;;;;:9;:20;;;;;;;;;:55;;;;30904:36;;;;;;;30829:20;;30904:36;;;;;;;;;;;;;30700:1496;;;31013:3;31003:7;;:13;31000:214;;;31077:13;;31036:20;;31059:33;;-1:-1:-1;;;;;31077:13:0;31059:9;:33::i;:::-;31036:56;-1:-1:-1;31130:24:0;31036:56;31150:3;31130:19;:24::i;:::-;31120:6;:34;;31111:44;;;;;;31184:7;;:14;;31196:1;31184:11;:14::i;:::-;31174:7;:24;-1:-1:-1;31000:214:0;31246:14;;;;;;;31242:943;;;31281:42;31298:6;31306:9;31316:6;31281:16;:42::i;:::-;31242:943;;;31364:25;31392:24;31410:4;31392:9;:24::i;:::-;31487:22;;31364:52;;-1:-1:-1;31463:46:0;;;31555:21;31616:22;;31613:436;;31667:14;:21;;-1:-1:-1;;31667:21:0;;;;;31715:39;31735:18;31715:19;:39::i;:::-;31613:436;;;31819:19;:40;;;;-1:-1:-1;31843:16:0;;;;31842:17;31819:40;:71;;;;-1:-1:-1;31877:13:0;;-1:-1:-1;;;;;31877:13:0;31863:10;:27;;31819:71;:97;;;;-1:-1:-1;31894:22:0;;;;;;;31819:97;31815:234;;;31945:14;:21;;-1:-1:-1;;31945:21:0;;;;;31993:36;32008:20;31993:14;:36::i;:::-;32085:43;32102:6;32110:9;32121:6;32085:16;:43::i;:::-;-1:-1:-1;;32147:14:0;:22;;-1:-1:-1;;32147:22:0;;;-1:-1:-1;31242:943:0;30363:1840;;;:::o;6620:192::-;6706:7;6742:12;6734:6;;;;6726:29;;;;-1:-1:-1;;;6726:29:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;6778:5:0;;;6620:192::o;5717:181::-;5775:7;5807:5;;;5831:6;;;;5823:46;;;;;-1:-1:-1;;;5823:46:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;5889:1;5717:181;-1:-1:-1;;;5717:181:0:o;7071:471::-;7129:7;7374:6;7370:47;;-1:-1:-1;7404:1:0;7397:8;;7370:47;7441:5;;;7445:1;7441;:5;:1;7465:5;;;;;:10;7457:56;;;;-1:-1:-1;;;7457:56:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6181:136;6239:7;6266:43;6270:1;6273;6266:43;;;;;;;;;;;;;;;;;:3;:43::i;8018:132::-;8076:7;8103:39;8107:1;8110;8103:39;;;;;;;;;;;;;;;;;:3;:39::i;32221:671::-;32317:18;32338:22;32358:1;32338:15;:6;32349:3;32338:10;:15::i;:::-;:19;;:22::i;:::-;32317:43;-1:-1:-1;32371:15:0;32389;:6;32400:3;32389:10;:15::i;:::-;32371:33;-1:-1:-1;32415:19:0;32437:41;32464:13;32437:22;:6;32371:33;32437:10;:22::i;:::-;:26;;:41::i;:::-;-1:-1:-1;;;;;32519:17:0;;;;;;:9;:17;;;;;;32415:63;;-1:-1:-1;32519:29:0;;32541:6;32519:21;:29::i;:::-;-1:-1:-1;;;;;32499:17:0;;;;;;;:9;:17;;;;;;:49;;;;32582:20;;;;;;;:40;;32607:14;32582:24;:40::i;:::-;-1:-1:-1;;;;;32559:20:0;;;;;;:9;:20;;;;;;:63;;;;32678:4;32660:24;;;;:43;;32689:13;32660:28;:43::i;:::-;32651:4;32633:24;;;;:9;:24;;;;;:70;32729:12;;:28;;32746:10;32729:16;:28::i;:::-;32714:12;:43;32783:41;;;;;;;;32809:1;;-1:-1:-1;;;;;32783:41:0;;;;;;;;;;;;32858:9;-1:-1:-1;;;;;32840:44:0;32850:6;-1:-1:-1;;;;;32840:44:0;;32869:14;32840:44;;;;;;;;;;;;;;;;;;32221:671;;;;;;:::o;34126:421::-;34214:16;;;34228:1;34214:16;;;;;;;;34190:21;;34214:16;;;;;;;;-1:-1:-1;;34251:15:0;;:22;;;-1:-1:-1;;;34251:22:0;;;;34190:40;;-1:-1:-1;;;;;;34251:15:0;;;;:20;;-1:-1:-1;34251:22:0;;;;;;;;;;;;;;:15;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;34251:22:0;34241:7;;:4;;34246:1;;34241:7;;;;-1:-1:-1;;;;;34241:32:0;;;:7;;;;;;;;;:32;34302:11;;34284:7;;34302:11;;;34284:4;;34302:11;;34284:7;;;;;;-1:-1:-1;;;;;34284:30:0;;;:7;;;;;;;;;:30;34359:15;;34327:60;;34344:4;;34359:15;34377:9;34327:8;:60::i;:::-;34398:15;;34506;;34398:141;;-1:-1:-1;;;34398:141:0;;;;;;;;-1:-1:-1;;;;;34506:15:0;;;34398:141;;;;;;34523:15;34398:141;;;;;;;;;;;;;;;;;;;;;:15;;;;;:66;;34472:9;;;;34493:4;;34506:15;34523;34398:141;;;;;;;;;;;;;;;;:15;:141;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;34126:421;;:::o;32904:717::-;32975:20;32998:34;33030:1;32998:27;:20;33023:1;32998:24;:27::i;:34::-;32975:57;-1:-1:-1;33043:17:0;33063:41;:20;32975:57;33063:24;:41::i;:::-;33043:61;-1:-1:-1;33147:21:0;33189:33;33206:15;33189:16;:33::i;:::-;33243:18;33264:41;:21;33290:14;33264:25;:41::i;:::-;33243:62;-1:-1:-1;33316:17:0;33336:24;33358:1;33336:17;33243:62;33351:1;33336:14;:17::i;:24::-;33448:9;;33432:49;;33316:44;;-1:-1:-1;33316:44:0;;-1:-1:-1;;;;;33448:9:0;;;;33432:49;;;;;33316:44;;33371:16;33432:49;33371:16;33432:49;33316:44;33448:9;33432:49;;;;;;;;;;;;;;;;;;;;;33492:40;33505:12;33519;33492;:40::i;:::-;33558:55;;;;;;;;;;;;;;;;;;;;;;;;;;;;;32904:717;;;;;;;:::o;8646:278::-;8732:7;8767:12;8760:5;8752:28;;;;-1:-1:-1;;;8752:28:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8791:9;8807:1;8803;:5;;;;;;;8646:278;-1:-1:-1;;;;;8646:278:0:o;33633:481::-;33783:16;;;33797:1;33783:16;;;;;;;;33759:21;;33783:16;;;;;;;;;;-1:-1:-1;33783:16:0;33759:40;;33828:4;33810;33815:1;33810:7;;;;;;;;-1:-1:-1;;;;;33810:23:0;;;:7;;;;;;;;;;:23;;;;33854:15;;:22;;;-1:-1:-1;;;33854:22:0;;;;:15;;;;;:20;;:22;;;;;33810:7;;33854:22;;;;;:15;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;33854:22:0;33844:7;;:4;;33849:1;;33844:7;;;;;;-1:-1:-1;;;;;33844:32:0;;;:7;;;;;;;;;:32;33921:15;;33889:62;;33906:4;;33921:15;33939:11;33889:8;:62::i;:::-;33990:15;;:116;;-1:-1:-1;;;33990:116:0;;;;;;;;:15;:116;;;;;;34084:4;33990:116;;;;;;34090:15;33990:116;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;33990:15:0;;;;:66;;34057:11;;34071:4;;34084;34090:15;33990:116;;;;;;;;;;;;;;;;:15;:116;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;33633:481;;:::o;34555:382::-;34735:15;;34703:62;;34720:4;;-1:-1:-1;;;;;34735:15:0;34753:11;34703:8;:62::i;:::-;34808:15;;34896;;34808:121;;;-1:-1:-1;;;34808:121:0;;34866:4;34808:121;;;;;;;;;;:15;:121;;;;;;;;;;-1:-1:-1;;;;;34896:15:0;;;34808:121;;;;34913:15;34808:121;;;;;;:15;;;;;:31;;34847:9;;34808:121;;;;;;;;;;;;;;;34847:9;34808:15;:121;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;34555:382:0:o

Swarm Source

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