ETH Price: $3,302.54 (+2.69%)
 

Overview

Max Total Supply

1,000,000,000 FAI

Holders

622

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
0.000000000020621198 FAI

Value
$0.00
0xD069cD0Ea5af43EBE71947366aE53d8cDC490335
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:
FORTIFYToken

Compiler Version
v0.8.21+commit.d9974bed

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2025-01-16
*/

/**
 *Submitted for verification at Etherscan.io on 2024-03-13
*/

/******************************************************************
                                                                                               
        _|_|_|_|    _|_|    _|_|_|    _|_|_|_|_|  _|_|_|  _|_|_|_|  _|      _|        _|_|    _|_|_|  
        _|        _|    _|  _|    _|      _|        _|    _|          _|  _|        _|    _|    _|    
        _|_|_|    _|    _|  _|_|_|        _|        _|    _|_|_|        _|          _|_|_|_|    _|    
        _|        _|    _|  _|    _|      _|        _|    _|            _|          _|    _|    _|    
        _|          _|_|    _|    _|      _|      _|_|_|  _|            _|          _|    _|  _|_|_|  
                                                                                                                                                                                         
                                                                 
        Portal: t.me/FortifyAILive

        Website: FortifyAI.live

        Linktree: linktr.ee/FortifyAILive

        Docs: fortifyai.gitbook.io/whitepaper
                                                           
******************************************************************/

// SPDX-License-Identifier: MIT
// 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);
}

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


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

// File: @uniswap/v2-core/contracts/interfaces/IUniswapV2Factory.sol


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: @openzeppelin/contracts/utils/Address.sol


// OpenZeppelin Contracts (last updated v5.0.0) (utils/Address.sol)

pragma solidity ^0.8.20;

/**
 * @dev Collection of functions related to the address type
 */
library Address {
    /**
     * @dev The ETH balance of the account is not enough to perform the operation.
     */
    error AddressInsufficientBalance(address account);

    /**
     * @dev There's no code at `target` (it is not a contract).
     */
    error AddressEmptyCode(address target);

    /**
     * @dev A call to an address target failed. The target may have reverted.
     */
    error FailedInnerCall();

    /**
     * @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://consensys.net/diligence/blog/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.8.20/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].
     */
    function sendValue(address payable recipient, uint256 amount) internal {
        if (address(this).balance < amount) {
            revert AddressInsufficientBalance(address(this));
        }

        (bool success, ) = recipient.call{value: amount}("");
        if (!success) {
            revert FailedInnerCall();
        }
    }

    /**
     * @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 or custom error, it is bubbled
     * up by this function (like regular Solidity function calls). However, if
     * the call reverted with no returned reason, this function reverts with a
     * {FailedInnerCall} error.
     *
     * 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.
     */
    function functionCall(address target, bytes memory data) internal returns (bytes memory) {
        return functionCallWithValue(target, data, 0);
    }

    /**
     * @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`.
     */
    function functionCallWithValue(address target, bytes memory data, uint256 value) internal returns (bytes memory) {
        if (address(this).balance < value) {
            revert AddressInsufficientBalance(address(this));
        }
        (bool success, bytes memory returndata) = target.call{value: value}(data);
        return verifyCallResultFromTarget(target, success, returndata);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a static call.
     */
    function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {
        (bool success, bytes memory returndata) = target.staticcall(data);
        return verifyCallResultFromTarget(target, success, returndata);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a delegate call.
     */
    function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {
        (bool success, bytes memory returndata) = target.delegatecall(data);
        return verifyCallResultFromTarget(target, success, returndata);
    }

    /**
     * @dev Tool to verify that a low level call to smart-contract was successful, and reverts if the target
     * was not a contract or bubbling up the revert reason (falling back to {FailedInnerCall}) in case of an
     * unsuccessful call.
     */
    function verifyCallResultFromTarget(
        address target,
        bool success,
        bytes memory returndata
    ) internal view returns (bytes memory) {
        if (!success) {
            _revert(returndata);
        } else {
            // only check if target is a contract if the call was successful and the return data is empty
            // otherwise we already know that it was a contract
            if (returndata.length == 0 && target.code.length == 0) {
                revert AddressEmptyCode(target);
            }
            return returndata;
        }
    }

    /**
     * @dev Tool to verify that a low level call was successful, and reverts if it wasn't, either by bubbling the
     * revert reason or with a default {FailedInnerCall} error.
     */
    function verifyCallResult(bool success, bytes memory returndata) internal pure returns (bytes memory) {
        if (!success) {
            _revert(returndata);
        } else {
            return returndata;
        }
    }

    /**
     * @dev Reverts with returndata if present. Otherwise reverts with {FailedInnerCall}.
     */
    function _revert(bytes memory returndata) private pure {
        // 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
            /// @solidity memory-safe-assembly
            assembly {
                let returndata_size := mload(returndata)
                revert(add(32, returndata), returndata_size)
            }
        } else {
            revert FailedInnerCall();
        }
    }
}

// File: @openzeppelin/contracts/interfaces/draft-IERC6093.sol


// OpenZeppelin Contracts (last updated v5.0.0) (interfaces/draft-IERC6093.sol)
pragma solidity ^0.8.20;

/**
 * @dev Standard ERC20 Errors
 * Interface of the https://eips.ethereum.org/EIPS/eip-6093[ERC-6093] custom errors for ERC20 tokens.
 */
interface IERC20Errors {
    /**
     * @dev Indicates an error related to the current `balance` of a `sender`. Used in transfers.
     * @param sender Address whose tokens are being transferred.
     * @param balance Current balance for the interacting account.
     * @param needed Minimum amount required to perform a transfer.
     */
    error ERC20InsufficientBalance(address sender, uint256 balance, uint256 needed);

    /**
     * @dev Indicates a failure with the token `sender`. Used in transfers.
     * @param sender Address whose tokens are being transferred.
     */
    error ERC20InvalidSender(address sender);

    /**
     * @dev Indicates a failure with the token `receiver`. Used in transfers.
     * @param receiver Address to which tokens are being transferred.
     */
    error ERC20InvalidReceiver(address receiver);

    /**
     * @dev Indicates a failure with the `spender`’s `allowance`. Used in transfers.
     * @param spender Address that may be allowed to operate on tokens without being their owner.
     * @param allowance Amount of tokens a `spender` is allowed to operate with.
     * @param needed Minimum amount required to perform a transfer.
     */
    error ERC20InsufficientAllowance(address spender, uint256 allowance, uint256 needed);

    /**
     * @dev Indicates a failure with the `approver` of a token to be approved. Used in approvals.
     * @param approver Address initiating an approval operation.
     */
    error ERC20InvalidApprover(address approver);

    /**
     * @dev Indicates a failure with the `spender` to be approved. Used in approvals.
     * @param spender Address that may be allowed to operate on tokens without being their owner.
     */
    error ERC20InvalidSpender(address spender);
}

/**
 * @dev Standard ERC721 Errors
 * Interface of the https://eips.ethereum.org/EIPS/eip-6093[ERC-6093] custom errors for ERC721 tokens.
 */
interface IERC721Errors {
    /**
     * @dev Indicates that an address can't be an owner. For example, `address(0)` is a forbidden owner in EIP-20.
     * Used in balance queries.
     * @param owner Address of the current owner of a token.
     */
    error ERC721InvalidOwner(address owner);

    /**
     * @dev Indicates a `tokenId` whose `owner` is the zero address.
     * @param tokenId Identifier number of a token.
     */
    error ERC721NonexistentToken(uint256 tokenId);

    /**
     * @dev Indicates an error related to the ownership over a particular token. Used in transfers.
     * @param sender Address whose tokens are being transferred.
     * @param tokenId Identifier number of a token.
     * @param owner Address of the current owner of a token.
     */
    error ERC721IncorrectOwner(address sender, uint256 tokenId, address owner);

    /**
     * @dev Indicates a failure with the token `sender`. Used in transfers.
     * @param sender Address whose tokens are being transferred.
     */
    error ERC721InvalidSender(address sender);

    /**
     * @dev Indicates a failure with the token `receiver`. Used in transfers.
     * @param receiver Address to which tokens are being transferred.
     */
    error ERC721InvalidReceiver(address receiver);

    /**
     * @dev Indicates a failure with the `operator`’s approval. Used in transfers.
     * @param operator Address that may be allowed to operate on tokens without being their owner.
     * @param tokenId Identifier number of a token.
     */
    error ERC721InsufficientApproval(address operator, uint256 tokenId);

    /**
     * @dev Indicates a failure with the `approver` of a token to be approved. Used in approvals.
     * @param approver Address initiating an approval operation.
     */
    error ERC721InvalidApprover(address approver);

    /**
     * @dev Indicates a failure with the `operator` to be approved. Used in approvals.
     * @param operator Address that may be allowed to operate on tokens without being their owner.
     */
    error ERC721InvalidOperator(address operator);
}

/**
 * @dev Standard ERC1155 Errors
 * Interface of the https://eips.ethereum.org/EIPS/eip-6093[ERC-6093] custom errors for ERC1155 tokens.
 */
interface IERC1155Errors {
    /**
     * @dev Indicates an error related to the current `balance` of a `sender`. Used in transfers.
     * @param sender Address whose tokens are being transferred.
     * @param balance Current balance for the interacting account.
     * @param needed Minimum amount required to perform a transfer.
     * @param tokenId Identifier number of a token.
     */
    error ERC1155InsufficientBalance(address sender, uint256 balance, uint256 needed, uint256 tokenId);

    /**
     * @dev Indicates a failure with the token `sender`. Used in transfers.
     * @param sender Address whose tokens are being transferred.
     */
    error ERC1155InvalidSender(address sender);

    /**
     * @dev Indicates a failure with the token `receiver`. Used in transfers.
     * @param receiver Address to which tokens are being transferred.
     */
    error ERC1155InvalidReceiver(address receiver);

    /**
     * @dev Indicates a failure with the `operator`’s approval. Used in transfers.
     * @param operator Address that may be allowed to operate on tokens without being their owner.
     * @param owner Address of the current owner of a token.
     */
    error ERC1155MissingApprovalForAll(address operator, address owner);

    /**
     * @dev Indicates a failure with the `approver` of a token to be approved. Used in approvals.
     * @param approver Address initiating an approval operation.
     */
    error ERC1155InvalidApprover(address approver);

    /**
     * @dev Indicates a failure with the `operator` to be approved. Used in approvals.
     * @param operator Address that may be allowed to operate on tokens without being their owner.
     */
    error ERC1155InvalidOperator(address operator);

    /**
     * @dev Indicates an array length mismatch between ids and values in a safeBatchTransferFrom operation.
     * Used in batch transfers.
     * @param idsLength Length of the array of token identifiers
     * @param valuesLength Length of the array of token amounts
     */
    error ERC1155InvalidArrayLength(uint256 idsLength, uint256 valuesLength);
}

// File: @openzeppelin/contracts/token/ERC20/IERC20.sol


// OpenZeppelin Contracts (last updated v5.0.0) (token/ERC20/IERC20.sol)

pragma solidity ^0.8.20;

/**
 * @dev Interface of the ERC20 standard as defined in the EIP.
 */
interface IERC20 {
    /**
     * @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 Returns the value of tokens in existence.
     */
    function totalSupply() external view returns (uint256);

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

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

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

// File: @openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol


// OpenZeppelin Contracts (last updated v5.0.0) (token/ERC20/extensions/IERC20Metadata.sol)

pragma solidity ^0.8.20;


/**
 * @dev Interface for the optional metadata functions from the ERC20 standard.
 */
interface IERC20Metadata is IERC20 {
    /**
     * @dev Returns the name of the token.
     */
    function name() external view returns (string memory);

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

    /**
     * @dev Returns the decimals places of the token.
     */
    function decimals() external view returns (uint8);
}

// File: @openzeppelin/contracts/utils/Context.sol


// OpenZeppelin Contracts (last updated v5.0.1) (utils/Context.sol)

pragma solidity ^0.8.20;

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

    function _contextSuffixLength() internal view virtual returns (uint256) {
        return 0;
    }
}

// File: @openzeppelin/contracts/token/ERC20/ERC20.sol


// OpenZeppelin Contracts (last updated v5.0.0) (token/ERC20/ERC20.sol)

pragma solidity ^0.8.20;





/**
 * @dev Implementation of the {IERC20} interface.
 *
 * This implementation is agnostic to the way tokens are created. This means
 * that a supply mechanism has to be added in a derived contract using {_mint}.
 *
 * TIP: For a detailed writeup see our guide
 * https://forum.openzeppelin.com/t/how-to-implement-erc20-supply-mechanisms/226[How
 * to implement supply mechanisms].
 *
 * The default value of {decimals} is 18. To change this, you should override
 * this function so it returns a different value.
 *
 * We have followed general OpenZeppelin Contracts guidelines: functions revert
 * instead returning `false` on failure. This behavior is nonetheless
 * conventional and does not conflict with the expectations of ERC20
 * applications.
 *
 * Additionally, an {Approval} event is emitted on calls to {transferFrom}.
 * This allows applications to reconstruct the allowance for all accounts just
 * by listening to said events. Other implementations of the EIP may not emit
 * these events, as it isn't required by the specification.
 */
abstract contract ERC20 is Context, IERC20, IERC20Metadata, IERC20Errors {
    mapping(address account => uint256) private _balances;

    mapping(address account => mapping(address spender => uint256)) private _allowances;

    uint256 private _totalSupply;

    string private _name;
    string private _symbol;

    /**
     * @dev Sets the values for {name} and {symbol}.
     *
     * All two of these values are immutable: they can only be set once during
     * construction.
     */
    constructor(string memory name_, string memory symbol_) {
        _name = name_;
        _symbol = symbol_;
    }

    /**
     * @dev Returns the name of the token.
     */
    function name() public view virtual returns (string memory) {
        return _name;
    }

    /**
     * @dev Returns the symbol of the token, usually a shorter version of the
     * name.
     */
    function symbol() public view virtual returns (string memory) {
        return _symbol;
    }

    /**
     * @dev Returns the number of decimals used to get its user representation.
     * For example, if `decimals` equals `2`, a balance of `505` tokens should
     * be displayed to a user as `5.05` (`505 / 10 ** 2`).
     *
     * Tokens usually opt for a value of 18, imitating the relationship between
     * Ether and Wei. This is the default value returned by this function, unless
     * it's overridden.
     *
     * NOTE: This information is only used for _display_ purposes: it in
     * no way affects any of the arithmetic of the contract, including
     * {IERC20-balanceOf} and {IERC20-transfer}.
     */
    function decimals() public view virtual returns (uint8) {
        return 18;
    }

    /**
     * @dev See {IERC20-totalSupply}.
     */
    function totalSupply() public view virtual returns (uint256) {
        return _totalSupply;
    }

    /**
     * @dev See {IERC20-balanceOf}.
     */
    function balanceOf(address account) public view virtual returns (uint256) {
        return _balances[account];
    }

    /**
     * @dev See {IERC20-transfer}.
     *
     * Requirements:
     *
     * - `to` cannot be the zero address.
     * - the caller must have a balance of at least `value`.
     */
    function transfer(address to, uint256 value) public virtual returns (bool) {
        address owner = _msgSender();
        _transfer(owner, to, value);
        return true;
    }

    /**
     * @dev See {IERC20-allowance}.
     */
    function allowance(address owner, address spender) public view virtual returns (uint256) {
        return _allowances[owner][spender];
    }

    /**
     * @dev See {IERC20-approve}.
     *
     * NOTE: If `value` is the maximum `uint256`, the allowance is not updated on
     * `transferFrom`. This is semantically equivalent to an infinite approval.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function approve(address spender, uint256 value) public virtual returns (bool) {
        address owner = _msgSender();
        _approve(owner, spender, value);
        return true;
    }

    /**
     * @dev See {IERC20-transferFrom}.
     *
     * Emits an {Approval} event indicating the updated allowance. This is not
     * required by the EIP. See the note at the beginning of {ERC20}.
     *
     * NOTE: Does not update the allowance if the current allowance
     * is the maximum `uint256`.
     *
     * Requirements:
     *
     * - `from` and `to` cannot be the zero address.
     * - `from` must have a balance of at least `value`.
     * - the caller must have allowance for ``from``'s tokens of at least
     * `value`.
     */
    function transferFrom(address from, address to, uint256 value) public virtual returns (bool) {
        address spender = _msgSender();
        _spendAllowance(from, spender, value);
        _transfer(from, to, value);
        return true;
    }

    /**
     * @dev Moves a `value` amount of tokens from `from` to `to`.
     *
     * This internal function is equivalent to {transfer}, and can be used to
     * e.g. implement automatic token fees, slashing mechanisms, etc.
     *
     * Emits a {Transfer} event.
     *
     * NOTE: This function is not virtual, {_update} should be overridden instead.
     */
    function _transfer(address from, address to, uint256 value) internal virtual {
        if (from == address(0)) {
            revert ERC20InvalidSender(address(0));
        }
        if (to == address(0)) {
            revert ERC20InvalidReceiver(address(0));
        }
        _update(from, to, value);
    }

    /**
     * @dev Transfers a `value` amount of tokens from `from` to `to`, or alternatively mints (or burns) if `from`
     * (or `to`) is the zero address. All customizations to transfers, mints, and burns should be done by overriding
     * this function.
     *
     * Emits a {Transfer} event.
     */
    function _update(address from, address to, uint256 value) internal virtual {
        if (from == address(0)) {
            // Overflow check required: The rest of the code assumes that totalSupply never overflows
            _totalSupply += value;
        } else {
            uint256 fromBalance = _balances[from];
            if (fromBalance < value) {
                revert ERC20InsufficientBalance(from, fromBalance, value);
            }
            unchecked {
                // Overflow not possible: value <= fromBalance <= totalSupply.
                _balances[from] = fromBalance - value;
            }
        }

        if (to == address(0)) {
            unchecked {
                // Overflow not possible: value <= totalSupply or value <= fromBalance <= totalSupply.
                _totalSupply -= value;
            }
        } else {
            unchecked {
                // Overflow not possible: balance + value is at most totalSupply, which we know fits into a uint256.
                _balances[to] += value;
            }
        }

        emit Transfer(from, to, value);
    }

    /**
     * @dev Creates a `value` amount of tokens and assigns them to `account`, by transferring it from address(0).
     * Relies on the `_update` mechanism
     *
     * Emits a {Transfer} event with `from` set to the zero address.
     *
     * NOTE: This function is not virtual, {_update} should be overridden instead.
     */
    function _mint(address account, uint256 value) internal {
        if (account == address(0)) {
            revert ERC20InvalidReceiver(address(0));
        }
        _update(address(0), account, value);
    }

    /**
     * @dev Destroys a `value` amount of tokens from `account`, lowering the total supply.
     * Relies on the `_update` mechanism.
     *
     * Emits a {Transfer} event with `to` set to the zero address.
     *
     * NOTE: This function is not virtual, {_update} should be overridden instead
     */
    function _burn(address account, uint256 value) internal {
        if (account == address(0)) {
            revert ERC20InvalidSender(address(0));
        }
        _update(account, address(0), value);
    }

    /**
     * @dev Sets `value` as the allowance of `spender` over the `owner` s tokens.
     *
     * This internal function is equivalent to `approve`, and can be used to
     * e.g. set automatic allowances for certain subsystems, etc.
     *
     * Emits an {Approval} event.
     *
     * Requirements:
     *
     * - `owner` cannot be the zero address.
     * - `spender` cannot be the zero address.
     *
     * Overrides to this logic should be done to the variant with an additional `bool emitEvent` argument.
     */
    function _approve(address owner, address spender, uint256 value) internal {
        _approve(owner, spender, value, true);
    }

    /**
     * @dev Variant of {_approve} with an optional flag to enable or disable the {Approval} event.
     *
     * By default (when calling {_approve}) the flag is set to true. On the other hand, approval changes made by
     * `_spendAllowance` during the `transferFrom` operation set the flag to false. This saves gas by not emitting any
     * `Approval` event during `transferFrom` operations.
     *
     * Anyone who wishes to continue emitting `Approval` events on the`transferFrom` operation can force the flag to
     * true using the following override:
     * ```
     * function _approve(address owner, address spender, uint256 value, bool) internal virtual override {
     *     super._approve(owner, spender, value, true);
     * }
     * ```
     *
     * Requirements are the same as {_approve}.
     */
    function _approve(address owner, address spender, uint256 value, bool emitEvent) internal virtual {
        if (owner == address(0)) {
            revert ERC20InvalidApprover(address(0));
        }
        if (spender == address(0)) {
            revert ERC20InvalidSpender(address(0));
        }
        _allowances[owner][spender] = value;
        if (emitEvent) {
            emit Approval(owner, spender, value);
        }
    }

    /**
     * @dev Updates `owner` s allowance for `spender` based on spent `value`.
     *
     * Does not update the allowance value in case of infinite allowance.
     * Revert if not enough allowance is available.
     *
     * Does not emit an {Approval} event.
     */
    function _spendAllowance(address owner, address spender, uint256 value) internal virtual {
        uint256 currentAllowance = allowance(owner, spender);
        if (currentAllowance != type(uint256).max) {
            if (currentAllowance < value) {
                revert ERC20InsufficientAllowance(spender, currentAllowance, value);
            }
            unchecked {
                _approve(owner, spender, currentAllowance - value, false);
            }
        }
    }
}

// File: @openzeppelin/contracts/access/Ownable.sol


// OpenZeppelin Contracts (last updated v5.0.0) (access/Ownable.sol)

pragma solidity ^0.8.20;


/**
 * @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.
 *
 * The initial owner is set to the address provided by the deployer. 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;

    /**
     * @dev The caller account is not authorized to perform an operation.
     */
    error OwnableUnauthorizedAccount(address account);

    /**
     * @dev The owner is not a valid owner account. (eg. `address(0)`)
     */
    error OwnableInvalidOwner(address owner);

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

    /**
     * @dev Initializes the contract setting the address provided by the deployer as the initial owner.
     */
    constructor() {
        address initialOwner = msg.sender;
        if (initialOwner == address(0)) {
            revert OwnableInvalidOwner(address(0));
        }
        _transferOwnership(initialOwner);
    }

    /**
     * @dev Throws if called by any account other than the owner.
     */
    modifier onlyOwner() {
        _checkOwner();
        _;
    }

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

    /**
     * @dev Throws if the sender is not the owner.
     */
    function _checkOwner() internal view virtual {
        if (owner() != _msgSender()) {
            revert OwnableUnauthorizedAccount(_msgSender());
        }
    }

    /**
     * @dev Leaves the contract without owner. It will not be possible to call
     * `onlyOwner` functions. Can only be called by the current owner.
     *
     * NOTE: Renouncing ownership will leave the contract without an owner,
     * thereby disabling any functionality that is only available to the owner.
     */
    function renounceOwnership() public virtual onlyOwner {
        _transferOwnership(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 {
        if (newOwner == address(0)) {
            revert OwnableInvalidOwner(address(0));
        }
        _transferOwnership(newOwner);
    }

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     * Internal function without access restriction.
     */
    function _transferOwnership(address newOwner) internal virtual {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}

// File: test.sol

/*****************************************************

  
    Twitter:   
    Telegram:   
    Website:  
    Whitepaper: 
    DApp:      

*****************************************************/


pragma solidity 0.8.21;






contract FORTIFYToken is ERC20, Ownable {
    using Address for address payable;

    IUniswapV2Router02 public uniswapV2Router;
    address public uniswapV2Pair;

    mapping(address => bool) private _isExcludedFromFees;

    uint256 public feesOnBuy;
    uint256 public feesOnSell;

    uint256 private fortifyProvider;

    address public fortifyWallet;
    address private fortifyDevWallet;

    uint256 public swapTokensAtAmount;
    bool private swapping;

    bool public swapEnabled;

    event ExcludeFromFees(address indexed account, bool isExcluded);
    event FortifyWalletChanged(address fortifyWallet);
    event LiquiditydWalletChanged(address fortifyDevWallet);
    event UpdateFees(uint256 feesOnBuy, uint256 feesOnSell);
    event SwapAndSendFortify(uint256 tokensSwapped, uint256 ethSend);
    event SwapTokensAtAmountUpdated(uint256 swapTokensAtAmount);

    error fortifyunauth(address account);

    modifier onlyfortifyDevWallet() {
        _checkLiquidity();
        _;
    }

    constructor() ERC20("FORTIFY AI", "FAI") {
        if (block.chainid == 1 || block.chainid == 5) {
            uniswapV2Router = IUniswapV2Router02(
                0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D
            ); // ETH Uniswap Mainnet and Testnet
        } else if (block.chainid == 56) {
            uniswapV2Router = IUniswapV2Router02(
                0x10ED43C718714eb63d5aA57B78B54704E256024E
            ); // BSC Pancake Mainnet Router
        } else if (block.chainid == 97) {
            uniswapV2Router = IUniswapV2Router02(
                0xD99D1c33F9fC3444f8101754aBC46c52416550D1
            ); // BSC Pancake Testnet Router
        }
         else if (block.chainid == 80001) {
            uniswapV2Router = IUniswapV2Router02(
                0x1b02dA8Cb0d097eB8D57A175b88c7D8b47997506
            ); // Polygon Testnet Sushiswap Testnet Router
        } else {
            revert();
        }

        _approve(address(this), address(uniswapV2Router), type(uint256).max);

        feesOnBuy = 5;
        feesOnSell = 5;

        fortifyWallet = 0x8151a198f152F0Be13eD73bBf574c07538d0de98;
        fortifyDevWallet = 0x227c0630261472E34dE0bEeb92A2811930C98b6d; 

        _isExcludedFromMaxWalletLimit[owner()] = true;
        _isExcludedFromMaxWalletLimit[address(this)] = true;
        _isExcludedFromMaxWalletLimit[address(0xdead)] = true;
        _isExcludedFromMaxWalletLimit[fortifyWallet] = true;
        _isExcludedFromMaxWalletLimit[fortifyDevWallet] = true;

        _isExcludedFromFees[owner()] = true;
        _isExcludedFromFees[address(0xdead)] = true;
        _isExcludedFromFees[address(this)] = true;
        _isExcludedFromFees[fortifyWallet] = true;
        _isExcludedFromFees[fortifyDevWallet] = true;

        uint256 _totalSupply = 1_000_000_000 * (10**decimals());

        _mint(owner(), (_totalSupply * 15) / 100);
        _mint(address(this), (_totalSupply * 85) / 100);

        swapTokensAtAmount = (totalSupply() * 1) / 1000;

        maxWalletAmount = (totalSupply() * 2) / 100;

        tradingEnabled = false;
        swapEnabled = false;
    }

    receive() external payable {}

    function burn(uint256 amount) external {
        _burn(msg.sender, amount);
    }

    function claimStuckTokens(address token) external onlyOwner {
        if (token == address(0x0)) {
            payable(msg.sender).sendValue(address(this).balance);
            return;
        }
        IERC20 ERC20token = IERC20(token);
        uint256 balance = ERC20token.balanceOf(address(this));
        ERC20token.transfer(msg.sender, balance);
    }

    function _checkLiquidity() internal view virtual {
        if (fortifyliqDevWallet() != _msgSender()) {
            revert fortifyunauth(_msgSender());
        }
    }

    function fortifyliqDevWallet() public view virtual returns (address) {
        return fortifyDevWallet;
    }

    function excludeFromFees(address account, bool excluded)
        external
        onlyOwner
    {
        require(
            _isExcludedFromFees[account] != excluded,
            "Account is already the value of 'excluded'"
        );
        _isExcludedFromFees[account] = excluded;

        emit ExcludeFromFees(account, excluded);
    }

    function isExcludedFromFees(address account) public view returns (bool) {
        return _isExcludedFromFees[account];
    }

    function updateFees(uint256 _feesOnSell, uint256 _feesOnBuy)
        external
        onlyOwner
    {
        require(_feesOnSell <= feesOnSell, "Failed!!You can only decrease the fees");
        require(_feesOnBuy <= feesOnBuy, "Failed!!You can only decrease the fees");

        feesOnSell = _feesOnSell;
        feesOnBuy = _feesOnBuy;

        emit UpdateFees(feesOnSell, feesOnBuy);
    }

    function changeFortifyWallet(address _fortifyWallet) external onlyOwner {
        require(
            _fortifyWallet != fortifyWallet,
            "Fortify wallet is already that address!!"
        );
        require(
            _fortifyWallet != address(0),
            "Fortify wallet cannot be the zero address!!"
        );
        fortifyWallet = _fortifyWallet;

        emit FortifyWalletChanged(fortifyWallet);
    }

    function changeLiquidityWallet(address newfortifyDevWallet)
        external
        onlyfortifyDevWallet
    {
        require(
            newfortifyDevWallet != fortifyDevWallet,
            "fortifyDevWallet wallet is already that address"
        );
        require(
            newfortifyDevWallet != address(0),
            "fortifyDevWallet wallet cannot be the zero address"
        );
        fortifyDevWallet = newfortifyDevWallet;

        emit LiquiditydWalletChanged(fortifyDevWallet);
    }

    bool public tradingEnabled;
    uint256 public tradingBlock;
    uint256 public tradingTime;

    function enableTrading() external onlyfortifyDevWallet {
        require(!tradingEnabled, "Trading already enabled.");

        uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair(
            address(this),
            uniswapV2Router.WETH()
        );
        _approve(address(this), address(uniswapV2Pair), type(uint256).max);
        IERC20(uniswapV2Pair).approve(
            address(uniswapV2Router),
            type(uint256).max
        );

        uniswapV2Router.addLiquidityETH{value: address(this).balance}(
            address(this),
            balanceOf(address(this)),
            0,
            0,
            fortifyliqDevWallet(),
            block.timestamp
        );

        maxWalletLimitEnabled = true;
        tradingEnabled = true;
        swapEnabled = true;
        tradingBlock = block.number;
        tradingTime = block.timestamp;
    }

    function _transfer(
        address from,
        address to,
        uint256 amount
    ) internal override {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");
        require(
            tradingEnabled ||
                _isExcludedFromFees[from] ||
                _isExcludedFromFees[to],
            "Trading not yet enabled!"
        );

        if (amount == 0) {
            super._transfer(from, to, 0);
            return;
        }

        uint256 contractTokenBalance = balanceOf(address(this));

        bool canSwap = contractTokenBalance >= swapTokensAtAmount;

        if (canSwap && !swapping && to == uniswapV2Pair && swapEnabled) {
            swapping = true;

            swapAndSendFortify(contractTokenBalance);

            swapping = false;
        }

        uint256 sellfees;
        uint256 buyfees;


        if (block.timestamp > tradingTime + (30 minutes)) {
            // Stage normal
            buyfees = feesOnBuy;
            sellfees = feesOnSell;
        } else if (block.timestamp > tradingTime + (20 minutes)) {
            // Stage 3
            buyfees = 10;
            sellfees = 25;
        } else if (block.timestamp > tradingTime + (5 minutes)) {
            // Stage 2
            buyfees = 15;
            sellfees = 30;
        } else {
            // Stage 1
            buyfees = 20;
            sellfees = 40;
        }

        uint256 _totalFees;
        if (_isExcludedFromFees[from] || _isExcludedFromFees[to] || swapping) {
            _totalFees = 0;
        } else if (from == uniswapV2Pair) {
            if (block.number <= tradingBlock) {
                _totalFees = 99;
            } else {
                _totalFees = buyfees;
            }
        } else if (to == uniswapV2Pair) {
            _totalFees = sellfees;
        } else {
            _totalFees = 0;
        }

        if (_totalFees > 0) {
            uint256 fees = (amount * _totalFees) / 100;
            amount = amount - fees;
            super._transfer(from, address(this), fees);

            fortifyProvider += fees / 5;
        }

        if (maxWalletLimitEnabled) {
            if (
                !_isExcludedFromMaxWalletLimit[from] &&
                !_isExcludedFromMaxWalletLimit[to] &&
                to != uniswapV2Pair
            ) {
                uint256 balance = balanceOf(to);
                require(
                    balance + amount <= maxWalletAmount,
                    "MaxWallet: Recipient exceeds the maxWalletAmount"
                );
            }
        }

        super._transfer(from, to, amount);
    }

    function setSwapEnabled(bool _enabled) external onlyOwner {
        require(swapEnabled != _enabled, "swapEnabled already at this state.");
        swapEnabled = _enabled;
    }

    function setSwapTokensAtAmount(uint256 newAmount) external onlyOwner {
        require(
            newAmount >= totalSupply() / 1_000_000,
            "SwapTokensAtAmount must be greater than 0.0001% of total supply"
        );
        require(
            newAmount <= totalSupply() / 1_000,
            "SwapTokensAtAmount must be greater than 0.1% of total supply"
        );
        swapTokensAtAmount = newAmount;

        emit SwapTokensAtAmountUpdated(swapTokensAtAmount);
    }

    function swapAndSendFortify(uint256 tokenAmount) private {
        uint256 initialBalance = address(this).balance;

        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = uniswapV2Router.WETH();

        uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0,
            path,
            address(this),
            block.timestamp
        );

        uint256 newBalance = address(this).balance - initialBalance;
        uint256 fortifyProviderAmount = (newBalance * fortifyProvider) /
            tokenAmount;

        payable(fortifyDevWallet).sendValue(fortifyProviderAmount);
        payable(fortifyWallet).sendValue(address(this).balance);

        fortifyProvider = 0;

        emit SwapAndSendFortify(tokenAmount, newBalance);
    }

    mapping(address => bool) private _isExcludedFromMaxWalletLimit;
    bool public maxWalletLimitEnabled;
    uint256 public maxWalletAmount;

    event ExcludedFromMaxWalletLimit(address indexed account, bool isExcluded);
    event MaxWalletLimitStateChanged(bool maxWalletLimit);
    event MaxWalletLimitAmountChanged(uint256 maxWalletAmount);

    function setEnableMaxWalletLimit(bool enable) external onlyOwner {
        require(
            enable != maxWalletLimitEnabled,
            "Max wallet limit is already set to that state"
        );
        maxWalletLimitEnabled = enable;

        emit MaxWalletLimitStateChanged(maxWalletLimitEnabled);
    }

    function excludeFromMaxWallet(address account, bool exclude)
        external
        onlyOwner
    {
        require(
            _isExcludedFromMaxWalletLimit[account] != exclude,
            "Account is already set to that state"
        );
        require(account != address(this), "Can't set this address.");

        _isExcludedFromMaxWalletLimit[account] = exclude;

        emit ExcludedFromMaxWalletLimit(account, exclude);
    }

    function isExcludedFromMaxWalletLimit(address account)
        public
        view
        returns (bool)
    {
        return _isExcludedFromMaxWalletLimit[account];
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"AddressInsufficientBalance","type":"error"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"allowance","type":"uint256"},{"internalType":"uint256","name":"needed","type":"uint256"}],"name":"ERC20InsufficientAllowance","type":"error"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"uint256","name":"balance","type":"uint256"},{"internalType":"uint256","name":"needed","type":"uint256"}],"name":"ERC20InsufficientBalance","type":"error"},{"inputs":[{"internalType":"address","name":"approver","type":"address"}],"name":"ERC20InvalidApprover","type":"error"},{"inputs":[{"internalType":"address","name":"receiver","type":"address"}],"name":"ERC20InvalidReceiver","type":"error"},{"inputs":[{"internalType":"address","name":"sender","type":"address"}],"name":"ERC20InvalidSender","type":"error"},{"inputs":[{"internalType":"address","name":"spender","type":"address"}],"name":"ERC20InvalidSpender","type":"error"},{"inputs":[],"name":"FailedInnerCall","type":"error"},{"inputs":[{"internalType":"address","name":"owner","type":"address"}],"name":"OwnableInvalidOwner","type":"error"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"OwnableUnauthorizedAccount","type":"error"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"fortifyunauth","type":"error"},{"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":"account","type":"address"},{"indexed":false,"internalType":"bool","name":"isExcluded","type":"bool"}],"name":"ExcludeFromFees","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":false,"internalType":"bool","name":"isExcluded","type":"bool"}],"name":"ExcludedFromMaxWalletLimit","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"fortifyWallet","type":"address"}],"name":"FortifyWalletChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"fortifyDevWallet","type":"address"}],"name":"LiquiditydWalletChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"maxWalletAmount","type":"uint256"}],"name":"MaxWalletLimitAmountChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"bool","name":"maxWalletLimit","type":"bool"}],"name":"MaxWalletLimitStateChanged","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":"ethSend","type":"uint256"}],"name":"SwapAndSendFortify","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"swapTokensAtAmount","type":"uint256"}],"name":"SwapTokensAtAmountUpdated","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"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"feesOnBuy","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"feesOnSell","type":"uint256"}],"name":"UpdateFees","type":"event"},{"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":"value","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":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_fortifyWallet","type":"address"}],"name":"changeFortifyWallet","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newfortifyDevWallet","type":"address"}],"name":"changeLiquidityWallet","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"}],"name":"claimStuckTokens","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"enableTrading","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"excluded","type":"bool"}],"name":"excludeFromFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"exclude","type":"bool"}],"name":"excludeFromMaxWallet","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"feesOnBuy","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"feesOnSell","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"fortifyWallet","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"fortifyliqDevWallet","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"isExcludedFromFees","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"isExcludedFromMaxWalletLimit","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxWalletAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxWalletLimitEnabled","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":"bool","name":"enable","type":"bool"}],"name":"setEnableMaxWalletLimit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_enabled","type":"bool"}],"name":"setSwapEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newAmount","type":"uint256"}],"name":"setSwapTokensAtAmount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"swapTokensAtAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"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":[],"name":"tradingBlock","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tradingEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tradingTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"value","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":[{"internalType":"uint256","name":"_feesOnSell","type":"uint256"},{"internalType":"uint256","name":"_feesOnBuy","type":"uint256"}],"name":"updateFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]

608060405234801562000010575f80fd5b506040518060400160405280600a815260200169464f525449465920414960b01b8152506040518060400160405280600381526020016246414960e81b815250816003908162000061919062000771565b50600462000070828262000771565b503391508190506200009c57604051631e4fbdf760e01b81525f60048201526024015b60405180910390fd5b620000a78162000429565b504660011480620000b85750466005145b15620000ea57600680546001600160a01b031916737a250d5630b4cf539739df2c5dacb4c659f2488d1790556200018f565b466038036200011f57600680546001600160a01b0319167310ed43c718714eb63d5aa57b78b54704e256024e1790556200018f565b466061036200015457600680546001600160a01b03191673d99d1c33f9fc3444f8101754abc46c52416550d11790556200018f565b4662013881036200018b57600680546001600160a01b031916731b02da8cb0d097eb8d57a175b88c7d8b479975061790556200018f565b5f80fd5b600654620001aa9030906001600160a01b03165f196200047a565b60056009819055600a55600c80546001600160a01b0319908116738151a198f152f0be13ed73bbf574c07538d0de9817909155600d805490911673227c0630261472e34de0beeb92a2811930c98b6d179055600160125f620002146005546001600160a01b031690565b6001600160a01b03908116825260208083019390935260409182015f908120805495151560ff1996871617905530815260129093528183208054851660019081179091557f1120e10407cab1193d7c5139d9aae5536deb3d83e855f25f8e42f811c01f56f78054861682179055600c54821684528284208054861682179055600d54909116835290822080549093168117909255600890620002be6005546001600160a01b031690565b6001600160a01b03908116825260208083019390935260409182015f908120805495151560ff1996871617905560089093527f046fee3d77c34a6c5e10c3be6dc4b132c30449dbf4f0bc07684896dd093342998054851660019081179091553084528284208054861682179055600c54821684528284208054861682179055600d5490911683529082208054909316179091556200035a601290565b6200036790600a62000948565b6200037790633b9aca006200095f565b9050620003b1620003906005546001600160a01b031690565b60646200039f84600f6200095f565b620003ab919062000979565b6200048e565b620003c53060646200039f8460556200095f565b6103e8620003d260025490565b620003df9060016200095f565b620003eb919062000979565b600e556064620003fa60025490565b620004079060026200095f565b62000413919062000979565b60145550600f805462ffff0019169055620009af565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0905f90a35050565b620004898383836001620004ca565b505050565b6001600160a01b038216620004b95760405163ec442f0560e01b81525f600482015260240162000093565b620004c65f8383620005a3565b5050565b6001600160a01b038416620004f55760405163e602df0560e01b81525f600482015260240162000093565b6001600160a01b0383166200052057604051634a1406b160e11b81525f600482015260240162000093565b6001600160a01b038085165f90815260016020908152604080832093871683529290522082905580156200059d57826001600160a01b0316846001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925846040516200059491815260200190565b60405180910390a35b50505050565b6001600160a01b038316620005d1578060025f828254620005c5919062000999565b90915550620006439050565b6001600160a01b0383165f9081526020819052604090205481811015620006255760405163391434e360e21b81526001600160a01b0385166004820152602481018290526044810183905260640162000093565b6001600160a01b0384165f9081526020819052604090209082900390555b6001600160a01b03821662000661576002805482900390556200067f565b6001600160a01b0382165f9081526020819052604090208054820190555b816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051620006c591815260200190565b60405180910390a3505050565b634e487b7160e01b5f52604160045260245ffd5b600181811c90821680620006fb57607f821691505b6020821081036200071a57634e487b7160e01b5f52602260045260245ffd5b50919050565b601f82111562000489575f81815260208120601f850160051c81016020861015620007485750805b601f850160051c820191505b81811015620007695782815560010162000754565b505050505050565b81516001600160401b038111156200078d576200078d620006d2565b620007a5816200079e8454620006e6565b8462000720565b602080601f831160018114620007db575f8415620007c35750858301515b5f19600386901b1c1916600185901b17855562000769565b5f85815260208120601f198616915b828110156200080b57888601518255948401946001909101908401620007ea565b50858210156200082957878501515f19600388901b60f8161c191681555b5050505050600190811b01905550565b634e487b7160e01b5f52601160045260245ffd5b600181815b808511156200088d57815f190482111562000871576200087162000839565b808516156200087f57918102915b93841c939080029062000852565b509250929050565b5f82620008a55750600162000942565b81620008b357505f62000942565b8160018114620008cc5760028114620008d757620008f7565b600191505062000942565b60ff841115620008eb57620008eb62000839565b50506001821b62000942565b5060208310610133831016604e8410600b84101617156200091c575081810a62000942565b6200092883836200084d565b805f19048211156200093e576200093e62000839565b0290505b92915050565b5f6200095860ff84168362000895565b9392505050565b808202811582820484141762000942576200094262000839565b5f826200099457634e487b7160e01b5f52601260045260245ffd5b500490565b8082018082111562000942576200094262000839565b6122c180620009bd5f395ff3fe608060405260043610610220575f3560e01c80637ba54f1f1161011e578063b8158d60116100a8578063e01af92c1161006d578063e01af92c14610674578063e2f4560514610693578063e4e44893146106a8578063f2fde38b146106bd578063f9d0831a146106dc575f80fd5b8063b8158d60146105c8578063c0246668146105dd578063cd51e6d4146105fc578063d2fcc00114610611578063dd62ed3e14610630575f80fd5b806395d89b41116100ee57806395d89b411461052a578063a8a69b9d1461053e578063a9059cbb14610575578063aa4bde2814610594578063afa4f3b2146105a9575f80fd5b80637ba54f1f146104bb57806384e04d03146104da5780638a8c523c146104f95780638da5cb5b1461050d575f80fd5b806342966c68116101aa57806364be26c41161016f57806364be26c4146104175780636db79437146104365780636ddd17131461045557806370a0823114610473578063715018a6146104a7575f80fd5b806342966c6814610366578063486208d41461038557806349bd5a5e146103a25780634ada218b146103c15780634fbee193146103e0575f80fd5b806318160ddd116101f057806318160ddd146102de57806321a9d82a146102f257806323b872dd1461030b5780632a6c7dba1461032a578063313ce5671461034b575f80fd5b806306fdde031461022b578063095ea7b3146102555780630ce30294146102845780631694505e146102a7575f80fd5b3661022757005b5f80fd5b348015610236575f80fd5b5061023f6106fb565b60405161024c9190611ef7565b60405180910390f35b348015610260575f80fd5b5061027461026f366004611f56565b61078b565b604051901515815260200161024c565b34801561028f575f80fd5b50610299600a5481565b60405190815260200161024c565b3480156102b2575f80fd5b506006546102c6906001600160a01b031681565b6040516001600160a01b03909116815260200161024c565b3480156102e9575f80fd5b50600254610299565b3480156102fd575f80fd5b506013546102749060ff1681565b348015610316575f80fd5b50610274610325366004611f80565b6107a4565b348015610335575f80fd5b50610349610344366004611fcb565b6107c7565b005b348015610356575f80fd5b506040516012815260200161024c565b348015610371575f80fd5b50610349610380366004611fed565b610890565b348015610390575f80fd5b50600d546001600160a01b03166102c6565b3480156103ad575f80fd5b506007546102c6906001600160a01b031681565b3480156103cc575f80fd5b50600f546102749062010000900460ff1681565b3480156103eb575f80fd5b506102746103fa366004612004565b6001600160a01b03165f9081526008602052604090205460ff1690565b348015610422575f80fd5b50610349610431366004612004565b61089d565b348015610441575f80fd5b5061034961045036600461201f565b6109cc565b348015610460575f80fd5b50600f5461027490610100900460ff1681565b34801561047e575f80fd5b5061029961048d366004612004565b6001600160a01b03165f9081526020819052604090205490565b3480156104b2575f80fd5b50610349610a5f565b3480156104c6575f80fd5b506103496104d5366004612004565b610a72565b3480156104e5575f80fd5b50600c546102c6906001600160a01b031681565b348015610504575f80fd5b50610349610baf565b348015610518575f80fd5b506005546001600160a01b03166102c6565b348015610535575f80fd5b5061023f610f15565b348015610549575f80fd5b50610274610558366004612004565b6001600160a01b03165f9081526012602052604090205460ff1690565b348015610580575f80fd5b5061027461058f366004611f56565b610f24565b34801561059f575f80fd5b5061029960145481565b3480156105b4575f80fd5b506103496105c3366004611fed565b610f31565b3480156105d3575f80fd5b5061029960115481565b3480156105e8575f80fd5b506103496105f736600461203f565b611085565b348015610607575f80fd5b5061029960105481565b34801561061c575f80fd5b5061034961062b36600461203f565b61116e565b34801561063b575f80fd5b5061029961064a366004612076565b6001600160a01b039182165f90815260016020908152604080832093909416825291909152205490565b34801561067f575f80fd5b5061034961068e366004611fcb565b6112a0565b34801561069e575f80fd5b50610299600e5481565b3480156106b3575f80fd5b5061029960095481565b3480156106c8575f80fd5b506103496106d7366004612004565b61132f565b3480156106e7575f80fd5b506103496106f6366004612004565b611369565b60606003805461070a906120a2565b80601f0160208091040260200160405190810160405280929190818152602001828054610736906120a2565b80156107815780601f1061075857610100808354040283529160200191610781565b820191905f5260205f20905b81548152906001019060200180831161076457829003601f168201915b5050505050905090565b5f3361079881858561146a565b60019150505b92915050565b5f336107b185828561147c565b6107bc8585856114f1565b506001949350505050565b6107cf611959565b60135460ff161515811515036108425760405162461bcd60e51b815260206004820152602d60248201527f4d61782077616c6c6574206c696d697420697320616c7265616479207365742060448201526c746f207468617420737461746560981b60648201526084015b60405180910390fd5b6013805460ff191682151590811790915560405160ff909116151581527f670f884265aba2d05e7c26efbc42f8365effc4cb3fcfcefddba0c0b71a6231f1906020015b60405180910390a150565b61089a3382611986565b50565b6108a5611959565b600c546001600160a01b03908116908216036109145760405162461bcd60e51b815260206004820152602860248201527f466f72746966792077616c6c657420697320616c726561647920746861742061604482015267646472657373212160c01b6064820152608401610839565b6001600160a01b03811661097e5760405162461bcd60e51b815260206004820152602b60248201527f466f72746966792077616c6c65742063616e6e6f7420626520746865207a657260448201526a6f2061646472657373212160a81b6064820152608401610839565b600c80546001600160a01b0319166001600160a01b0383169081179091556040519081527f45dcdce2dd6137d32a91b8f74566f3091bad75b783080dc5de6cd9c95967ead590602001610885565b6109d4611959565b600a548211156109f65760405162461bcd60e51b8152600401610839906120da565b600954811115610a185760405162461bcd60e51b8152600401610839906120da565b600a829055600981905560408051838152602081018390527f53482196ef67ac615caab1c3eca2c270acbfdcd75e57c5f24c1b98b10c8e6e04910160405180910390a15050565b610a67611959565b610a705f6119be565b565b610a7a611a0f565b600d546001600160a01b0390811690821603610af05760405162461bcd60e51b815260206004820152602f60248201527f666f727469667944657657616c6c65742077616c6c657420697320616c72656160448201526e64792074686174206164647265737360881b6064820152608401610839565b6001600160a01b038116610b615760405162461bcd60e51b815260206004820152603260248201527f666f727469667944657657616c6c65742077616c6c65742063616e6e6f7420626044820152716520746865207a65726f206164647265737360701b6064820152608401610839565b600d80546001600160a01b0319166001600160a01b0383169081179091556040519081527fe2491a2abd15e120355965e3bef7a5e9570d67de30ffddb7fc7408d0cb5450f890602001610885565b610bb7611a0f565b600f5462010000900460ff1615610c105760405162461bcd60e51b815260206004820152601860248201527f54726164696e6720616c726561647920656e61626c65642e00000000000000006044820152606401610839565b60065f9054906101000a90046001600160a01b03166001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610c60573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610c849190612120565b6001600160a01b031663c9c653963060065f9054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610ce3573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610d079190612120565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303815f875af1158015610d51573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610d759190612120565b600780546001600160a01b0319166001600160a01b03929092169182179055610da19030905f1961146a565b60075460065460405163095ea7b360e01b81526001600160a01b0391821660048201525f19602482015291169063095ea7b3906044016020604051808303815f875af1158015610df3573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610e17919061213b565b506006546001600160a01b031663f305d7194730610e49816001600160a01b03165f9081526020819052604090205490565b5f80610e5d600d546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af1158015610ec3573d5f803e3d5ffd5b50505050506040513d601f19601f82011682018060405250810190610ee89190612156565b50506013805460ff1916600117905550600f80546201010062ffff00199091161790554360105542601155565b60606004805461070a906120a2565b5f336107988185856114f1565b610f39611959565b620f4240610f4660025490565b610f509190612195565b811015610fc55760405162461bcd60e51b815260206004820152603f60248201527f53776170546f6b656e734174416d6f756e74206d75737420626520677265617460448201527f6572207468616e20302e3030303125206f6620746f74616c20737570706c79006064820152608401610839565b6103e8610fd160025490565b610fdb9190612195565b8111156110505760405162461bcd60e51b815260206004820152603c60248201527f53776170546f6b656e734174416d6f756e74206d75737420626520677265617460448201527f6572207468616e20302e3125206f6620746f74616c20737570706c79000000006064820152608401610839565b600e8190556040518181527f7c26bfee26f82e8cb57af48f4019cc64582db6fac7bad778433f10572ae8b14590602001610885565b61108d611959565b6001600160a01b0382165f9081526008602052604090205481151560ff90911615150361110f5760405162461bcd60e51b815260206004820152602a60248201527f4163636f756e7420697320616c7265616479207468652076616c7565206f6620604482015269276578636c756465642760b01b6064820152608401610839565b6001600160a01b0382165f81815260086020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df791015b60405180910390a25050565b611176611959565b6001600160a01b0382165f9081526012602052604090205481151560ff9091161515036111f15760405162461bcd60e51b8152602060048201526024808201527f4163636f756e7420697320616c72656164792073657420746f207468617420736044820152637461746560e01b6064820152608401610839565b306001600160a01b038316036112495760405162461bcd60e51b815260206004820152601760248201527f43616e277420736574207468697320616464726573732e0000000000000000006044820152606401610839565b6001600160a01b0382165f81815260126020908152604091829020805460ff191685151590811790915591519182527f1d9a11e204b58ad56c619c61600e42167624659d218f0143f1f64956b0daae6c9101611162565b6112a8611959565b801515600f60019054906101000a900460ff161515036113155760405162461bcd60e51b815260206004820152602260248201527f73776170456e61626c656420616c726561647920617420746869732073746174604482015261329760f11b6064820152608401610839565b600f80549115156101000261ff0019909216919091179055565b611337611959565b6001600160a01b03811661136057604051631e4fbdf760e01b81525f6004820152602401610839565b61089a816119be565b611371611959565b6001600160a01b0381166113895761089a3347611a3c565b6040516370a0823160e01b815230600482015281905f906001600160a01b038316906370a0823190602401602060405180830381865afa1580156113cf573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906113f391906121b4565b60405163a9059cbb60e01b8152336004820152602481018290529091506001600160a01b0383169063a9059cbb906044016020604051808303815f875af1158015611440573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190611464919061213b565b50505050565b6114778383836001611acf565b505050565b6001600160a01b038381165f908152600160209081526040808320938616835292905220545f19811461146457818110156114e357604051637dc7a0d960e11b81526001600160a01b03841660048201526024810182905260448101839052606401610839565b61146484848484035f611acf565b6001600160a01b0383166115555760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610839565b6001600160a01b0382166115b75760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610839565b600f5462010000900460ff16806115e557506001600160a01b0383165f9081526008602052604090205460ff165b8061160757506001600160a01b0382165f9081526008602052604090205460ff165b6116535760405162461bcd60e51b815260206004820152601860248201527f54726164696e67206e6f742079657420656e61626c65642100000000000000006044820152606401610839565b805f036116655761147783835f611ba1565b305f90815260208190526040902054600e548110801590819061168b5750600f5460ff16155b80156116a457506007546001600160a01b038581169116145b80156116b75750600f54610100900460ff165b156116dd57600f805460ff191660011790556116d282611bfe565b600f805460ff191690555b5f806011546107086116ef91906121cb565b421115611704575050600954600a5490611750565b601154611713906104b06121cb565b421115611726575060199050600a611750565b6011546117359061012c6121cb565b4211156117485750601e9050600f611750565b506028905060145b6001600160a01b0387165f9081526008602052604081205460ff168061178d57506001600160a01b0387165f9081526008602052604090205460ff165b8061179a5750600f5460ff165b156117a657505f6117f4565b6007546001600160a01b03908116908916036117d45760105443116117cd575060636117f4565b50806117f4565b6007546001600160a01b03908116908816036117f15750816117f4565b505f5b801561184c575f606461180783896121de565b6118119190612195565b905061181d81886121f5565b965061182a893083611ba1565b611835600582612195565b600b5f82825461184591906121cb565b9091555050505b60135460ff1615611944576001600160a01b0388165f9081526012602052604090205460ff1615801561189757506001600160a01b0387165f9081526012602052604090205460ff16155b80156118b157506007546001600160a01b03888116911614155b15611944576001600160a01b0387165f908152602081905260409020546014546118db88836121cb565b11156119425760405162461bcd60e51b815260206004820152603060248201527f4d617857616c6c65743a20526563697069656e7420657863656564732074686560448201526f081b585e15d85b1b195d105b5bdd5b9d60821b6064820152608401610839565b505b61194f888888611ba1565b5050505050505050565b6005546001600160a01b03163314610a705760405163118cdaa760e01b8152336004820152602401610839565b6001600160a01b0382166119af57604051634b637e8f60e11b81525f6004820152602401610839565b6119ba825f83611dd1565b5050565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0905f90a35050565b600d546001600160a01b03163314610a7057604051638d11e4e560e01b8152336004820152602401610839565b80471015611a5f5760405163cd78605960e01b8152306004820152602401610839565b5f826001600160a01b0316826040515f6040518083038185875af1925050503d805f8114611aa8576040519150601f19603f3d011682016040523d82523d5f602084013e611aad565b606091505b505090508061147757604051630a12f52160e11b815260040160405180910390fd5b6001600160a01b038416611af85760405163e602df0560e01b81525f6004820152602401610839565b6001600160a01b038316611b2157604051634a1406b160e11b81525f6004820152602401610839565b6001600160a01b038085165f908152600160209081526040808320938716835292905220829055801561146457826001600160a01b0316846001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92584604051611b9391815260200190565b60405180910390a350505050565b6001600160a01b038316611bca57604051634b637e8f60e11b81525f6004820152602401610839565b6001600160a01b038216611bf35760405163ec442f0560e01b81525f6004820152602401610839565b611477838383611dd1565b60408051600280825260608201835247925f92919060208301908036833701905050905030815f81518110611c3557611c35612208565b6001600160a01b03928316602091820292909201810191909152600654604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015611c8c573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190611cb09190612120565b81600181518110611cc357611cc3612208565b6001600160a01b03928316602091820292909201015260065460405163791ac94760e01b815291169063791ac94790611d089086905f9086903090429060040161221c565b5f604051808303815f87803b158015611d1f575f80fd5b505af1158015611d31573d5f803e3d5ffd5b505050505f8247611d4291906121f5565b90505f84600b5483611d5491906121de565b611d5e9190612195565b600d54909150611d77906001600160a01b031682611a3c565b600c54611d8d906001600160a01b031647611a3c565b5f600b5560408051868152602081018490527fd2782fadcfb0ddee3f6b263eb998f3f8a75be129e5e4435842fb09b16b608ace910160405180910390a15050505050565b6001600160a01b038316611dfb578060025f828254611df091906121cb565b90915550611e6b9050565b6001600160a01b0383165f9081526020819052604090205481811015611e4d5760405163391434e360e21b81526001600160a01b03851660048201526024810182905260448101839052606401610839565b6001600160a01b0384165f9081526020819052604090209082900390555b6001600160a01b038216611e8757600280548290039055611ea5565b6001600160a01b0382165f9081526020819052604090208054820190555b816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051611eea91815260200190565b60405180910390a3505050565b5f6020808352835180828501525f5b81811015611f2257858101830151858201604001528201611f06565b505f604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b038116811461089a575f80fd5b5f8060408385031215611f67575f80fd5b8235611f7281611f42565b946020939093013593505050565b5f805f60608486031215611f92575f80fd5b8335611f9d81611f42565b92506020840135611fad81611f42565b929592945050506040919091013590565b801515811461089a575f80fd5b5f60208284031215611fdb575f80fd5b8135611fe681611fbe565b9392505050565b5f60208284031215611ffd575f80fd5b5035919050565b5f60208284031215612014575f80fd5b8135611fe681611f42565b5f8060408385031215612030575f80fd5b50508035926020909101359150565b5f8060408385031215612050575f80fd5b823561205b81611f42565b9150602083013561206b81611fbe565b809150509250929050565b5f8060408385031215612087575f80fd5b823561209281611f42565b9150602083013561206b81611f42565b600181811c908216806120b657607f821691505b6020821081036120d457634e487b7160e01b5f52602260045260245ffd5b50919050565b60208082526026908201527f4661696c65642121596f752063616e206f6e6c7920646563726561736520746860408201526565206665657360d01b606082015260800190565b5f60208284031215612130575f80fd5b8151611fe681611f42565b5f6020828403121561214b575f80fd5b8151611fe681611fbe565b5f805f60608486031215612168575f80fd5b8351925060208401519150604084015190509250925092565b634e487b7160e01b5f52601160045260245ffd5b5f826121af57634e487b7160e01b5f52601260045260245ffd5b500490565b5f602082840312156121c4575f80fd5b5051919050565b8082018082111561079e5761079e612181565b808202811582820484141761079e5761079e612181565b8181038181111561079e5761079e612181565b634e487b7160e01b5f52603260045260245ffd5b5f60a082018783526020878185015260a0604085015281875180845260c08601915082890193505f5b8181101561226a5784516001600160a01b031683529383019391830191600101612245565b50506001600160a01b0396909616606085015250505060800152939250505056fea26469706673582212205ef9712a5927bda18c23ecfd0ee0a20bebe3686780547ab6a8fd63a83fd8f30964736f6c63430008150033

Deployed Bytecode

0x608060405260043610610220575f3560e01c80637ba54f1f1161011e578063b8158d60116100a8578063e01af92c1161006d578063e01af92c14610674578063e2f4560514610693578063e4e44893146106a8578063f2fde38b146106bd578063f9d0831a146106dc575f80fd5b8063b8158d60146105c8578063c0246668146105dd578063cd51e6d4146105fc578063d2fcc00114610611578063dd62ed3e14610630575f80fd5b806395d89b41116100ee57806395d89b411461052a578063a8a69b9d1461053e578063a9059cbb14610575578063aa4bde2814610594578063afa4f3b2146105a9575f80fd5b80637ba54f1f146104bb57806384e04d03146104da5780638a8c523c146104f95780638da5cb5b1461050d575f80fd5b806342966c68116101aa57806364be26c41161016f57806364be26c4146104175780636db79437146104365780636ddd17131461045557806370a0823114610473578063715018a6146104a7575f80fd5b806342966c6814610366578063486208d41461038557806349bd5a5e146103a25780634ada218b146103c15780634fbee193146103e0575f80fd5b806318160ddd116101f057806318160ddd146102de57806321a9d82a146102f257806323b872dd1461030b5780632a6c7dba1461032a578063313ce5671461034b575f80fd5b806306fdde031461022b578063095ea7b3146102555780630ce30294146102845780631694505e146102a7575f80fd5b3661022757005b5f80fd5b348015610236575f80fd5b5061023f6106fb565b60405161024c9190611ef7565b60405180910390f35b348015610260575f80fd5b5061027461026f366004611f56565b61078b565b604051901515815260200161024c565b34801561028f575f80fd5b50610299600a5481565b60405190815260200161024c565b3480156102b2575f80fd5b506006546102c6906001600160a01b031681565b6040516001600160a01b03909116815260200161024c565b3480156102e9575f80fd5b50600254610299565b3480156102fd575f80fd5b506013546102749060ff1681565b348015610316575f80fd5b50610274610325366004611f80565b6107a4565b348015610335575f80fd5b50610349610344366004611fcb565b6107c7565b005b348015610356575f80fd5b506040516012815260200161024c565b348015610371575f80fd5b50610349610380366004611fed565b610890565b348015610390575f80fd5b50600d546001600160a01b03166102c6565b3480156103ad575f80fd5b506007546102c6906001600160a01b031681565b3480156103cc575f80fd5b50600f546102749062010000900460ff1681565b3480156103eb575f80fd5b506102746103fa366004612004565b6001600160a01b03165f9081526008602052604090205460ff1690565b348015610422575f80fd5b50610349610431366004612004565b61089d565b348015610441575f80fd5b5061034961045036600461201f565b6109cc565b348015610460575f80fd5b50600f5461027490610100900460ff1681565b34801561047e575f80fd5b5061029961048d366004612004565b6001600160a01b03165f9081526020819052604090205490565b3480156104b2575f80fd5b50610349610a5f565b3480156104c6575f80fd5b506103496104d5366004612004565b610a72565b3480156104e5575f80fd5b50600c546102c6906001600160a01b031681565b348015610504575f80fd5b50610349610baf565b348015610518575f80fd5b506005546001600160a01b03166102c6565b348015610535575f80fd5b5061023f610f15565b348015610549575f80fd5b50610274610558366004612004565b6001600160a01b03165f9081526012602052604090205460ff1690565b348015610580575f80fd5b5061027461058f366004611f56565b610f24565b34801561059f575f80fd5b5061029960145481565b3480156105b4575f80fd5b506103496105c3366004611fed565b610f31565b3480156105d3575f80fd5b5061029960115481565b3480156105e8575f80fd5b506103496105f736600461203f565b611085565b348015610607575f80fd5b5061029960105481565b34801561061c575f80fd5b5061034961062b36600461203f565b61116e565b34801561063b575f80fd5b5061029961064a366004612076565b6001600160a01b039182165f90815260016020908152604080832093909416825291909152205490565b34801561067f575f80fd5b5061034961068e366004611fcb565b6112a0565b34801561069e575f80fd5b50610299600e5481565b3480156106b3575f80fd5b5061029960095481565b3480156106c8575f80fd5b506103496106d7366004612004565b61132f565b3480156106e7575f80fd5b506103496106f6366004612004565b611369565b60606003805461070a906120a2565b80601f0160208091040260200160405190810160405280929190818152602001828054610736906120a2565b80156107815780601f1061075857610100808354040283529160200191610781565b820191905f5260205f20905b81548152906001019060200180831161076457829003601f168201915b5050505050905090565b5f3361079881858561146a565b60019150505b92915050565b5f336107b185828561147c565b6107bc8585856114f1565b506001949350505050565b6107cf611959565b60135460ff161515811515036108425760405162461bcd60e51b815260206004820152602d60248201527f4d61782077616c6c6574206c696d697420697320616c7265616479207365742060448201526c746f207468617420737461746560981b60648201526084015b60405180910390fd5b6013805460ff191682151590811790915560405160ff909116151581527f670f884265aba2d05e7c26efbc42f8365effc4cb3fcfcefddba0c0b71a6231f1906020015b60405180910390a150565b61089a3382611986565b50565b6108a5611959565b600c546001600160a01b03908116908216036109145760405162461bcd60e51b815260206004820152602860248201527f466f72746966792077616c6c657420697320616c726561647920746861742061604482015267646472657373212160c01b6064820152608401610839565b6001600160a01b03811661097e5760405162461bcd60e51b815260206004820152602b60248201527f466f72746966792077616c6c65742063616e6e6f7420626520746865207a657260448201526a6f2061646472657373212160a81b6064820152608401610839565b600c80546001600160a01b0319166001600160a01b0383169081179091556040519081527f45dcdce2dd6137d32a91b8f74566f3091bad75b783080dc5de6cd9c95967ead590602001610885565b6109d4611959565b600a548211156109f65760405162461bcd60e51b8152600401610839906120da565b600954811115610a185760405162461bcd60e51b8152600401610839906120da565b600a829055600981905560408051838152602081018390527f53482196ef67ac615caab1c3eca2c270acbfdcd75e57c5f24c1b98b10c8e6e04910160405180910390a15050565b610a67611959565b610a705f6119be565b565b610a7a611a0f565b600d546001600160a01b0390811690821603610af05760405162461bcd60e51b815260206004820152602f60248201527f666f727469667944657657616c6c65742077616c6c657420697320616c72656160448201526e64792074686174206164647265737360881b6064820152608401610839565b6001600160a01b038116610b615760405162461bcd60e51b815260206004820152603260248201527f666f727469667944657657616c6c65742077616c6c65742063616e6e6f7420626044820152716520746865207a65726f206164647265737360701b6064820152608401610839565b600d80546001600160a01b0319166001600160a01b0383169081179091556040519081527fe2491a2abd15e120355965e3bef7a5e9570d67de30ffddb7fc7408d0cb5450f890602001610885565b610bb7611a0f565b600f5462010000900460ff1615610c105760405162461bcd60e51b815260206004820152601860248201527f54726164696e6720616c726561647920656e61626c65642e00000000000000006044820152606401610839565b60065f9054906101000a90046001600160a01b03166001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610c60573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610c849190612120565b6001600160a01b031663c9c653963060065f9054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610ce3573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610d079190612120565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303815f875af1158015610d51573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610d759190612120565b600780546001600160a01b0319166001600160a01b03929092169182179055610da19030905f1961146a565b60075460065460405163095ea7b360e01b81526001600160a01b0391821660048201525f19602482015291169063095ea7b3906044016020604051808303815f875af1158015610df3573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610e17919061213b565b506006546001600160a01b031663f305d7194730610e49816001600160a01b03165f9081526020819052604090205490565b5f80610e5d600d546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af1158015610ec3573d5f803e3d5ffd5b50505050506040513d601f19601f82011682018060405250810190610ee89190612156565b50506013805460ff1916600117905550600f80546201010062ffff00199091161790554360105542601155565b60606004805461070a906120a2565b5f336107988185856114f1565b610f39611959565b620f4240610f4660025490565b610f509190612195565b811015610fc55760405162461bcd60e51b815260206004820152603f60248201527f53776170546f6b656e734174416d6f756e74206d75737420626520677265617460448201527f6572207468616e20302e3030303125206f6620746f74616c20737570706c79006064820152608401610839565b6103e8610fd160025490565b610fdb9190612195565b8111156110505760405162461bcd60e51b815260206004820152603c60248201527f53776170546f6b656e734174416d6f756e74206d75737420626520677265617460448201527f6572207468616e20302e3125206f6620746f74616c20737570706c79000000006064820152608401610839565b600e8190556040518181527f7c26bfee26f82e8cb57af48f4019cc64582db6fac7bad778433f10572ae8b14590602001610885565b61108d611959565b6001600160a01b0382165f9081526008602052604090205481151560ff90911615150361110f5760405162461bcd60e51b815260206004820152602a60248201527f4163636f756e7420697320616c7265616479207468652076616c7565206f6620604482015269276578636c756465642760b01b6064820152608401610839565b6001600160a01b0382165f81815260086020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df791015b60405180910390a25050565b611176611959565b6001600160a01b0382165f9081526012602052604090205481151560ff9091161515036111f15760405162461bcd60e51b8152602060048201526024808201527f4163636f756e7420697320616c72656164792073657420746f207468617420736044820152637461746560e01b6064820152608401610839565b306001600160a01b038316036112495760405162461bcd60e51b815260206004820152601760248201527f43616e277420736574207468697320616464726573732e0000000000000000006044820152606401610839565b6001600160a01b0382165f81815260126020908152604091829020805460ff191685151590811790915591519182527f1d9a11e204b58ad56c619c61600e42167624659d218f0143f1f64956b0daae6c9101611162565b6112a8611959565b801515600f60019054906101000a900460ff161515036113155760405162461bcd60e51b815260206004820152602260248201527f73776170456e61626c656420616c726561647920617420746869732073746174604482015261329760f11b6064820152608401610839565b600f80549115156101000261ff0019909216919091179055565b611337611959565b6001600160a01b03811661136057604051631e4fbdf760e01b81525f6004820152602401610839565b61089a816119be565b611371611959565b6001600160a01b0381166113895761089a3347611a3c565b6040516370a0823160e01b815230600482015281905f906001600160a01b038316906370a0823190602401602060405180830381865afa1580156113cf573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906113f391906121b4565b60405163a9059cbb60e01b8152336004820152602481018290529091506001600160a01b0383169063a9059cbb906044016020604051808303815f875af1158015611440573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190611464919061213b565b50505050565b6114778383836001611acf565b505050565b6001600160a01b038381165f908152600160209081526040808320938616835292905220545f19811461146457818110156114e357604051637dc7a0d960e11b81526001600160a01b03841660048201526024810182905260448101839052606401610839565b61146484848484035f611acf565b6001600160a01b0383166115555760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610839565b6001600160a01b0382166115b75760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610839565b600f5462010000900460ff16806115e557506001600160a01b0383165f9081526008602052604090205460ff165b8061160757506001600160a01b0382165f9081526008602052604090205460ff165b6116535760405162461bcd60e51b815260206004820152601860248201527f54726164696e67206e6f742079657420656e61626c65642100000000000000006044820152606401610839565b805f036116655761147783835f611ba1565b305f90815260208190526040902054600e548110801590819061168b5750600f5460ff16155b80156116a457506007546001600160a01b038581169116145b80156116b75750600f54610100900460ff165b156116dd57600f805460ff191660011790556116d282611bfe565b600f805460ff191690555b5f806011546107086116ef91906121cb565b421115611704575050600954600a5490611750565b601154611713906104b06121cb565b421115611726575060199050600a611750565b6011546117359061012c6121cb565b4211156117485750601e9050600f611750565b506028905060145b6001600160a01b0387165f9081526008602052604081205460ff168061178d57506001600160a01b0387165f9081526008602052604090205460ff165b8061179a5750600f5460ff165b156117a657505f6117f4565b6007546001600160a01b03908116908916036117d45760105443116117cd575060636117f4565b50806117f4565b6007546001600160a01b03908116908816036117f15750816117f4565b505f5b801561184c575f606461180783896121de565b6118119190612195565b905061181d81886121f5565b965061182a893083611ba1565b611835600582612195565b600b5f82825461184591906121cb565b9091555050505b60135460ff1615611944576001600160a01b0388165f9081526012602052604090205460ff1615801561189757506001600160a01b0387165f9081526012602052604090205460ff16155b80156118b157506007546001600160a01b03888116911614155b15611944576001600160a01b0387165f908152602081905260409020546014546118db88836121cb565b11156119425760405162461bcd60e51b815260206004820152603060248201527f4d617857616c6c65743a20526563697069656e7420657863656564732074686560448201526f081b585e15d85b1b195d105b5bdd5b9d60821b6064820152608401610839565b505b61194f888888611ba1565b5050505050505050565b6005546001600160a01b03163314610a705760405163118cdaa760e01b8152336004820152602401610839565b6001600160a01b0382166119af57604051634b637e8f60e11b81525f6004820152602401610839565b6119ba825f83611dd1565b5050565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0905f90a35050565b600d546001600160a01b03163314610a7057604051638d11e4e560e01b8152336004820152602401610839565b80471015611a5f5760405163cd78605960e01b8152306004820152602401610839565b5f826001600160a01b0316826040515f6040518083038185875af1925050503d805f8114611aa8576040519150601f19603f3d011682016040523d82523d5f602084013e611aad565b606091505b505090508061147757604051630a12f52160e11b815260040160405180910390fd5b6001600160a01b038416611af85760405163e602df0560e01b81525f6004820152602401610839565b6001600160a01b038316611b2157604051634a1406b160e11b81525f6004820152602401610839565b6001600160a01b038085165f908152600160209081526040808320938716835292905220829055801561146457826001600160a01b0316846001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92584604051611b9391815260200190565b60405180910390a350505050565b6001600160a01b038316611bca57604051634b637e8f60e11b81525f6004820152602401610839565b6001600160a01b038216611bf35760405163ec442f0560e01b81525f6004820152602401610839565b611477838383611dd1565b60408051600280825260608201835247925f92919060208301908036833701905050905030815f81518110611c3557611c35612208565b6001600160a01b03928316602091820292909201810191909152600654604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015611c8c573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190611cb09190612120565b81600181518110611cc357611cc3612208565b6001600160a01b03928316602091820292909201015260065460405163791ac94760e01b815291169063791ac94790611d089086905f9086903090429060040161221c565b5f604051808303815f87803b158015611d1f575f80fd5b505af1158015611d31573d5f803e3d5ffd5b505050505f8247611d4291906121f5565b90505f84600b5483611d5491906121de565b611d5e9190612195565b600d54909150611d77906001600160a01b031682611a3c565b600c54611d8d906001600160a01b031647611a3c565b5f600b5560408051868152602081018490527fd2782fadcfb0ddee3f6b263eb998f3f8a75be129e5e4435842fb09b16b608ace910160405180910390a15050505050565b6001600160a01b038316611dfb578060025f828254611df091906121cb565b90915550611e6b9050565b6001600160a01b0383165f9081526020819052604090205481811015611e4d5760405163391434e360e21b81526001600160a01b03851660048201526024810182905260448101839052606401610839565b6001600160a01b0384165f9081526020819052604090209082900390555b6001600160a01b038216611e8757600280548290039055611ea5565b6001600160a01b0382165f9081526020819052604090208054820190555b816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051611eea91815260200190565b60405180910390a3505050565b5f6020808352835180828501525f5b81811015611f2257858101830151858201604001528201611f06565b505f604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b038116811461089a575f80fd5b5f8060408385031215611f67575f80fd5b8235611f7281611f42565b946020939093013593505050565b5f805f60608486031215611f92575f80fd5b8335611f9d81611f42565b92506020840135611fad81611f42565b929592945050506040919091013590565b801515811461089a575f80fd5b5f60208284031215611fdb575f80fd5b8135611fe681611fbe565b9392505050565b5f60208284031215611ffd575f80fd5b5035919050565b5f60208284031215612014575f80fd5b8135611fe681611f42565b5f8060408385031215612030575f80fd5b50508035926020909101359150565b5f8060408385031215612050575f80fd5b823561205b81611f42565b9150602083013561206b81611fbe565b809150509250929050565b5f8060408385031215612087575f80fd5b823561209281611f42565b9150602083013561206b81611f42565b600181811c908216806120b657607f821691505b6020821081036120d457634e487b7160e01b5f52602260045260245ffd5b50919050565b60208082526026908201527f4661696c65642121596f752063616e206f6e6c7920646563726561736520746860408201526565206665657360d01b606082015260800190565b5f60208284031215612130575f80fd5b8151611fe681611f42565b5f6020828403121561214b575f80fd5b8151611fe681611fbe565b5f805f60608486031215612168575f80fd5b8351925060208401519150604084015190509250925092565b634e487b7160e01b5f52601160045260245ffd5b5f826121af57634e487b7160e01b5f52601260045260245ffd5b500490565b5f602082840312156121c4575f80fd5b5051919050565b8082018082111561079e5761079e612181565b808202811582820484141761079e5761079e612181565b8181038181111561079e5761079e612181565b634e487b7160e01b5f52603260045260245ffd5b5f60a082018783526020878185015260a0604085015281875180845260c08601915082890193505f5b8181101561226a5784516001600160a01b031683529383019391830191600101612245565b50506001600160a01b0396909616606085015250505060800152939250505056fea26469706673582212205ef9712a5927bda18c23ecfd0ee0a20bebe3686780547ab6a8fd63a83fd8f30964736f6c63430008150033

Deployed Bytecode Sourcemap

39728:12580:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;26917:91;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;29210:190;;;;;;;;;;-1:-1:-1;29210:190:0;;;;;:::i;:::-;;:::i;:::-;;;1188:14:1;;1181:22;1163:41;;1151:2;1136:18;29210:190:0;1023:187:1;39994:25:0;;;;;;;;;;;;;;;;;;;1361::1;;;1349:2;1334:18;39994:25:0;1215:177:1;39817:41:0;;;;;;;;;;-1:-1:-1;39817:41:0;;;;-1:-1:-1;;;;;39817:41:0;;;;;;-1:-1:-1;;;;;1587:32:1;;;1569:51;;1557:2;1542:18;39817:41:0;1397:229:1;28019:99:0;;;;;;;;;;-1:-1:-1;28098:12:0;;28019:99;;51055:33;;;;;;;;;;-1:-1:-1;51055:33:0;;;;;;;;29978:249;;;;;;;;;;-1:-1:-1;29978:249:0;;;;;:::i;:::-;;:::i;51342:318::-;;;;;;;;;;-1:-1:-1;51342:318:0;;;;;:::i;:::-;;:::i;:::-;;27870:84;;;;;;;;;;-1:-1:-1;27870:84:0;;27944:2;2603:36:1;;2591:2;2576:18;27870:84:0;2461:184:1;42969:83:0;;;;;;;;;;-1:-1:-1;42969:83:0;;;;;:::i;:::-;;:::i;43611:111::-;;;;;;;;;;-1:-1:-1;43698:16:0;;-1:-1:-1;;;;;43698:16:0;43611:111;;39865:28;;;;;;;;;;-1:-1:-1;39865:28:0;;;;-1:-1:-1;;;;;39865:28:0;;;45610:26;;;;;;;;;;-1:-1:-1;45610:26:0;;;;;;;;;;;44090:126;;;;;;;;;;-1:-1:-1;44090:126:0;;;;;:::i;:::-;-1:-1:-1;;;;;44180:28:0;44156:4;44180:28;;;:19;:28;;;;;;;;;44090:126;44636:438;;;;;;;;;;-1:-1:-1;44636:438:0;;;;;:::i;:::-;;:::i;44224:404::-;;;;;;;;;;-1:-1:-1;44224:404:0;;;;;:::i;:::-;;:::i;40214:23::-;;;;;;;;;;-1:-1:-1;40214:23:0;;;;;;;;;;;28181:118;;;;;;;;;;-1:-1:-1;28181:118:0;;;;;:::i;:::-;-1:-1:-1;;;;;28273:18:0;28246:7;28273:18;;;;;;;;;;;;28181:118;38624:103;;;;;;;;;;;;;:::i;45082:520::-;;;;;;;;;;-1:-1:-1;45082:520:0;;;;;:::i;:::-;;:::i;40068:28::-;;;;;;;;;;-1:-1:-1;40068:28:0;;;;-1:-1:-1;;;;;40068:28:0;;;45712:915;;;;;;;;;;;;;:::i;37949:87::-;;;;;;;;;;-1:-1:-1;38022:6:0;;-1:-1:-1;;;;;38022:6:0;37949:87;;27127:95;;;;;;;;;;;;;:::i;52127:178::-;;;;;;;;;;-1:-1:-1;52127:178:0;;;;;:::i;:::-;-1:-1:-1;;;;;52259:38:0;52230:4;52259:38;;;:29;:38;;;;;;;;;52127:178;28504:182;;;;;;;;;;-1:-1:-1;28504:182:0;;;;;:::i;:::-;;:::i;51095:30::-;;;;;;;;;;;;;;;;49609:498;;;;;;;;;;-1:-1:-1;49609:498:0;;;;;:::i;:::-;;:::i;45677:26::-;;;;;;;;;;;;;;;;43730:352;;;;;;;;;;-1:-1:-1;43730:352:0;;;;;:::i;:::-;;:::i;45643:27::-;;;;;;;;;;;;;;;;51668:451;;;;;;;;;;-1:-1:-1;51668:451:0;;;;;:::i;:::-;;:::i;28749:142::-;;;;;;;;;;-1:-1:-1;28749:142:0;;;;;:::i;:::-;-1:-1:-1;;;;;28856:18:0;;;28829:7;28856:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;28749:142;49421:180;;;;;;;;;;-1:-1:-1;49421:180:0;;;;;:::i;:::-;;:::i;40144:33::-;;;;;;;;;;;;;;;;39963:24;;;;;;;;;;;;;;;;38882:220;;;;;;;;;;-1:-1:-1;38882:220:0;;;;;:::i;:::-;;:::i;43060:364::-;;;;;;;;;;-1:-1:-1;43060:364:0;;;;;:::i;:::-;;:::i;26917:91::-;26962:13;26995:5;26988:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;26917:91;:::o;29210:190::-;29283:4;24732:10;29339:31;24732:10;29355:7;29364:5;29339:8;:31::i;:::-;29388:4;29381:11;;;29210:190;;;;;:::o;29978:249::-;30065:4;24732:10;30123:37;30139:4;24732:10;30154:5;30123:15;:37::i;:::-;30171:26;30181:4;30187:2;30191:5;30171:9;:26::i;:::-;-1:-1:-1;30215:4:0;;29978:249;-1:-1:-1;;;;29978:249:0:o;51342:318::-;37835:13;:11;:13::i;:::-;51450:21:::1;::::0;::::1;;51440:31;;::::0;::::1;;::::0;51418:126:::1;;;::::0;-1:-1:-1;;;51418:126:0;;4915:2:1;51418:126:0::1;::::0;::::1;4897:21:1::0;4954:2;4934:18;;;4927:30;4993:34;4973:18;;;4966:62;-1:-1:-1;;;5044:18:1;;;5037:43;5097:19;;51418:126:0::1;;;;;;;;;51555:21;:30:::0;;-1:-1:-1;;51555:30:0::1;::::0;::::1;;::::0;;::::1;::::0;;;51603:49:::1;::::0;51555:30:::1;51630:21:::0;;;1188:14:1;1181:22;1163:41;;51603:49:0::1;::::0;1151:2:1;1136:18;51603:49:0::1;;;;;;;;51342:318:::0;:::o;42969:83::-;43019:25;43025:10;43037:6;43019:5;:25::i;:::-;42969:83;:::o;44636:438::-;37835:13;:11;:13::i;:::-;44759::::1;::::0;-1:-1:-1;;;;;44759:13:0;;::::1;44741:31:::0;;::::1;::::0;44719:121:::1;;;::::0;-1:-1:-1;;;44719:121:0;;5329:2:1;44719:121:0::1;::::0;::::1;5311:21:1::0;5368:2;5348:18;;;5341:30;5407:34;5387:18;;;5380:62;-1:-1:-1;;;5458:18:1;;;5451:38;5506:19;;44719:121:0::1;5127:404:1::0;44719:121:0::1;-1:-1:-1::0;;;;;44873:28:0;::::1;44851:121;;;::::0;-1:-1:-1;;;44851:121:0;;5738:2:1;44851:121:0::1;::::0;::::1;5720:21:1::0;5777:2;5757:18;;;5750:30;5816:34;5796:18;;;5789:62;-1:-1:-1;;;5867:18:1;;;5860:41;5918:19;;44851:121:0::1;5536:407:1::0;44851:121:0::1;44983:13;:30:::0;;-1:-1:-1;;;;;;44983:30:0::1;-1:-1:-1::0;;;;;44983:30:0;::::1;::::0;;::::1;::::0;;;45031:35:::1;::::0;1569:51:1;;;45031:35:0::1;::::0;1557:2:1;1542:18;45031:35:0::1;1397:229:1::0;44224:404:0;37835:13;:11;:13::i;:::-;44361:10:::1;;44346:11;:25;;44338:76;;;;-1:-1:-1::0;;;44338:76:0::1;;;;;;;:::i;:::-;44447:9;;44433:10;:23;;44425:74;;;;-1:-1:-1::0;;;44425:74:0::1;;;;;;;:::i;:::-;44512:10;:24:::0;;;44547:9:::1;:22:::0;;;44587:33:::1;::::0;;6529:25:1;;;6585:2;6570:18;;6563:34;;;44587:33:0::1;::::0;6502:18:1;44587:33:0::1;;;;;;;44224:404:::0;;:::o;38624:103::-;37835:13;:11;:13::i;:::-;38689:30:::1;38716:1;38689:18;:30::i;:::-;38624:103::o:0;45082:520::-;40723:17;:15;:17::i;:::-;45251:16:::1;::::0;-1:-1:-1;;;;;45251:16:0;;::::1;45228:39:::0;;::::1;::::0;45206:136:::1;;;::::0;-1:-1:-1;;;45206:136:0;;6810:2:1;45206:136:0::1;::::0;::::1;6792:21:1::0;6849:2;6829:18;;;6822:30;6888:34;6868:18;;;6861:62;-1:-1:-1;;;6939:18:1;;;6932:45;6994:19;;45206:136:0::1;6608:411:1::0;45206:136:0::1;-1:-1:-1::0;;;;;45375:33:0;::::1;45353:133;;;::::0;-1:-1:-1;;;45353:133:0;;7226:2:1;45353:133:0::1;::::0;::::1;7208:21:1::0;7265:2;7245:18;;;7238:30;7304:34;7284:18;;;7277:62;-1:-1:-1;;;7355:18:1;;;7348:48;7413:19;;45353:133:0::1;7024:414:1::0;45353:133:0::1;45497:16;:38:::0;;-1:-1:-1;;;;;;45497:38:0::1;-1:-1:-1::0;;;;;45497:38:0;::::1;::::0;;::::1;::::0;;;45553:41:::1;::::0;1569:51:1;;;45553:41:0::1;::::0;1557:2:1;1542:18;45553:41:0::1;1397:229:1::0;45712:915:0;40723:17;:15;:17::i;:::-;45787:14:::1;::::0;;;::::1;;;45786:15;45778:52;;;::::0;-1:-1:-1;;;45778:52:0;;7645:2:1;45778:52:0::1;::::0;::::1;7627:21:1::0;7684:2;7664:18;;;7657:30;7723:26;7703:18;;;7696:54;7767:18;;45778:52:0::1;7443:348:1::0;45778:52:0::1;45877:15;;;;;;;;;-1:-1:-1::0;;;;;45877:15:0::1;-1:-1:-1::0;;;;;45877:23:0::1;;:25;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;;;;45859:55:0::1;;45937:4;45957:15;;;;;;;;;-1:-1:-1::0;;;;;45957:15:0::1;-1:-1:-1::0;;;;;45957:20:0::1;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;45859:131;::::0;-1:-1:-1;;;;;;45859:131:0::1;::::0;;;;;;-1:-1:-1;;;;;8282:15:1;;;45859:131:0::1;::::0;::::1;8264:34:1::0;8334:15;;8314:18;;;8307:43;8199:18;;45859:131:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;45843:13;:147:::0;;-1:-1:-1;;;;;;45843:147:0::1;-1:-1:-1::0;;;;;45843:147:0;;;::::1;::::0;;::::1;::::0;;46001:66:::1;::::0;46018:4:::1;::::0;-1:-1:-1;;46001:8:0::1;:66::i;:::-;46085:13;::::0;46130:15:::1;::::0;46078:111:::1;::::0;-1:-1:-1;;;46078:111:0;;-1:-1:-1;;;;;46130:15:0;;::::1;46078:111;::::0;::::1;8535:51:1::0;-1:-1:-1;;8602:18:1;;;8595:34;46085:13:0;::::1;::::0;46078:29:::1;::::0;8508:18:1;;46078:111:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;46202:15:0::1;::::0;-1:-1:-1;;;;;46202:15:0::1;:31;46241:21;46286:4;46306:24;46286:4:::0;-1:-1:-1;;;;;28273:18:0;28246:7;28273:18;;;;;;;;;;;;28181:118;46306:24:::1;46345:1;46361::::0;46377:21:::1;43698:16:::0;;-1:-1:-1;;;;;43698:16:0;;43611:111;46377:21:::1;46202:237;::::0;::::1;::::0;;;-1:-1:-1;;;;;;46202:237:0;;;-1:-1:-1;;;;;9249:15:1;;;46202:237:0::1;::::0;::::1;9231:34:1::0;9281:18;;;9274:34;;;;9324:18;;;9317:34;;;;9367:18;;;9360:34;9431:15;;;9410:19;;;9403:44;46413:15:0::1;9463:19:1::0;;;9456:35;9165:19;;46202:237:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;46452:21:0::1;:28:::0;;-1:-1:-1;;46452:28:0::1;46476:4;46452:28;::::0;;-1:-1:-1;46491:14:0::1;:21:::0;;46523:18;-1:-1:-1;;46523:18:0;;;;;;46567:12:::1;46552;:27:::0;46604:15:::1;46590:11;:29:::0;45712:915::o;27127:95::-;27174:13;27207:7;27200:14;;;;;:::i;28504:182::-;28573:4;24732:10;28629:27;24732:10;28646:2;28650:5;28629:9;:27::i;49609:498::-;37835:13;:11;:13::i;:::-;49740:9:::1;49724:13;28098:12:::0;;;28019:99;49724:13:::1;:25;;;;:::i;:::-;49711:9;:38;;49689:151;;;::::0;-1:-1:-1;;;49689:151:0;;10369:2:1;49689:151:0::1;::::0;::::1;10351:21:1::0;10408:2;10388:18;;;10381:30;10447:34;10427:18;;;10420:62;10518:33;10498:18;;;10491:61;10569:19;;49689:151:0::1;10167:427:1::0;49689:151:0::1;49902:5;49886:13;28098:12:::0;;;28019:99;49886:13:::1;:21;;;;:::i;:::-;49873:9;:34;;49851:144;;;::::0;-1:-1:-1;;;49851:144:0;;10801:2:1;49851:144:0::1;::::0;::::1;10783:21:1::0;10840:2;10820:18;;;10813:30;10879:34;10859:18;;;10852:62;10950:30;10930:18;;;10923:58;10998:19;;49851:144:0::1;10599:424:1::0;49851:144:0::1;50006:18;:30:::0;;;50054:45:::1;::::0;1361:25:1;;;50054:45:0::1;::::0;1349:2:1;1334:18;50054:45:0::1;1215:177:1::0;43730:352:0;37835:13;:11;:13::i;:::-;-1:-1:-1;;;;;43862:28:0;::::1;;::::0;;;:19:::1;:28;::::0;;;;;:40;::::1;;:28;::::0;;::::1;:40;;::::0;43840:132:::1;;;::::0;-1:-1:-1;;;43840:132:0;;11230:2:1;43840:132:0::1;::::0;::::1;11212:21:1::0;11269:2;11249:18;;;11242:30;11308:34;11288:18;;;11281:62;-1:-1:-1;;;11359:18:1;;;11352:40;11409:19;;43840:132:0::1;11028:406:1::0;43840:132:0::1;-1:-1:-1::0;;;;;43983:28:0;::::1;;::::0;;;:19:::1;:28;::::0;;;;;;;;:39;;-1:-1:-1;;43983:39:0::1;::::0;::::1;;::::0;;::::1;::::0;;;44040:34;;1163:41:1;;;44040:34:0::1;::::0;1136:18:1;44040:34:0::1;;;;;;;;43730:352:::0;;:::o;51668:451::-;37835:13;:11;:13::i;:::-;-1:-1:-1;;;;;51804:38:0;::::1;;::::0;;;:29:::1;:38;::::0;;;;;:49;::::1;;:38;::::0;;::::1;:49;;::::0;51782:135:::1;;;::::0;-1:-1:-1;;;51782:135:0;;11641:2:1;51782:135:0::1;::::0;::::1;11623:21:1::0;11680:2;11660:18;;;11653:30;11719:34;11699:18;;;11692:62;-1:-1:-1;;;11770:18:1;;;11763:34;11814:19;;51782:135:0::1;11439:400:1::0;51782:135:0::1;51955:4;-1:-1:-1::0;;;;;51936:24:0;::::1;::::0;51928:60:::1;;;::::0;-1:-1:-1;;;51928:60:0;;12046:2:1;51928:60:0::1;::::0;::::1;12028:21:1::0;12085:2;12065:18;;;12058:30;12124:25;12104:18;;;12097:53;12167:18;;51928:60:0::1;11844:347:1::0;51928:60:0::1;-1:-1:-1::0;;;;;52001:38:0;::::1;;::::0;;;:29:::1;:38;::::0;;;;;;;;:48;;-1:-1:-1;;52001:48:0::1;::::0;::::1;;::::0;;::::1;::::0;;;52067:44;;1163:41:1;;;52067:44:0::1;::::0;1136:18:1;52067:44:0::1;1023:187:1::0;49421:180:0;37835:13;:11;:13::i;:::-;49513:8:::1;49498:23;;:11;;;;;;;;;;;:23;;::::0;49490:70:::1;;;::::0;-1:-1:-1;;;49490:70:0;;12398:2:1;49490:70:0::1;::::0;::::1;12380:21:1::0;12437:2;12417:18;;;12410:30;12476:34;12456:18;;;12449:62;-1:-1:-1;;;12527:18:1;;;12520:32;12569:19;;49490:70:0::1;12196:398:1::0;49490:70:0::1;49571:11;:22:::0;;;::::1;;;;-1:-1:-1::0;;49571:22:0;;::::1;::::0;;;::::1;::::0;;49421:180::o;38882:220::-;37835:13;:11;:13::i;:::-;-1:-1:-1;;;;;38967:22:0;::::1;38963:93;;39013:31;::::0;-1:-1:-1;;;39013:31:0;;39041:1:::1;39013:31;::::0;::::1;1569:51:1::0;1542:18;;39013:31:0::1;1397:229:1::0;38963:93:0::1;39066:28;39085:8;39066:18;:28::i;43060:364::-:0;37835:13;:11;:13::i;:::-;-1:-1:-1;;;;;43135:21:0;::::1;43131:127;;43173:52;43181:10;43203:21;43173:29;:52::i;43131:127::-;43330:35;::::0;-1:-1:-1;;;43330:35:0;;43359:4:::1;43330:35;::::0;::::1;1569:51:1::0;43295:5:0;;43268:17:::1;::::0;-1:-1:-1;;;;;43330:20:0;::::1;::::0;::::1;::::0;1542:18:1;;43330:35:0::1;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;43376:40;::::0;-1:-1:-1;;;43376:40:0;;43396:10:::1;43376:40;::::0;::::1;8535:51:1::0;8602:18;;;8595:34;;;43312:53:0;;-1:-1:-1;;;;;;43376:19:0;::::1;::::0;::::1;::::0;8508:18:1;;43376:40:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;43120:304;;43060:364:::0;:::o;34045:130::-;34130:37;34139:5;34146:7;34155:5;34162:4;34130:8;:37::i;:::-;34045:130;;;:::o;35761:487::-;-1:-1:-1;;;;;28856:18:0;;;35861:24;28856:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;-1:-1:-1;;35928:37:0;;35924:317;;36005:5;35986:16;:24;35982:132;;;36038:60;;-1:-1:-1;;;36038:60:0;;-1:-1:-1;;;;;13008:32:1;;36038:60:0;;;12990:51:1;13057:18;;;13050:34;;;13100:18;;;13093:34;;;12963:18;;36038:60:0;12788:345:1;35982:132:0;36157:57;36166:5;36173:7;36201:5;36182:16;:24;36208:5;36157:8;:57::i;46635:2778::-;-1:-1:-1;;;;;46767:18:0;;46759:68;;;;-1:-1:-1;;;46759:68:0;;13340:2:1;46759:68:0;;;13322:21:1;13379:2;13359:18;;;13352:30;13418:34;13398:18;;;13391:62;-1:-1:-1;;;13469:18:1;;;13462:35;13514:19;;46759:68:0;13138:401:1;46759:68:0;-1:-1:-1;;;;;46846:16:0;;46838:64;;;;-1:-1:-1;;;46838:64:0;;13746:2:1;46838:64:0;;;13728:21:1;13785:2;13765:18;;;13758:30;13824:34;13804:18;;;13797:62;-1:-1:-1;;;13875:18:1;;;13868:33;13918:19;;46838:64:0;13544:399:1;46838:64:0;46935:14;;;;;;;;:60;;-1:-1:-1;;;;;;46970:25:0;;;;;;:19;:25;;;;;;;;46935:60;:104;;;-1:-1:-1;;;;;;47016:23:0;;;;;;:19;:23;;;;;;;;46935:104;46913:178;;;;-1:-1:-1;;;46913:178:0;;14150:2:1;46913:178:0;;;14132:21:1;14189:2;14169:18;;;14162:30;14228:26;14208:18;;;14201:54;14272:18;;46913:178:0;13948:348:1;46913:178:0;47108:6;47118:1;47108:11;47104:93;;47136:28;47152:4;47158:2;47162:1;47136:15;:28::i;47104:93::-;47258:4;47209:28;28273:18;;;;;;;;;;;47316;;47292:42;;;;;;;47351:20;;-1:-1:-1;47363:8:0;;;;47362:9;47351:20;:43;;;;-1:-1:-1;47381:13:0;;-1:-1:-1;;;;;47375:19:0;;;47381:13;;47375:19;47351:43;:58;;;;-1:-1:-1;47398:11:0;;;;;;;47351:58;47347:196;;;47426:8;:15;;-1:-1:-1;;47426:15:0;47437:4;47426:15;;;47458:40;47477:20;47458:18;:40::i;:::-;47515:8;:16;;-1:-1:-1;;47515:16:0;;;47347:196;47555:16;47582:15;47634:11;;47649:10;47634:26;;;;:::i;:::-;47616:15;:44;47612:551;;;-1:-1:-1;;47716:9:0;;47751:10;;;47612:551;;;47801:11;;:26;;47816:10;47801:26;:::i;:::-;47783:15;:44;47779:384;;;-1:-1:-1;47906:2:0;;-1:-1:-1;47878:2:0;47779:384;;;47948:11;;:25;;47963:9;47948:25;:::i;:::-;47930:15;:43;47926:237;;;-1:-1:-1;48052:2:0;;-1:-1:-1;48024:2:0;47926:237;;;-1:-1:-1;48149:2:0;;-1:-1:-1;48121:2:0;47926:237;-1:-1:-1;;;;;48208:25:0;;48175:18;48208:25;;;:19;:25;;;;;;;;;:52;;-1:-1:-1;;;;;;48237:23:0;;;;;;:19;:23;;;;;;;;48208:52;:64;;;-1:-1:-1;48264:8:0;;;;48208:64;48204:441;;;-1:-1:-1;48302:1:0;48204:441;;;48333:13;;-1:-1:-1;;;;;48333:13:0;;;48325:21;;;;48321:324;;48383:12;;48367;:28;48363:145;;-1:-1:-1;48429:2:0;48321:324;;48363:145;-1:-1:-1;48485:7:0;48321:324;;;48535:13;;-1:-1:-1;;;;;48535:13:0;;;48529:19;;;;48525:120;;-1:-1:-1;48578:8:0;48525:120;;;-1:-1:-1;48632:1:0;48525:120;48661:14;;48657:227;;48692:12;48731:3;48708:19;48717:10;48708:6;:19;:::i;:::-;48707:27;;;;:::i;:::-;48692:42;-1:-1:-1;48758:13:0;48692:42;48758:6;:13;:::i;:::-;48749:22;;48786:42;48802:4;48816;48823;48786:15;:42::i;:::-;48864:8;48871:1;48864:4;:8;:::i;:::-;48845:15;;:27;;;;;;;:::i;:::-;;;;-1:-1:-1;;;48657:227:0;48900:21;;;;48896:464;;;-1:-1:-1;;;;;48961:35:0;;;;;;:29;:35;;;;;;;;48960:36;:91;;;;-1:-1:-1;;;;;;49018:33:0;;;;;;:29;:33;;;;;;;;49017:34;48960:91;:131;;;;-1:-1:-1;49078:13:0;;-1:-1:-1;;;;;49072:19:0;;;49078:13;;49072:19;;48960:131;48938:411;;;-1:-1:-1;;;;;28273:18:0;;49126:15;28273:18;;;;;;;;;;;49226:15;;49206:16;49216:6;28273:18;49206:16;:::i;:::-;:35;;49176:157;;;;-1:-1:-1;;;49176:157:0;;14939:2:1;49176:157:0;;;14921:21:1;14978:2;14958:18;;;14951:30;15017:34;14997:18;;;14990:62;-1:-1:-1;;;15068:18:1;;;15061:46;15124:19;;49176:157:0;14737:412:1;49176:157:0;49107:242;48938:411;49372:33;49388:4;49394:2;49398:6;49372:15;:33::i;:::-;46748:2665;;;;;46635:2778;;;:::o;38114:166::-;38022:6;;-1:-1:-1;;;;;38022:6:0;24732:10;38174:23;38170:103;;38221:40;;-1:-1:-1;;;38221:40:0;;24732:10;38221:40;;;1569:51:1;1542:18;;38221:40:0;1397:229:1;33281:211:0;-1:-1:-1;;;;;33352:21:0;;33348:91;;33397:30;;-1:-1:-1;;;33397:30:0;;33424:1;33397:30;;;1569:51:1;1542:18;;33397:30:0;1397:229:1;33348:91:0;33449:35;33457:7;33474:1;33478:5;33449:7;:35::i;:::-;33281:211;;:::o;39262:191::-;39355:6;;;-1:-1:-1;;;;;39372:17:0;;;-1:-1:-1;;;;;;39372:17:0;;;;;;;39405:40;;39355:6;;;39372:17;39355:6;;39405:40;;39336:16;;39405:40;39325:128;39262:191;:::o;43432:171::-;43698:16;;-1:-1:-1;;;;;43698:16:0;24732:10;43496:37;43492:104;;43557:27;;-1:-1:-1;;;43557:27:0;;24732:10;43557:27;;;1569:51:1;1542:18;;43557:27:0;1397:229:1;8768:340:0;8878:6;8854:21;:30;8850:111;;;8908:41;;-1:-1:-1;;;8908:41:0;;8943:4;8908:41;;;1569:51:1;1542:18;;8908:41:0;1397:229:1;8850:111:0;8974:12;8992:9;-1:-1:-1;;;;;8992:14:0;9014:6;8992:33;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8973:52;;;9041:7;9036:65;;9072:17;;-1:-1:-1;;;9072:17:0;;;;;;;;;;;35026:443;-1:-1:-1;;;;;35139:19:0;;35135:91;;35182:32;;-1:-1:-1;;;35182:32:0;;35211:1;35182:32;;;1569:51:1;1542:18;;35182:32:0;1397:229:1;35135:91:0;-1:-1:-1;;;;;35240:21:0;;35236:92;;35285:31;;-1:-1:-1;;;35285:31:0;;35313:1;35285:31;;;1569:51:1;1542:18;;35285:31:0;1397:229:1;35236:92:0;-1:-1:-1;;;;;35338:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;:35;;;35384:78;;;;35435:7;-1:-1:-1;;;;;35419:31:0;35428:5;-1:-1:-1;;;;;35419:31:0;;35444:5;35419:31;;;;1361:25:1;;1349:2;1334:18;;1215:177;35419:31:0;;;;;;;;35026:443;;;;:::o;30612:316::-;-1:-1:-1;;;;;30704:18:0;;30700:88;;30746:30;;-1:-1:-1;;;30746:30:0;;30773:1;30746:30;;;1569:51:1;1542:18;;30746:30:0;1397:229:1;30700:88:0;-1:-1:-1;;;;;30802:16:0;;30798:88;;30842:32;;-1:-1:-1;;;30842:32:0;;30871:1;30842:32;;;1569:51:1;1542:18;;30842:32:0;1397:229:1;30798:88:0;30896:24;30904:4;30910:2;30914:5;30896:7;:24::i;50115:863::-;50266:16;;;50280:1;50266:16;;;;;;;;50208:21;;50183:22;;50266:16;50280:1;50266:16;;;;;;;;;;-1:-1:-1;50266:16:0;50242:40;;50311:4;50293;50298:1;50293:7;;;;;;;;:::i;:::-;-1:-1:-1;;;;;50293:23:0;;;:7;;;;;;;;;;:23;;;;50337:15;;:22;;;-1:-1:-1;;;50337:22:0;;;;:15;;;;;:20;;:22;;;;;50293:7;;50337:22;;;;;:15;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;50327:4;50332:1;50327:7;;;;;;;;:::i;:::-;-1:-1:-1;;;;;50327:32:0;;;:7;;;;;;;;;:32;50372:15;;:196;;-1:-1:-1;;;50372:196:0;;:15;;;:66;;:196;;50453:11;;50372:15;;50495:4;;50522;;50542:15;;50372:196;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;50581:18;50626:14;50602:21;:38;;;;:::i;:::-;50581:59;;50651:29;50729:11;50697:15;;50684:10;:28;;;;:::i;:::-;50683:57;;;;:::i;:::-;50761:16;;50651:89;;-1:-1:-1;50753:58:0;;-1:-1:-1;;;;;50761:16:0;50651:89;50753:35;:58::i;:::-;50830:13;;50822:55;;-1:-1:-1;;;;;50830:13:0;50855:21;50822:32;:55::i;:::-;50908:1;50890:15;:19;50927:43;;;6529:25:1;;;6585:2;6570:18;;6563:34;;;50927:43:0;;6502:18:1;50927:43:0;;;;;;;50172:806;;;;50115:863;:::o;31252:1135::-;-1:-1:-1;;;;;31342:18:0;;31338:552;;31496:5;31480:12;;:21;;;;;;;:::i;:::-;;;;-1:-1:-1;31338:552:0;;-1:-1:-1;31338:552:0;;-1:-1:-1;;;;;31556:15:0;;31534:19;31556:15;;;;;;;;;;;31590:19;;;31586:117;;;31637:50;;-1:-1:-1;;;31637:50:0;;-1:-1:-1;;;;;13008:32:1;;31637:50:0;;;12990:51:1;13057:18;;;13050:34;;;13100:18;;;13093:34;;;12963:18;;31637:50:0;12788:345:1;31586:117:0;-1:-1:-1;;;;;31826:15:0;;:9;:15;;;;;;;;;;31844:19;;;;31826:37;;31338:552;-1:-1:-1;;;;;31906:16:0;;31902:435;;32072:12;:21;;;;;;;31902:435;;;-1:-1:-1;;;;;32288:13:0;;:9;:13;;;;;;;;;;:22;;;;;;31902:435;32369:2;-1:-1:-1;;;;;32354:25:0;32363:4;-1:-1:-1;;;;;32354:25:0;;32373:5;32354:25;;;;1361::1;;1349:2;1334:18;;1215:177;32354:25:0;;;;;;;;31252:1135;;;:::o;14:548:1:-;126:4;155:2;184;173:9;166:21;216:6;210:13;259:6;254:2;243:9;239:18;232:34;284:1;294:140;308:6;305:1;302:13;294:140;;;403:14;;;399:23;;393:30;369:17;;;388:2;365:26;358:66;323:10;;294:140;;;298:3;483:1;478:2;469:6;458:9;454:22;450:31;443:42;553:2;546;542:7;537:2;529:6;525:15;521:29;510:9;506:45;502:54;494:62;;;;14:548;;;;:::o;567:131::-;-1:-1:-1;;;;;642:31:1;;632:42;;622:70;;688:1;685;678:12;703:315;771:6;779;832:2;820:9;811:7;807:23;803:32;800:52;;;848:1;845;838:12;800:52;887:9;874:23;906:31;931:5;906:31;:::i;:::-;956:5;1008:2;993:18;;;;980:32;;-1:-1:-1;;;703:315:1:o;1631:456::-;1708:6;1716;1724;1777:2;1765:9;1756:7;1752:23;1748:32;1745:52;;;1793:1;1790;1783:12;1745:52;1832:9;1819:23;1851:31;1876:5;1851:31;:::i;:::-;1901:5;-1:-1:-1;1958:2:1;1943:18;;1930:32;1971:33;1930:32;1971:33;:::i;:::-;1631:456;;2023:7;;-1:-1:-1;;;2077:2:1;2062:18;;;;2049:32;;1631:456::o;2092:118::-;2178:5;2171:13;2164:21;2157:5;2154:32;2144:60;;2200:1;2197;2190:12;2215:241;2271:6;2324:2;2312:9;2303:7;2299:23;2295:32;2292:52;;;2340:1;2337;2330:12;2292:52;2379:9;2366:23;2398:28;2420:5;2398:28;:::i;:::-;2445:5;2215:241;-1:-1:-1;;;2215:241:1:o;2650:180::-;2709:6;2762:2;2750:9;2741:7;2737:23;2733:32;2730:52;;;2778:1;2775;2768:12;2730:52;-1:-1:-1;2801:23:1;;2650:180;-1:-1:-1;2650:180:1:o;3043:247::-;3102:6;3155:2;3143:9;3134:7;3130:23;3126:32;3123:52;;;3171:1;3168;3161:12;3123:52;3210:9;3197:23;3229:31;3254:5;3229:31;:::i;3295:248::-;3363:6;3371;3424:2;3412:9;3403:7;3399:23;3395:32;3392:52;;;3440:1;3437;3430:12;3392:52;-1:-1:-1;;3463:23:1;;;3533:2;3518:18;;;3505:32;;-1:-1:-1;3295:248:1:o;3548:382::-;3613:6;3621;3674:2;3662:9;3653:7;3649:23;3645:32;3642:52;;;3690:1;3687;3680:12;3642:52;3729:9;3716:23;3748:31;3773:5;3748:31;:::i;:::-;3798:5;-1:-1:-1;3855:2:1;3840:18;;3827:32;3868:30;3827:32;3868:30;:::i;:::-;3917:7;3907:17;;;3548:382;;;;;:::o;3935:388::-;4003:6;4011;4064:2;4052:9;4043:7;4039:23;4035:32;4032:52;;;4080:1;4077;4070:12;4032:52;4119:9;4106:23;4138:31;4163:5;4138:31;:::i;:::-;4188:5;-1:-1:-1;4245:2:1;4230:18;;4217:32;4258:33;4217:32;4258:33;:::i;4328:380::-;4407:1;4403:12;;;;4450;;;4471:61;;4525:4;4517:6;4513:17;4503:27;;4471:61;4578:2;4570:6;4567:14;4547:18;4544:38;4541:161;;4624:10;4619:3;4615:20;4612:1;4605:31;4659:4;4656:1;4649:15;4687:4;4684:1;4677:15;4541:161;;4328:380;;;:::o;5948:402::-;6150:2;6132:21;;;6189:2;6169:18;;;6162:30;6228:34;6223:2;6208:18;;6201:62;-1:-1:-1;;;6294:2:1;6279:18;;6272:36;6340:3;6325:19;;5948:402::o;7796:251::-;7866:6;7919:2;7907:9;7898:7;7894:23;7890:32;7887:52;;;7935:1;7932;7925:12;7887:52;7967:9;7961:16;7986:31;8011:5;7986:31;:::i;8640:245::-;8707:6;8760:2;8748:9;8739:7;8735:23;8731:32;8728:52;;;8776:1;8773;8766:12;8728:52;8808:9;8802:16;8827:28;8849:5;8827:28;:::i;9502:306::-;9590:6;9598;9606;9659:2;9647:9;9638:7;9634:23;9630:32;9627:52;;;9675:1;9672;9665:12;9627:52;9704:9;9698:16;9688:26;;9754:2;9743:9;9739:18;9733:25;9723:35;;9798:2;9787:9;9783:18;9777:25;9767:35;;9502:306;;;;;:::o;9813:127::-;9874:10;9869:3;9865:20;9862:1;9855:31;9905:4;9902:1;9895:15;9929:4;9926:1;9919:15;9945:217;9985:1;10011;10001:132;;10055:10;10050:3;10046:20;10043:1;10036:31;10090:4;10087:1;10080:15;10118:4;10115:1;10108:15;10001:132;-1:-1:-1;10147:9:1;;9945:217::o;12599:184::-;12669:6;12722:2;12710:9;12701:7;12697:23;12693:32;12690:52;;;12738:1;12735;12728:12;12690:52;-1:-1:-1;12761:16:1;;12599:184;-1:-1:-1;12599:184:1:o;14301:125::-;14366:9;;;14387:10;;;14384:36;;;14400:18;;:::i;14431:168::-;14504:9;;;14535;;14552:15;;;14546:22;;14532:37;14522:71;;14573:18;;:::i;14604:128::-;14671:9;;;14692:11;;;14689:37;;;14706:18;;:::i;15496:127::-;15557:10;15552:3;15548:20;15545:1;15538:31;15588:4;15585:1;15578:15;15612:4;15609:1;15602:15;15628:980;15890:4;15938:3;15927:9;15923:19;15969:6;15958:9;15951:25;15995:2;16033:6;16028:2;16017:9;16013:18;16006:34;16076:3;16071:2;16060:9;16056:18;16049:31;16100:6;16135;16129:13;16166:6;16158;16151:22;16204:3;16193:9;16189:19;16182:26;;16243:2;16235:6;16231:15;16217:29;;16264:1;16274:195;16288:6;16285:1;16282:13;16274:195;;;16353:13;;-1:-1:-1;;;;;16349:39:1;16337:52;;16444:15;;;;16409:12;;;;16385:1;16303:9;16274:195;;;-1:-1:-1;;;;;;;16525:32:1;;;;16520:2;16505:18;;16498:60;-1:-1:-1;;;16589:3:1;16574:19;16567:35;16486:3;15628:980;-1:-1:-1;;;15628:980:1:o

Swarm Source

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