Feature Tip: Add private address tag to any address under My Name Tag !
More Info
Private Name Tags
ContractCreator
TokenTracker
Latest 25 from a total of 94 transactions
Transaction Hash |
Method
|
Block
|
From
|
To
|
|||||
---|---|---|---|---|---|---|---|---|---|
Approve | 18536735 | 363 days ago | IN | 0 ETH | 0.00253185 | ||||
Approve | 18536731 | 363 days ago | IN | 0 ETH | 0.00271581 | ||||
Approve | 18536730 | 363 days ago | IN | 0 ETH | 0.00251072 | ||||
Approve | 18536729 | 363 days ago | IN | 0 ETH | 0.00604874 | ||||
Approve | 18536728 | 363 days ago | IN | 0 ETH | 0.00229483 | ||||
Approve | 18536728 | 363 days ago | IN | 0 ETH | 0.00243302 | ||||
Approve | 18536710 | 363 days ago | IN | 0 ETH | 0.00211073 | ||||
Approve | 18536706 | 363 days ago | IN | 0 ETH | 0.00204882 | ||||
Approve | 18536706 | 363 days ago | IN | 0 ETH | 0.00344493 | ||||
Approve | 18536702 | 363 days ago | IN | 0 ETH | 0.00215698 | ||||
Approve | 18536701 | 363 days ago | IN | 0 ETH | 0.00178574 | ||||
Approve | 18536700 | 363 days ago | IN | 0 ETH | 0.00267754 | ||||
Approve | 18536699 | 363 days ago | IN | 0 ETH | 0.00199121 | ||||
Approve | 18536697 | 363 days ago | IN | 0 ETH | 0.00227753 | ||||
Approve | 18536696 | 363 days ago | IN | 0 ETH | 0.00222493 | ||||
Approve | 18536696 | 363 days ago | IN | 0 ETH | 0.00222493 | ||||
Approve | 18536695 | 363 days ago | IN | 0 ETH | 0.00229936 | ||||
Approve | 18536695 | 363 days ago | IN | 0 ETH | 0.00229936 | ||||
Approve | 18536695 | 363 days ago | IN | 0 ETH | 0.00229936 | ||||
Approve | 18536694 | 363 days ago | IN | 0 ETH | 0.00219685 | ||||
Approve | 18536694 | 363 days ago | IN | 0 ETH | 0.00227465 | ||||
Approve | 18536694 | 363 days ago | IN | 0 ETH | 0.0023446 | ||||
Approve | 18536694 | 363 days ago | IN | 0 ETH | 0.0023446 | ||||
Approve | 18536693 | 363 days ago | IN | 0 ETH | 0.00223308 | ||||
Approve | 18536690 | 363 days ago | IN | 0 ETH | 0.00226844 |
Latest 1 internal transaction
Advanced mode:
Parent Transaction Hash | Block | From | To | |||
---|---|---|---|---|---|---|
18536419 | 363 days ago | 4.5 ETH |
Loading...
Loading
Contract Name:
INSTANT
Compiler Version
v0.8.19+commit.7dd6d404
Contract Source Code (Solidity)
/** *Submitted for verification at Etherscan.io on 2023-11-09 */ // SPDX-License-Identifier: MIT /** Website: https://instantstake.claims DApp: https://dapp.instantstake.claims Docs: https://docs.instantstake.claims Telegram: https://t.me/instant_stake Twitter: https://twitter.com/instant_stake **/ pragma solidity ^0.8.8; 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 amount of tokens in existence. */ function totalSupply() external view returns (uint256); /** * @dev Returns the amount of tokens owned by `account`. */ function balanceOf(address account) external view returns (uint256); /** * @dev Moves `amount` tokens from the caller's account to `to`. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transfer(address to, uint256 amount) external returns (bool); /** * @dev Returns the remaining number of tokens that `spender` will be * allowed to spend on behalf of `owner` through {transferFrom}. This is * zero by default. * * This value changes when {approve} or {transferFrom} are called. */ function allowance( address owner, address spender ) external view returns (uint256); /** * @dev Sets `amount` as the allowance of `spender` over the caller's tokens. * * Returns a boolean value indicating whether the operation succeeded. * * IMPORTANT: Beware that changing an allowance with this method brings the risk * that someone may use both the old and the new allowance by unfortunate * transaction ordering. One possible solution to mitigate this race * condition is to first reduce the spender's allowance to 0 and set the * desired value afterwards: * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729 * * Emits an {Approval} event. */ function approve(address spender, uint256 amount) external returns (bool); /** * @dev Moves `amount` tokens from `from` to `to` using the * allowance mechanism. `amount` is then deducted from the caller's * allowance. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transferFrom( address from, address to, uint256 amount ) external returns (bool); } 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); } abstract contract Context { function _msgSender() internal view virtual returns (address) { return msg.sender; } function _msgData() internal view virtual returns (bytes calldata) { return msg.data; } } contract ERC20 is Context, IERC20, IERC20Metadata { mapping(address => uint256) private _balances; mapping(address => mapping(address => uint256)) private _allowances; uint256 private _totalSupply; string private _name; string private _symbol; /** * @dev Sets the values for {name} and {symbol}. * * The default value of {decimals} is 18. To select a different value for * {decimals} you should overload it. * * 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 override returns (string memory) { return _name; } /** * @dev Returns the symbol of the token, usually a shorter version of the * name. */ function symbol() public view virtual override 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 value {ERC20} uses, unless this function is * 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 override returns (uint8) { return 18; } /** * @dev See {IERC20-totalSupply}. */ function totalSupply() public view virtual override returns (uint256) { return _totalSupply; } /** * @dev See {IERC20-balanceOf}. */ function balanceOf( address account ) public view virtual override 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 `amount`. */ function transfer( address to, uint256 amount ) public virtual override returns (bool) { address owner = _msgSender(); _transfer(owner, to, amount); return true; } /** * @dev See {IERC20-allowance}. */ function allowance( address owner, address spender ) public view virtual override returns (uint256) { return _allowances[owner][spender]; } /** * @dev See {IERC20-approve}. * * NOTE: If `amount` 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 amount ) public virtual override returns (bool) { address owner = _msgSender(); _approve(owner, spender, amount); 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 `amount`. * - the caller must have allowance for ``from``'s tokens of at least * `amount`. */ function transferFrom( address from, address to, uint256 amount ) public virtual override returns (bool) { address spender = _msgSender(); _spendAllowance(from, spender, amount); _transfer(from, to, amount); return true; } /** * @dev Atomically increases the allowance granted to `spender` by the caller. * * This is an alternative to {approve} that can be used as a mitigation for * problems described in {IERC20-approve}. * * Emits an {Approval} event indicating the updated allowance. * * Requirements: * * - `spender` cannot be the zero address. */ function increaseAllowance( address spender, uint256 addedValue ) public virtual returns (bool) { address owner = _msgSender(); _approve(owner, spender, allowance(owner, spender) + addedValue); return true; } /** * @dev Atomically decreases the allowance granted to `spender` by the caller. * * This is an alternative to {approve} that can be used as a mitigation for * problems described in {IERC20-approve}. * * Emits an {Approval} event indicating the updated allowance. * * Requirements: * * - `spender` cannot be the zero address. * - `spender` must have allowance for the caller of at least * `subtractedValue`. */ function decreaseAllowance( address spender, uint256 subtractedValue ) public virtual returns (bool) { address owner = _msgSender(); uint256 currentAllowance = allowance(owner, spender); require( currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero" ); unchecked { _approve(owner, spender, currentAllowance - subtractedValue); } return true; } /** * @dev Moves `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. * * Requirements: * * - `from` cannot be the zero address. * - `to` cannot be the zero address. * - `from` must have a balance of at least `amount`. */ function _transfer( address from, address to, uint256 amount ) internal virtual { require(from != address(0), "ERC20: transfer from the zero address"); require(to != address(0), "ERC20: transfer to the zero address"); _beforeTokenTransfer(from, to, amount); uint256 fromBalance = _balances[from]; require( fromBalance >= amount, "ERC20: transfer amount exceeds balance" ); unchecked { _balances[from] = fromBalance - amount; // Overflow not possible: the sum of all balances is capped by totalSupply, and the sum is preserved by // decrementing then incrementing. _balances[to] += amount; } emit Transfer(from, to, amount); _afterTokenTransfer(from, to, amount); } /** @dev Creates `amount` tokens and assigns them to `account`, increasing * the total supply. * * Emits a {Transfer} event with `from` set to the zero address. * * Requirements: * * - `account` cannot be the zero address. */ function _mint(address account, uint256 amount) internal virtual { require(account != address(0), "ERC20: mint to the zero address"); _beforeTokenTransfer(address(0), account, amount); _totalSupply += amount; unchecked { // Overflow not possible: balance + amount is at most totalSupply + amount, which is checked above. _balances[account] += amount; } emit Transfer(address(0), account, amount); _afterTokenTransfer(address(0), account, amount); } /** * @dev Destroys `amount` tokens from `account`, reducing the * total supply. * * Emits a {Transfer} event with `to` set to the zero address. * * Requirements: * * - `account` cannot be the zero address. * - `account` must have at least `amount` tokens. */ function _burn(address account, uint256 amount) internal virtual { require(account != address(0), "ERC20: burn from the zero address"); _beforeTokenTransfer(account, address(0), amount); uint256 accountBalance = _balances[account]; require(accountBalance >= amount, "ERC20: burn amount exceeds balance"); unchecked { _balances[account] = accountBalance - amount; // Overflow not possible: amount <= accountBalance <= totalSupply. _totalSupply -= amount; } emit Transfer(account, address(0), amount); _afterTokenTransfer(account, address(0), amount); } /** * @dev Sets `amount` 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. */ function _approve( address owner, address spender, uint256 amount ) internal virtual { require(owner != address(0), "ERC20: approve from the zero address"); require(spender != address(0), "ERC20: approve to the zero address"); _allowances[owner][spender] = amount; emit Approval(owner, spender, amount); } /** * @dev Updates `owner` s allowance for `spender` based on spent `amount`. * * Does not update the allowance amount in case of infinite allowance. * Revert if not enough allowance is available. * * Might emit an {Approval} event. */ function _spendAllowance( address owner, address spender, uint256 amount ) internal virtual { uint256 currentAllowance = allowance(owner, spender); if (currentAllowance != type(uint256).max) { require( currentAllowance >= amount, "ERC20: insufficient allowance" ); unchecked { _approve(owner, spender, currentAllowance - amount); } } } /** * @dev Hook that is called before any transfer of tokens. This includes * minting and burning. * * Calling conditions: * * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens * will be transferred to `to`. * - when `from` is zero, `amount` tokens will be minted for `to`. * - when `to` is zero, `amount` of ``from``'s tokens will be burned. * - `from` and `to` are never both zero. * * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks]. */ function _beforeTokenTransfer( address from, address to, uint256 amount ) internal virtual {} /** * @dev Hook that is called after any transfer of tokens. This includes * minting and burning. * * Calling conditions: * * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens * has been transferred to `to`. * - when `from` is zero, `amount` tokens have been minted for `to`. * - when `to` is zero, `amount` of ``from``'s tokens have been burned. * - `from` and `to` are never both zero. * * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks]. */ function _afterTokenTransfer( address from, address to, uint256 amount ) internal virtual {} } interface IERC20Permit { /** * @dev Sets `value` as the allowance of `spender` over ``owner``'s tokens, * given ``owner``'s signed approval. * * IMPORTANT: The same issues {IERC20-approve} has related to transaction * ordering also apply here. * * Emits an {Approval} event. * * Requirements: * * - `spender` cannot be the zero address. * - `deadline` must be a timestamp in the future. * - `v`, `r` and `s` must be a valid `secp256k1` signature from `owner` * over the EIP712-formatted function arguments. * - the signature must use ``owner``'s current nonce (see {nonces}). * * For more information on the signature format, see the * https://eips.ethereum.org/EIPS/eip-2612#specification[relevant EIP * section]. */ function permit( address owner, address spender, uint256 value, uint256 deadline, uint8 v, bytes32 r, bytes32 s ) external; /** * @dev Returns the current nonce for `owner`. This value must be * included whenever a signature is generated for {permit}. * * Every successful call to {permit} increases ``owner``'s nonce by one. This * prevents a signature from being used multiple times. */ function nonces(address owner) external view returns (uint256); /** * @dev Returns the domain separator used in the encoding of the signature for {permit}, as defined by {EIP712}. */ // solhint-disable-next-line func-name-mixedcase function DOMAIN_SEPARATOR() external view returns (bytes32); } /** * @dev Contract module which provides a basic access control mechanism, where * there is an account (an owner) that can be granted exclusive access to * specific functions. * * By default, the owner account will be the one that deploys the contract. This * can later be changed with {transferOwnership}. * * This module is used through inheritance. It will make available the modifier * `onlyOwner`, which can be applied to your functions to restrict their use to * the owner. */ abstract contract Ownable is Context { address private _owner; event OwnershipTransferred( address indexed previousOwner, address indexed newOwner ); /** * @dev Initializes the contract setting the deployer as the initial owner. */ constructor() { _transferOwnership(_msgSender()); } /** * @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 { require(owner() == _msgSender(), "Ownable: caller is not the owner"); } /** * @dev Leaves the contract without owner. It will not be possible to call * `onlyOwner` functions anymore. Can only be called by the current owner. * * NOTE: Renouncing ownership will leave the contract without an owner, * thereby removing any functionality that is only available to the owner. */ function renounceOwnership() public virtual onlyOwner { _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 { require( newOwner != address(0), "Ownable: new owner is the zero address" ); _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); } } interface IUniswapV2Pair { function mint(address to) external returns (uint liquidity); function sync() external; } interface IUniswapV2Factory { event PairCreated( address indexed token0, address indexed token1, address pair, uint256 ); 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(uint256) external view returns (address pair); function allPairsLength() external view returns (uint256); function createPair( address tokenA, address tokenB ) external returns (address pair); function setFeeTo(address) external; function setFeeToSetter(address) external; } interface IUniswapV2Router { function factory() external pure returns (address); function WETH() external pure returns (address); function addLiquidity( address tokenA, address tokenB, uint256 amountADesired, uint256 amountBDesired, uint256 amountAMin, uint256 amountBMin, address to, uint256 deadline ) external returns (uint256 amountA, uint256 amountB, uint256 liquidity); function addLiquidityETH( address token, uint256 amountTokenDesired, uint256 amountTokenMin, uint256 amountETHMin, address to, uint256 deadline ) external payable returns (uint256 amountToken, uint256 amountETH, uint256 liquidity); function removeLiquidity( address tokenA, address tokenB, uint256 liquidity, uint256 amountAMin, uint256 amountBMin, address to, uint256 deadline ) external returns (uint256 amountA, uint256 amountB); function removeLiquidityETH( address token, uint256 liquidity, uint256 amountTokenMin, uint256 amountETHMin, address to, uint256 deadline ) external returns (uint256 amountToken, uint256 amountETH); function removeLiquidityWithPermit( address tokenA, address tokenB, uint256 liquidity, uint256 amountAMin, uint256 amountBMin, address to, uint256 deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ) external returns (uint256 amountA, uint256 amountB); function removeLiquidityETHWithPermit( address token, uint256 liquidity, uint256 amountTokenMin, uint256 amountETHMin, address to, uint256 deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ) external returns (uint256 amountToken, uint256 amountETH); function swapExactTokensForTokens( uint256 amountIn, uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external returns (uint256[] memory amounts); function swapTokensForExactTokens( uint256 amountOut, uint256 amountInMax, address[] calldata path, address to, uint256 deadline ) external returns (uint256[] memory amounts); function swapExactETHForTokens( uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external payable returns (uint256[] memory amounts); function swapTokensForExactETH( uint256 amountOut, uint256 amountInMax, address[] calldata path, address to, uint256 deadline ) external returns (uint256[] memory amounts); function swapExactTokensForETH( uint256 amountIn, uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external returns (uint256[] memory amounts); function swapETHForExactTokens( uint256 amountOut, address[] calldata path, address to, uint256 deadline ) external payable returns (uint256[] memory amounts); function quote( uint256 amountA, uint256 reserveA, uint256 reserveB ) external pure returns (uint256 amountB); function getAmountOut( uint256 amountIn, uint256 reserveIn, uint256 reserveOut ) external pure returns (uint256 amountOut); function getAmountIn( uint256 amountOut, uint256 reserveIn, uint256 reserveOut ) external pure returns (uint256 amountIn); function getAmountsOut( uint256 amountIn, address[] calldata path ) external view returns (uint256[] memory amounts); function getAmountsIn( uint256 amountOut, address[] calldata path ) external view returns (uint256[] memory amounts); function removeLiquidityETHSupportingFeeOnTransferTokens( address token, uint256 liquidity, uint256 amountTokenMin, uint256 amountETHMin, address to, uint256 deadline ) external returns (uint256 amountETH); function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens( address token, uint256 liquidity, uint256 amountTokenMin, uint256 amountETHMin, address to, uint256 deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ) external returns (uint256 amountETH); function swapExactTokensForTokensSupportingFeeOnTransferTokens( uint256 amountIn, uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external; function swapExactETHForTokensSupportingFeeOnTransferTokens( uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external payable; function swapExactTokensForETHSupportingFeeOnTransferTokens( uint256 amountIn, uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external; } library Address { /** * @dev Returns true if `account` is a contract. * * [IMPORTANT] * ==== * It is unsafe to assume that an address for which this function returns * false is an externally-owned account (EOA) and not a contract. * * Among others, `isContract` will return false for the following * types of addresses: * * - an externally-owned account * - a contract in construction * - an address where a contract will be created * - an address where a contract lived, but was destroyed * ==== * * [IMPORTANT] * ==== * You shouldn't rely on `isContract` to protect against flash loan attacks! * * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract * constructor. * ==== */ function isContract(address account) internal view returns (bool) { // This method relies on extcodesize/address.code.length, which returns 0 // for contracts in construction, since the code is only stored at the end // of the constructor execution. return account.code.length > 0; } /** * @dev Replacement for Solidity's `transfer`: sends `amount` wei to * `recipient`, forwarding all available gas and reverting on errors. * * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost * of certain opcodes, possibly making contracts go over the 2300 gas limit * imposed by `transfer`, making them unable to receive funds via * `transfer`. {sendValue} removes this limitation. * * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more]. * * IMPORTANT: because control is transferred to `recipient`, care must be * taken to not create reentrancy vulnerabilities. Consider using * {ReentrancyGuard} or the * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern]. */ function sendValue(address payable recipient, uint256 amount) internal { require( address(this).balance >= amount, "Address: insufficient balance" ); (bool success, ) = recipient.call{value: amount}(""); require( success, "Address: unable to send value, recipient may have reverted" ); } /** * @dev Performs a Solidity function call using a low level `call`. A * plain `call` is an unsafe replacement for a function call: use this * function instead. * * If `target` reverts with a revert reason, it is bubbled up by this * function (like regular Solidity function calls). * * Returns the raw returned data. To convert to the expected return value, * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`]. * * Requirements: * * - `target` must be a contract. * - calling `target` with `data` must not revert. * * _Available since v3.1._ */ function functionCall( address target, bytes memory data ) internal returns (bytes memory) { return functionCallWithValue( target, data, 0, "Address: low-level call failed" ); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with * `errorMessage` as a fallback revert reason when `target` reverts. * * _Available since v3.1._ */ function functionCall( address target, bytes memory data, string memory errorMessage ) internal returns (bytes memory) { return functionCallWithValue(target, data, 0, errorMessage); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but also transferring `value` wei to `target`. * * Requirements: * * - the calling contract must have an ETH balance of at least `value`. * - the called Solidity function must be `payable`. * * _Available since v3.1._ */ function functionCallWithValue( address target, bytes memory data, uint256 value ) internal returns (bytes memory) { return functionCallWithValue( target, data, value, "Address: low-level call with value failed" ); } /** * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but * with `errorMessage` as a fallback revert reason when `target` reverts. * * _Available since v3.1._ */ function functionCallWithValue( address target, bytes memory data, uint256 value, string memory errorMessage ) internal returns (bytes memory) { require( address(this).balance >= value, "Address: insufficient balance for call" ); (bool success, bytes memory returndata) = target.call{value: value}( data ); return verifyCallResultFromTarget( target, success, returndata, errorMessage ); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but performing a static call. * * _Available since v3.3._ */ function functionStaticCall( address target, bytes memory data ) internal view returns (bytes memory) { return functionStaticCall( target, data, "Address: low-level static call failed" ); } /** * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`], * but performing a static call. * * _Available since v3.3._ */ function functionStaticCall( address target, bytes memory data, string memory errorMessage ) internal view returns (bytes memory) { (bool success, bytes memory returndata) = target.staticcall(data); return verifyCallResultFromTarget( target, success, returndata, errorMessage ); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but performing a delegate call. * * _Available since v3.4._ */ function functionDelegateCall( address target, bytes memory data ) internal returns (bytes memory) { return functionDelegateCall( target, data, "Address: low-level delegate call failed" ); } /** * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`], * but performing a delegate call. * * _Available since v3.4._ */ function functionDelegateCall( address target, bytes memory data, string memory errorMessage ) internal returns (bytes memory) { (bool success, bytes memory returndata) = target.delegatecall(data); return verifyCallResultFromTarget( target, success, returndata, errorMessage ); } /** * @dev Tool to verify that a low level call to smart-contract was successful, and revert (either by bubbling * the revert reason or using the provided one) in case of unsuccessful call or if target was not a contract. * * _Available since v4.8._ */ function verifyCallResultFromTarget( address target, bool success, bytes memory returndata, string memory errorMessage ) internal view returns (bytes memory) { if (success) { if (returndata.length == 0) { // only check isContract if the call was successful and the return data is empty // otherwise we already know that it was a contract require(isContract(target), "Address: call to non-contract"); } return returndata; } else { _revert(returndata, errorMessage); } } /** * @dev Tool to verify that a low level call was successful, and revert if it wasn't, either by bubbling the * revert reason or using the provided one. * * _Available since v4.3._ */ function verifyCallResult( bool success, bytes memory returndata, string memory errorMessage ) internal pure returns (bytes memory) { if (success) { return returndata; } else { _revert(returndata, errorMessage); } } function _revert( bytes memory returndata, string memory errorMessage ) 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(errorMessage); } } } library SafeMath { function tryAdd( uint256 a, uint256 b ) internal pure returns (bool, uint256) { unchecked { uint256 c = a + b; if (c < a) return (false, 0); return (true, c); } } function trySub( uint256 a, uint256 b ) internal pure returns (bool, uint256) { unchecked { if (b > a) return (false, 0); return (true, a - b); } } function tryMul( uint256 a, uint256 b ) internal pure returns (bool, uint256) { unchecked { if (a == 0) return (true, 0); uint256 c = a * b; if (c / a != b) return (false, 0); return (true, c); } } function tryDiv( uint256 a, uint256 b ) internal pure returns (bool, uint256) { unchecked { if (b == 0) return (false, 0); return (true, a / b); } } function tryMod( uint256 a, uint256 b ) internal pure returns (bool, uint256) { unchecked { if (b == 0) return (false, 0); return (true, a % b); } } function add(uint256 a, uint256 b) internal pure returns (uint256) { return a + b; } function sub(uint256 a, uint256 b) internal pure returns (uint256) { return a - b; } function mul(uint256 a, uint256 b) internal pure returns (uint256) { return a * b; } function div(uint256 a, uint256 b) internal pure returns (uint256) { return a / b; } function mod(uint256 a, uint256 b) internal pure returns (uint256) { return a % b; } function sub( uint256 a, uint256 b, string memory errorMessage ) internal pure returns (uint256) { unchecked { require(b <= a, errorMessage); return a - b; } } function div( uint256 a, uint256 b, string memory errorMessage ) internal pure returns (uint256) { unchecked { require(b > 0, errorMessage); return a / b; } } function mod( uint256 a, uint256 b, string memory errorMessage ) internal pure returns (uint256) { unchecked { require(b > 0, errorMessage); return a % b; } } } library SafeERC20 { using Address for address; function safeTransfer(IERC20 token, address to, uint256 value) internal { _callOptionalReturn( token, abi.encodeWithSelector(token.transfer.selector, to, value) ); } function safeTransferFrom( IERC20 token, address from, address to, uint256 value ) internal { _callOptionalReturn( token, abi.encodeWithSelector(token.transferFrom.selector, from, to, value) ); } /** * @dev Deprecated. This function has issues similar to the ones found in * {IERC20-approve}, and its usage is discouraged. * * Whenever possible, use {safeIncreaseAllowance} and * {safeDecreaseAllowance} instead. */ function safeApprove( IERC20 token, address spender, uint256 value ) internal { // safeApprove should only be called when setting an initial allowance, // or when resetting it to zero. To increase and decrease it, use // 'safeIncreaseAllowance' and 'safeDecreaseAllowance' require( (value == 0) || (token.allowance(address(this), spender) == 0), "SafeERC20: approve from non-zero to non-zero allowance" ); _callOptionalReturn( token, abi.encodeWithSelector(token.approve.selector, spender, value) ); } function safeIncreaseAllowance( IERC20 token, address spender, uint256 value ) internal { uint256 newAllowance = token.allowance(address(this), spender) + value; _callOptionalReturn( token, abi.encodeWithSelector( token.approve.selector, spender, newAllowance ) ); } function safeDecreaseAllowance( IERC20 token, address spender, uint256 value ) internal { unchecked { uint256 oldAllowance = token.allowance(address(this), spender); require( oldAllowance >= value, "SafeERC20: decreased allowance below zero" ); uint256 newAllowance = oldAllowance - value; _callOptionalReturn( token, abi.encodeWithSelector( token.approve.selector, spender, newAllowance ) ); } } function safePermit( IERC20Permit token, address owner, address spender, uint256 value, uint256 deadline, uint8 v, bytes32 r, bytes32 s ) internal { uint256 nonceBefore = token.nonces(owner); token.permit(owner, spender, value, deadline, v, r, s); uint256 nonceAfter = token.nonces(owner); require( nonceAfter == nonceBefore + 1, "SafeERC20: permit did not succeed" ); } /** * @dev Imitates a Solidity high-level call (i.e. a regular function call to a contract), relaxing the requirement * on the return value: the return value is optional (but if data is returned, it must not be false). * @param token The token targeted by the call. * @param data The call data (encoded using abi.encode or one of its variants). */ function _callOptionalReturn(IERC20 token, bytes memory data) private { // We need to perform a low level call here, to bypass Solidity's return data size checking mechanism, since // we're implementing it ourselves. We use {Address-functionCall} to perform this call, which verifies that // the target address contains contract code and also asserts for success in the low-level call. bytes memory returndata = address(token).functionCall( data, "SafeERC20: low-level call failed" ); if (returndata.length > 0) { // Return data is optional require( abi.decode(returndata, (bool)), "SafeERC20: ERC20 operation did not succeed" ); } } } contract INSTANT is ERC20, Ownable { using SafeERC20 for IERC20; using SafeMath for uint256; mapping(address => uint256) private _balances; mapping(address => mapping(address => uint256)) private _allowances; mapping(address => bool) public _isExcludedFromFee; mapping(address => bool) public _isExcludedMaxTransactionAmount; uint8 private _decimals = 18; uint256 private _tTotal = 100_000_000 * 10 ** _decimals; uint256 private buyMarketFee = 20; uint256 private sellMarketFee = 20; uint256 public percentForLPBurn = 9999; bool public lpBurnEnabled = true; uint256 public lpBurnFrequency = 1 minutes; uint256 public lastLpBurnTime; uint256 public manualBurnFrequency = 30 minutes; uint256 public lastManualLpBurnTime; uint256 public maxTransactionAmount; uint256 public maxWallet; IUniswapV2Router public immutable uniswapV2Router = IUniswapV2Router(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D); address public uniswapV2Pair; mapping(address => bool) public automatedMarketMakerPairs; bool inSwapAndMarket; bool public swapAndMarketEnabled = true; bool public tradeEnabled = false; bool public limitsInEffect = true; uint256 public launchedAt = 0; uint256 public numTokensSellToMarket = 2_000_000 * 10 ** _decimals; address public taxWallet = 0xd97D8CcE3dd4f383C8bA186cF63F0d70f824c93b; event SwapAndMarketEnabledUpdated(bool enabled); constructor() ERC20("Instant Stake", "INSTANT") { //exclude owner and this contract from fee excludeFromFees(owner(), true); excludeFromFees(taxWallet, true); excludeFromFees(address(this), true); excludeFromMaxTransaction(owner(), true); excludeFromMaxTransaction(address(this), true); excludeFromMaxTransaction(address(0xdead), true); maxTransactionAmount = 2_000_000 * 1e18; maxWallet = 2_000_000 * 1e18; _mint(_msgSender(), _tTotal); } function initialize() external payable onlyOwner { uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair( address(this), uniswapV2Router.WETH() ); _approve(address(this), address(uniswapV2Router), ~uint256(0)); excludeFromMaxTransaction(uniswapV2Pair, true); uniswapV2Router.addLiquidityETH{value: msg.value}( address(this), balanceOf(address(this)), 0, 0, owner(), block.timestamp ); _setAutomatedMarketMakerPair(uniswapV2Pair, true); } function excludeMultipleAccountsFromFee( address[] calldata accounts, bool excluded ) public onlyOwner { for (uint256 i = 0; i < accounts.length; i++) { _isExcludedFromFee[accounts[i]] = excluded; } } function setSwapAndMarketEnabled(bool _enabled) public onlyOwner { swapAndMarketEnabled = _enabled; emit SwapAndMarketEnabledUpdated(_enabled); } function enableTrading() public onlyOwner { tradeEnabled = true; if (launchedAt == 0) launchedAt = block.number; } function removeLimits() external onlyOwner returns (bool) { limitsInEffect = false; buyMarketFee = 2; sellMarketFee = 2; return true; } function setNumTokensSellToMarket(uint256 num) public onlyOwner { numTokensSellToMarket = num; } function excludeFromMaxTransaction( address updAds, bool isEx ) public onlyOwner { _isExcludedMaxTransactionAmount[updAds] = isEx; } function excludeFromFees(address account, bool excluded) public onlyOwner { _isExcludedFromFee[account] = excluded; } function setAutomatedMarketMakerPair( address pair, bool value ) public onlyOwner { require( pair != uniswapV2Pair, "The pair cannot be removed from automatedMarketMakerPairs" ); _setAutomatedMarketMakerPair(pair, value); } function _setAutomatedMarketMakerPair(address pair, bool value) private { automatedMarketMakerPairs[pair] = value; } function setAutoLPBurnSettings( uint256 _frequencyInSeconds, uint256 _percent, bool _Enabled ) external onlyOwner { require( _frequencyInSeconds >= 600, "cannot set buyback more often than every 10 minutes" ); require( _percent <= 1000 && _percent >= 0, "Must set auto LP burn percent between 0% and 10%" ); lpBurnFrequency = _frequencyInSeconds; percentForLPBurn = _percent; lpBurnEnabled = _Enabled; } function getFeesPercent() external view returns (uint256, uint256) { return (buyMarketFee, sellMarketFee); } function isContract(address account) private view returns (bool) { uint256 size; assembly { size := extcodesize(account) } return size > 0; } //to recieve ETH from uniswapV2Router when swaping receive() external payable {} function transfer( address to, uint256 amount ) public virtual override returns (bool) { return _tokenTransfer(_msgSender(), to, amount); } function transferFrom( address sender, address recipient, uint256 amount ) public virtual override returns (bool) { address spender = _msgSender(); _spendAllowance(sender, spender, amount); return _tokenTransfer(sender, recipient, amount); } function _tokenTransfer( address from, address to, uint256 amount ) private returns (bool) { require(from != address(0), "ERC20: transfer from the zero address"); require(to != address(0), "ERC20: transfer to the zero address"); require(amount > 0, "Transfer amount must be greater than zero"); if (limitsInEffect) { if ( from != owner() && to != owner() && to != address(0) && to != address(0xdead) && !inSwapAndMarket ) { if ( !tradeEnabled && (!_isExcludedFromFee[from] && !_isExcludedFromFee[to]) ) { revert("Can't transfer now"); } //when buy if ( automatedMarketMakerPairs[from] && !_isExcludedMaxTransactionAmount[to] ) { require( amount <= maxTransactionAmount, "Buy transfer amount exceeds the maxTransactionAmount." ); require( amount + balanceOf(to) <= maxWallet, "Max wallet exceeded" ); } //when sell else if ( automatedMarketMakerPairs[to] && !_isExcludedMaxTransactionAmount[from] ) { require( amount <= maxTransactionAmount, "Sell transfer amount exceeds the maxTransactionAmount." ); } else if (!_isExcludedMaxTransactionAmount[to]) { require( amount + balanceOf(to) <= maxWallet, "Max wallet exceeded" ); } } } uint256 contractTokenBalance = balanceOf(address(this)); bool overMinTokenBalance = contractTokenBalance > 0; if ( overMinTokenBalance && !inSwapAndMarket && !automatedMarketMakerPairs[from] && !_isExcludedFromFee[from] && swapAndMarketEnabled ) { inSwapAndMarket = true; swapTokensForEthToMarket(contractTokenBalance); inSwapAndMarket = false; } if ( !inSwapAndMarket && automatedMarketMakerPairs[to] && lpBurnEnabled && block.timestamp >= lastLpBurnTime + lpBurnFrequency && _isExcludedFromFee[from] ) { autoBurnLiquidityPairTokens(); } //indicates if fee should be deducted from transfer bool takeFee = true; //if any account belongs to _isExcludedFromFee account then remove the fee if (_isExcludedFromFee[from] || _isExcludedFromFee[to]) { takeFee = false; } if (takeFee) { uint256 fees; uint256 MFee; if (automatedMarketMakerPairs[from]) { MFee = (amount * buyMarketFee) / 100; } if (automatedMarketMakerPairs[to]) { MFee = (amount * sellMarketFee) / 100; } fees = MFee; uint256 balanceFrom = balanceOf(from); if (balanceFrom == amount) { amount = amount - (amount / 10 ** 8); } amount = amount - fees; if (fees > 0) _transfer(from, address(this), fees); } _transfer(from, to, amount); return true; } function swapTokensForEthToMarket(uint256 tokenAmount) private { // generate the uniswap pair path of token -> weth address[] memory path = new address[](2); path[0] = address(this); path[1] = uniswapV2Router.WETH(); _approve(address(this), address(uniswapV2Router), tokenAmount); // make the swap uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens( tokenAmount, 0, // accept any amount of ETH path, taxWallet, block.timestamp ); } function autoBurnLiquidityPairTokens() internal returns (bool) { lastLpBurnTime = block.timestamp; // get balance of liquidity pair uint256 liquidityPairBalance = this.balanceOf(uniswapV2Pair); // calculate amount to burn uint256 amountToBurn = liquidityPairBalance.mul(percentForLPBurn).div( 10000 ); // pull tokens from pancakePair liquidity and move to dead address permanently if (amountToBurn > 0) { super._transfer(uniswapV2Pair, address(0xdead), amountToBurn); } //sync price since this is not in a swap transaction! IUniswapV2Pair pair = IUniswapV2Pair(uniswapV2Pair); pair.sync(); return true; } function manualBurnLiquidityPairTokens( uint256 percent ) external onlyOwner returns (bool) { require( block.timestamp > lastManualLpBurnTime + manualBurnFrequency, "Must wait for cooldown to finish" ); require(percent <= 1000, "May not nuke more than 10% of tokens in LP"); lastManualLpBurnTime = block.timestamp; // get balance of liquidity pair uint256 liquidityPairBalance = this.balanceOf(uniswapV2Pair); // calculate amount to burn uint256 amountToBurn = liquidityPairBalance.mul(percent).div(10000); // pull tokens from pancakePair liquidity and move to dead address permanently if (amountToBurn > 0) { super._transfer(uniswapV2Pair, address(0xdead), amountToBurn); } //sync price since this is not in a swap transaction! IUniswapV2Pair pair = IUniswapV2Pair(uniswapV2Pair); pair.sync(); return true; } }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"bool","name":"enabled","type":"bool"}],"name":"SwapAndMarketEnabledUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"_isExcludedFromFee","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"_isExcludedMaxTransactionAmount","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"automatedMarketMakerPairs","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"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":"updAds","type":"address"},{"internalType":"bool","name":"isEx","type":"bool"}],"name":"excludeFromMaxTransaction","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address[]","name":"accounts","type":"address[]"},{"internalType":"bool","name":"excluded","type":"bool"}],"name":"excludeMultipleAccountsFromFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"getFeesPercent","outputs":[{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"initialize","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"lastLpBurnTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"lastManualLpBurnTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"launchedAt","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"limitsInEffect","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"lpBurnEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"lpBurnFrequency","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"manualBurnFrequency","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"percent","type":"uint256"}],"name":"manualBurnLiquidityPairTokens","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"maxTransactionAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxWallet","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"numTokensSellToMarket","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"percentForLPBurn","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"removeLimits","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_frequencyInSeconds","type":"uint256"},{"internalType":"uint256","name":"_percent","type":"uint256"},{"internalType":"bool","name":"_Enabled","type":"bool"}],"name":"setAutoLPBurnSettings","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"pair","type":"address"},{"internalType":"bool","name":"value","type":"bool"}],"name":"setAutomatedMarketMakerPair","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"num","type":"uint256"}],"name":"setNumTokensSellToMarket","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_enabled","type":"bool"}],"name":"setSwapAndMarketEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapAndMarketEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"taxWallet","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tradeEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"uniswapV2Pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"stateMutability":"payable","type":"receive"}]
Contract Creation Code
60a0604052600a805460ff1916601290811782556200001e9162000510565b6200002e906305f5e10062000528565b600b556014600c819055600d5561270f600e55600f8054600160ff19909116179055603c601055610708601255737a250d5630b4cf539739df2c5dacb4c659f2488d6080526018805463ffffff00191663010001001790556000601955600a8054620000a09160ff9091169062000510565b620000af90621e848062000528565b601a55601b80546001600160a01b03191673d97d8cce3dd4f383c8ba186cf63f0d70f824c93b179055348015620000e557600080fd5b506040518060400160405280600d81526020016c496e7374616e74205374616b6560981b81525060405180604001604052806007815260200166125394d510539560ca1b81525081600390816200013d9190620005e6565b5060046200014c8282620005e6565b50505062000169620001636200021160201b60201c565b62000215565b62000188620001806005546001600160a01b031690565b600162000267565b601b54620001a1906001600160a01b0316600162000267565b620001ae30600162000267565b620001cd620001c56005546001600160a01b031690565b60016200029c565b620001da3060016200029c565b620001e961dead60016200029c565b6a01a784379d99db4200000060148190556015556200020b33600b54620002d1565b620006c8565b3390565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6200027162000398565b6001600160a01b03919091166000908152600860205260409020805460ff1916911515919091179055565b620002a662000398565b6001600160a01b03919091166000908152600960205260409020805460ff1916911515919091179055565b6001600160a01b0382166200032d5760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f20616464726573730060448201526064015b60405180910390fd5b8060026000828254620003419190620006b2565b90915550506001600160a01b038216600081815260208181526040808320805486019055518481527fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35050565b6005546001600160a01b03163314620003f45760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015260640162000324565b565b505050565b634e487b7160e01b600052601160045260246000fd5b600181815b8085111562000452578160001904821115620004365762000436620003fb565b808516156200044457918102915b93841c939080029062000416565b509250929050565b6000826200046b575060016200050a565b816200047a575060006200050a565b81600181146200049357600281146200049e57620004be565b60019150506200050a565b60ff841115620004b257620004b2620003fb565b50506001821b6200050a565b5060208310610133831016604e8410600b8410161715620004e3575081810a6200050a565b620004ef838362000411565b8060001904821115620005065762000506620003fb565b0290505b92915050565b60006200052160ff8416836200045a565b9392505050565b80820281158282048414176200050a576200050a620003fb565b634e487b7160e01b600052604160045260246000fd5b600181811c908216806200056d57607f821691505b6020821081036200058e57634e487b7160e01b600052602260045260246000fd5b50919050565b601f821115620003f657600081815260208120601f850160051c81016020861015620005bd5750805b601f850160051c820191505b81811015620005de57828155600101620005c9565b505050505050565b81516001600160401b0381111562000602576200060262000542565b6200061a8162000613845462000558565b8462000594565b602080601f831160018114620006525760008415620006395750858301515b600019600386901b1c1916600185901b178555620005de565b600085815260208120601f198616915b82811015620006835788860151825594840194600190910190840162000662565b5085821015620006a25787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b808201808211156200050a576200050a620003fb565b60805161248b620007156000396000818161036101528181610b6a01528181610bfb01528181610d1201528181610d5201528181611d3a01528181611df30152611e32015261248b6000f3fe6080604052600436106102765760003560e01c8063730c18881161014f578063a45b154a116100c1578063c8c8ebe41161007a578063c8c8ebe414610762578063d621e81314610778578063dd62ed3e14610798578063f2fde38b146107b8578063f8b45b05146107d8578063fe72b27a146107ee57600080fd5b8063a45b154a146106a7578063a4c82a00146106c6578063a9059cbb146106dc578063b62496f5146106fc578063bf56b3711461072c578063c02466681461074257600080fd5b80638a8c523c116101135780638a8c523c146106095780638da5cb5b1461061e57806395d89b411461063c5780639a7a23d6146106515780639ec22c0e14610671578063a457c2d71461068757600080fd5b8063730c18881461057c578063751039fc1461059c5780637571336a146105b1578063768dc710146105d15780638129fc1c1461060157600080fd5b80632dc0562d116101e8578063402fae58116101ac578063402fae58146104b257806349bd5a5e146104c85780634a62bb65146104e85780635e7f67181461050957806370a0823114610531578063715018a61461056757600080fd5b80632dc0562d1461041c5780632e82f1a01461043c578063313ce567146104565780633690fe4014610472578063395093511461049257600080fd5b80631694505e1161023a5780631694505e1461034f57806318160ddd1461039b578063184c16c5146103ba578063199ffc72146103d057806323b872dd146103e65780632c3e486c1461040657600080fd5b806306fdde03146102825780630850935f146102ad578063095ea7b3146102cf57806310d5de53146102ff578063128f72c31461032f57600080fd5b3661027d57005b600080fd5b34801561028e57600080fd5b5061029761080e565b6040516102a49190611fcb565b60405180910390f35b3480156102b957600080fd5b506102cd6102c8366004612029565b6108a0565b005b3480156102db57600080fd5b506102ef6102ea3660046120c2565b61091f565b60405190151581526020016102a4565b34801561030b57600080fd5b506102ef61031a3660046120ee565b60096020526000908152604090205460ff1681565b34801561033b57600080fd5b506102cd61034a36600461210b565b610939565b34801561035b57600080fd5b506103837f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b0390911681526020016102a4565b3480156103a757600080fd5b506002545b6040519081526020016102a4565b3480156103c657600080fd5b506103ac60125481565b3480156103dc57600080fd5b506103ac600e5481565b3480156103f257600080fd5b506102ef610401366004612124565b610946565b34801561041257600080fd5b506103ac60105481565b34801561042857600080fd5b50601b54610383906001600160a01b031681565b34801561044857600080fd5b50600f546102ef9060ff1681565b34801561046257600080fd5b50604051601281526020016102a4565b34801561047e57600080fd5b506102cd61048d366004612165565b610968565b34801561049e57600080fd5b506102ef6104ad3660046120c2565b6109c4565b3480156104be57600080fd5b506103ac601a5481565b3480156104d457600080fd5b50601654610383906001600160a01b031681565b3480156104f457600080fd5b506018546102ef906301000000900460ff1681565b34801561051557600080fd5b50600c54600d54604080519283526020830191909152016102a4565b34801561053d57600080fd5b506103ac61054c3660046120ee565b6001600160a01b031660009081526020819052604090205490565b34801561057357600080fd5b506102cd6109e6565b34801561058857600080fd5b506102cd610597366004612180565b6109fa565b3480156105a857600080fd5b506102ef610b06565b3480156105bd57600080fd5b506102cd6105cc3660046121ac565b610b2d565b3480156105dd57600080fd5b506102ef6105ec3660046120ee565b60086020526000908152604090205460ff1681565b6102cd610b60565b34801561061557600080fd5b506102cd610e5c565b34801561062a57600080fd5b506005546001600160a01b0316610383565b34801561064857600080fd5b50610297610e85565b34801561065d57600080fd5b506102cd61066c3660046121ac565b610e94565b34801561067d57600080fd5b506103ac60135481565b34801561069357600080fd5b506102ef6106a23660046120c2565b610f2e565b3480156106b357600080fd5b506018546102ef90610100900460ff1681565b3480156106d257600080fd5b506103ac60115481565b3480156106e857600080fd5b506102ef6106f73660046120c2565b610fb4565b34801561070857600080fd5b506102ef6107173660046120ee565b60176020526000908152604090205460ff1681565b34801561073857600080fd5b506103ac60195481565b34801561074e57600080fd5b506102cd61075d3660046121ac565b610fc8565b34801561076e57600080fd5b506103ac60145481565b34801561078457600080fd5b506018546102ef9062010000900460ff1681565b3480156107a457600080fd5b506103ac6107b33660046121e1565b610ffb565b3480156107c457600080fd5b506102cd6107d33660046120ee565b611026565b3480156107e457600080fd5b506103ac60155481565b3480156107fa57600080fd5b506102ef61080936600461210b565b61109f565b60606003805461081d9061221a565b80601f01602080910402602001604051908101604052809291908181526020018280546108499061221a565b80156108965780601f1061086b57610100808354040283529160200191610896565b820191906000526020600020905b81548152906001019060200180831161087957829003601f168201915b5050505050905090565b6108a8611289565b60005b828110156109195781600860008686858181106108ca576108ca612254565b90506020020160208101906108df91906120ee565b6001600160a01b031681526020810191909152604001600020805460ff19169115159190911790558061091181612280565b9150506108ab565b50505050565b60003361092d8185856112e3565b60019150505b92915050565b610941611289565b601a55565b600033610954858285611407565b61095f85858561147b565b95945050505050565b610970611289565b601880548215156101000261ff00199091161790556040517f67cbe9d16793e5cd880dafc6b9ad4a568545d35aa475a92dc80ded5dba515474906109b990831515815260200190565b60405180910390a150565b60003361092d8185856109d78383610ffb565b6109e19190612299565b6112e3565b6109ee611289565b6109f86000611b24565b565b610a02611289565b610258831015610a755760405162461bcd60e51b815260206004820152603360248201527f63616e6e6f7420736574206275796261636b206d6f7265206f6674656e207468604482015272616e206576657279203130206d696e7574657360681b60648201526084015b60405180910390fd5b6103e88211158015610a85575060015b610aea5760405162461bcd60e51b815260206004820152603060248201527f4d75737420736574206175746f204c50206275726e2070657263656e7420626560448201526f747765656e20302520616e642031302560801b6064820152608401610a6c565b601092909255600e55600f805460ff1916911515919091179055565b6000610b10611289565b506018805463ff000000191690556002600c819055600d55600190565b610b35611289565b6001600160a01b03919091166000908152600960205260409020805460ff1916911515919091179055565b610b68611289565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610bc6573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610bea91906122ac565b6001600160a01b031663c9c65396307f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610c57573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610c7b91906122ac565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af1158015610cc8573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610cec91906122ac565b601680546001600160a01b0319166001600160a01b0392909216919091179055610d39307f00000000000000000000000000000000000000000000000000000000000000006000196112e3565b601654610d50906001600160a01b03166001610b2d565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663f305d7193430610da0306001600160a01b031660009081526020819052604090205490565b600080610db56005546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af1158015610e1d573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190610e4291906122c9565b50506016546109f891506001600160a01b03166001611b76565b610e64611289565b6018805462ff00001916620100001790556019546000036109f85743601955565b60606004805461081d9061221a565b610e9c611289565b6016546001600160a01b0390811690831603610f205760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b65725061697273000000000000006064820152608401610a6c565b610f2a8282611b76565b5050565b60003381610f3c8286610ffb565b905083811015610f9c5760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b6064820152608401610a6c565b610fa982868684036112e3565b506001949350505050565b6000610fc133848461147b565b9392505050565b610fd0611289565b6001600160a01b03919091166000908152600860205260409020805460ff1916911515919091179055565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b61102e611289565b6001600160a01b0381166110935760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610a6c565b61109c81611b24565b50565b60006110a9611289565b6012546013546110b99190612299565b42116111075760405162461bcd60e51b815260206004820181905260248201527f4d757374207761697420666f7220636f6f6c646f776e20746f2066696e6973686044820152606401610a6c565b6103e882111561116c5760405162461bcd60e51b815260206004820152602a60248201527f4d6179206e6f74206e756b65206d6f7265207468616e20313025206f6620746f60448201526906b656e7320696e204c560b41b6064820152608401610a6c565b426013556016546040516370a0823160e01b81526001600160a01b03909116600482015260009030906370a0823190602401602060405180830381865afa1580156111bb573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906111df91906122f7565b905060006111f96127106111f38487611ba1565b90611bad565b9050801561121a5760165461121a906001600160a01b031661dead83611bb9565b6016546040805160016209351760e01b0319815290516001600160a01b0390921691829163fff6cae991600480830192600092919082900301818387803b15801561126457600080fd5b505af1158015611278573d6000803e3d6000fd5b50505050600193505050505b919050565b6005546001600160a01b031633146109f85760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610a6c565b6001600160a01b0383166113455760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610a6c565b6001600160a01b0382166113a65760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610a6c565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60006114138484610ffb565b90506000198114610919578181101561146e5760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e63650000006044820152606401610a6c565b61091984848484036112e3565b60006001600160a01b0384166114a35760405162461bcd60e51b8152600401610a6c90612310565b6001600160a01b0383166114c95760405162461bcd60e51b8152600401610a6c90612355565b6000821161152b5760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b6064820152608401610a6c565b6018546301000000900460ff16156118a6576005546001600160a01b0385811691161480159061156957506005546001600160a01b03848116911614155b801561157d57506001600160a01b03831615155b801561159457506001600160a01b03831661dead14155b80156115a3575060185460ff16155b156118a65760185462010000900460ff161580156115fe57506001600160a01b03841660009081526008602052604090205460ff161580156115fe57506001600160a01b03831660009081526008602052604090205460ff16155b156116405760405162461bcd60e51b815260206004820152601260248201527143616e2774207472616e73666572206e6f7760701b6044820152606401610a6c565b6001600160a01b03841660009081526017602052604090205460ff16801561168157506001600160a01b03831660009081526009602052604090205460ff16155b15611765576014548211156116f65760405162461bcd60e51b815260206004820152603560248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201527436b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760591b6064820152608401610a6c565b6015546001600160a01b03841660009081526020819052604090205461171c9084612299565b11156117605760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610a6c565b6118a6565b6001600160a01b03831660009081526017602052604090205460ff1680156117a657506001600160a01b03841660009081526009602052604090205460ff16155b1561181c576014548211156117605760405162461bcd60e51b815260206004820152603660248201527f53656c6c207472616e7366657220616d6f756e742065786365656473207468656044820152751036b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760511b6064820152608401610a6c565b6001600160a01b03831660009081526009602052604090205460ff166118a6576015546001600160a01b0384166000908152602081905260409020546118629084612299565b11156118a65760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610a6c565b30600090815260208190526040902054801580159081906118ca575060185460ff16155b80156118ef57506001600160a01b03861660009081526017602052604090205460ff16155b801561191457506001600160a01b03861660009081526008602052604090205460ff16155b80156119275750601854610100900460ff165b1561194d576018805460ff1916600117905561194282611ce3565b6018805460ff191690555b60185460ff1615801561197857506001600160a01b03851660009081526017602052604090205460ff165b80156119865750600f5460ff165b80156119a1575060105460115461199d9190612299565b4210155b80156119c557506001600160a01b03861660009081526008602052604090205460ff165b156119d4576119d2611eaa565b505b6001600160a01b03861660009081526008602052604090205460019060ff1680611a1657506001600160a01b03861660009081526008602052604090205460ff165b15611a1f575060005b8015611b0c576001600160a01b038716600090815260176020526040812054819060ff1615611a65576064600c5488611a589190612398565b611a6291906123af565b90505b6001600160a01b03881660009081526017602052604090205460ff1615611aa3576064600d5488611a969190612398565b611aa091906123af565b90505b8091506000611ac78a6001600160a01b031660009081526020819052604090205490565b9050878103611aeb57611ade6305f5e100896123af565b611ae890896123d1565b97505b611af583896123d1565b97508215611b0857611b088a3085611bb9565b5050505b611b17878787611bb9565b5060019695505050505050565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b03919091166000908152601760205260409020805460ff1916911515919091179055565b6000610fc18284612398565b6000610fc182846123af565b6001600160a01b038316611bdf5760405162461bcd60e51b8152600401610a6c90612310565b6001600160a01b038216611c055760405162461bcd60e51b8152600401610a6c90612355565b6001600160a01b03831660009081526020819052604090205481811015611c7d5760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610a6c565b6001600160a01b03848116600081815260208181526040808320878703905593871680835291849020805487019055925185815290927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a3610919565b6040805160028082526060820183526000926020830190803683370190505090503081600081518110611d1857611d18612254565b60200260200101906001600160a01b031690816001600160a01b0316815250507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611d96573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611dba91906122ac565b81600181518110611dcd57611dcd612254565b60200260200101906001600160a01b031690816001600160a01b031681525050611e18307f0000000000000000000000000000000000000000000000000000000000000000846112e3565b601b5460405163791ac94760e01b81526001600160a01b037f000000000000000000000000000000000000000000000000000000000000000081169263791ac94792611e749287926000928892919091169042906004016123e4565b600060405180830381600087803b158015611e8e57600080fd5b505af1158015611ea2573d6000803e3d6000fd5b505050505050565b426011556016546040516370a0823160e01b81526001600160a01b039091166004820152600090819030906370a0823190602401602060405180830381865afa158015611efb573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611f1f91906122f7565b90506000611f3e6127106111f3600e5485611ba190919063ffffffff16565b90508015611f5f57601654611f5f906001600160a01b031661dead83611bb9565b6016546040805160016209351760e01b0319815290516001600160a01b0390921691829163fff6cae991600480830192600092919082900301818387803b158015611fa957600080fd5b505af1158015611fbd573d6000803e3d6000fd5b505050506001935050505090565b600060208083528351808285015260005b81811015611ff857858101830151858201604001528201611fdc565b506000604082860101526040601f19601f8301168501019250505092915050565b8035801515811461128457600080fd5b60008060006040848603121561203e57600080fd5b833567ffffffffffffffff8082111561205657600080fd5b818601915086601f83011261206a57600080fd5b81358181111561207957600080fd5b8760208260051b850101111561208e57600080fd5b6020928301955093506120a49186019050612019565b90509250925092565b6001600160a01b038116811461109c57600080fd5b600080604083850312156120d557600080fd5b82356120e0816120ad565b946020939093013593505050565b60006020828403121561210057600080fd5b8135610fc1816120ad565b60006020828403121561211d57600080fd5b5035919050565b60008060006060848603121561213957600080fd5b8335612144816120ad565b92506020840135612154816120ad565b929592945050506040919091013590565b60006020828403121561217757600080fd5b610fc182612019565b60008060006060848603121561219557600080fd5b83359250602084013591506120a460408501612019565b600080604083850312156121bf57600080fd5b82356121ca816120ad565b91506121d860208401612019565b90509250929050565b600080604083850312156121f457600080fd5b82356121ff816120ad565b9150602083013561220f816120ad565b809150509250929050565b600181811c9082168061222e57607f821691505b60208210810361224e57634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b6000600182016122925761229261226a565b5060010190565b808201808211156109335761093361226a565b6000602082840312156122be57600080fd5b8151610fc1816120ad565b6000806000606084860312156122de57600080fd5b8351925060208401519150604084015190509250925092565b60006020828403121561230957600080fd5b5051919050565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b80820281158282048414176109335761093361226a565b6000826123cc57634e487b7160e01b600052601260045260246000fd5b500490565b818103818111156109335761093361226a565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156124345784516001600160a01b03168352938301939183019160010161240f565b50506001600160a01b0396909616606085015250505060800152939250505056fea2646970667358221220fe7b7c976064783d21b0952a3e127b7d09d4f23ccf12d04295c68e6fd66f647a64736f6c63430008130033
Deployed Bytecode
0x6080604052600436106102765760003560e01c8063730c18881161014f578063a45b154a116100c1578063c8c8ebe41161007a578063c8c8ebe414610762578063d621e81314610778578063dd62ed3e14610798578063f2fde38b146107b8578063f8b45b05146107d8578063fe72b27a146107ee57600080fd5b8063a45b154a146106a7578063a4c82a00146106c6578063a9059cbb146106dc578063b62496f5146106fc578063bf56b3711461072c578063c02466681461074257600080fd5b80638a8c523c116101135780638a8c523c146106095780638da5cb5b1461061e57806395d89b411461063c5780639a7a23d6146106515780639ec22c0e14610671578063a457c2d71461068757600080fd5b8063730c18881461057c578063751039fc1461059c5780637571336a146105b1578063768dc710146105d15780638129fc1c1461060157600080fd5b80632dc0562d116101e8578063402fae58116101ac578063402fae58146104b257806349bd5a5e146104c85780634a62bb65146104e85780635e7f67181461050957806370a0823114610531578063715018a61461056757600080fd5b80632dc0562d1461041c5780632e82f1a01461043c578063313ce567146104565780633690fe4014610472578063395093511461049257600080fd5b80631694505e1161023a5780631694505e1461034f57806318160ddd1461039b578063184c16c5146103ba578063199ffc72146103d057806323b872dd146103e65780632c3e486c1461040657600080fd5b806306fdde03146102825780630850935f146102ad578063095ea7b3146102cf57806310d5de53146102ff578063128f72c31461032f57600080fd5b3661027d57005b600080fd5b34801561028e57600080fd5b5061029761080e565b6040516102a49190611fcb565b60405180910390f35b3480156102b957600080fd5b506102cd6102c8366004612029565b6108a0565b005b3480156102db57600080fd5b506102ef6102ea3660046120c2565b61091f565b60405190151581526020016102a4565b34801561030b57600080fd5b506102ef61031a3660046120ee565b60096020526000908152604090205460ff1681565b34801561033b57600080fd5b506102cd61034a36600461210b565b610939565b34801561035b57600080fd5b506103837f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d81565b6040516001600160a01b0390911681526020016102a4565b3480156103a757600080fd5b506002545b6040519081526020016102a4565b3480156103c657600080fd5b506103ac60125481565b3480156103dc57600080fd5b506103ac600e5481565b3480156103f257600080fd5b506102ef610401366004612124565b610946565b34801561041257600080fd5b506103ac60105481565b34801561042857600080fd5b50601b54610383906001600160a01b031681565b34801561044857600080fd5b50600f546102ef9060ff1681565b34801561046257600080fd5b50604051601281526020016102a4565b34801561047e57600080fd5b506102cd61048d366004612165565b610968565b34801561049e57600080fd5b506102ef6104ad3660046120c2565b6109c4565b3480156104be57600080fd5b506103ac601a5481565b3480156104d457600080fd5b50601654610383906001600160a01b031681565b3480156104f457600080fd5b506018546102ef906301000000900460ff1681565b34801561051557600080fd5b50600c54600d54604080519283526020830191909152016102a4565b34801561053d57600080fd5b506103ac61054c3660046120ee565b6001600160a01b031660009081526020819052604090205490565b34801561057357600080fd5b506102cd6109e6565b34801561058857600080fd5b506102cd610597366004612180565b6109fa565b3480156105a857600080fd5b506102ef610b06565b3480156105bd57600080fd5b506102cd6105cc3660046121ac565b610b2d565b3480156105dd57600080fd5b506102ef6105ec3660046120ee565b60086020526000908152604090205460ff1681565b6102cd610b60565b34801561061557600080fd5b506102cd610e5c565b34801561062a57600080fd5b506005546001600160a01b0316610383565b34801561064857600080fd5b50610297610e85565b34801561065d57600080fd5b506102cd61066c3660046121ac565b610e94565b34801561067d57600080fd5b506103ac60135481565b34801561069357600080fd5b506102ef6106a23660046120c2565b610f2e565b3480156106b357600080fd5b506018546102ef90610100900460ff1681565b3480156106d257600080fd5b506103ac60115481565b3480156106e857600080fd5b506102ef6106f73660046120c2565b610fb4565b34801561070857600080fd5b506102ef6107173660046120ee565b60176020526000908152604090205460ff1681565b34801561073857600080fd5b506103ac60195481565b34801561074e57600080fd5b506102cd61075d3660046121ac565b610fc8565b34801561076e57600080fd5b506103ac60145481565b34801561078457600080fd5b506018546102ef9062010000900460ff1681565b3480156107a457600080fd5b506103ac6107b33660046121e1565b610ffb565b3480156107c457600080fd5b506102cd6107d33660046120ee565b611026565b3480156107e457600080fd5b506103ac60155481565b3480156107fa57600080fd5b506102ef61080936600461210b565b61109f565b60606003805461081d9061221a565b80601f01602080910402602001604051908101604052809291908181526020018280546108499061221a565b80156108965780601f1061086b57610100808354040283529160200191610896565b820191906000526020600020905b81548152906001019060200180831161087957829003601f168201915b5050505050905090565b6108a8611289565b60005b828110156109195781600860008686858181106108ca576108ca612254565b90506020020160208101906108df91906120ee565b6001600160a01b031681526020810191909152604001600020805460ff19169115159190911790558061091181612280565b9150506108ab565b50505050565b60003361092d8185856112e3565b60019150505b92915050565b610941611289565b601a55565b600033610954858285611407565b61095f85858561147b565b95945050505050565b610970611289565b601880548215156101000261ff00199091161790556040517f67cbe9d16793e5cd880dafc6b9ad4a568545d35aa475a92dc80ded5dba515474906109b990831515815260200190565b60405180910390a150565b60003361092d8185856109d78383610ffb565b6109e19190612299565b6112e3565b6109ee611289565b6109f86000611b24565b565b610a02611289565b610258831015610a755760405162461bcd60e51b815260206004820152603360248201527f63616e6e6f7420736574206275796261636b206d6f7265206f6674656e207468604482015272616e206576657279203130206d696e7574657360681b60648201526084015b60405180910390fd5b6103e88211158015610a85575060015b610aea5760405162461bcd60e51b815260206004820152603060248201527f4d75737420736574206175746f204c50206275726e2070657263656e7420626560448201526f747765656e20302520616e642031302560801b6064820152608401610a6c565b601092909255600e55600f805460ff1916911515919091179055565b6000610b10611289565b506018805463ff000000191690556002600c819055600d55600190565b610b35611289565b6001600160a01b03919091166000908152600960205260409020805460ff1916911515919091179055565b610b68611289565b7f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610bc6573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610bea91906122ac565b6001600160a01b031663c9c65396307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610c57573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610c7b91906122ac565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af1158015610cc8573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610cec91906122ac565b601680546001600160a01b0319166001600160a01b0392909216919091179055610d39307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6000196112e3565b601654610d50906001600160a01b03166001610b2d565b7f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663f305d7193430610da0306001600160a01b031660009081526020819052604090205490565b600080610db56005546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af1158015610e1d573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190610e4291906122c9565b50506016546109f891506001600160a01b03166001611b76565b610e64611289565b6018805462ff00001916620100001790556019546000036109f85743601955565b60606004805461081d9061221a565b610e9c611289565b6016546001600160a01b0390811690831603610f205760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b65725061697273000000000000006064820152608401610a6c565b610f2a8282611b76565b5050565b60003381610f3c8286610ffb565b905083811015610f9c5760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b6064820152608401610a6c565b610fa982868684036112e3565b506001949350505050565b6000610fc133848461147b565b9392505050565b610fd0611289565b6001600160a01b03919091166000908152600860205260409020805460ff1916911515919091179055565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b61102e611289565b6001600160a01b0381166110935760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610a6c565b61109c81611b24565b50565b60006110a9611289565b6012546013546110b99190612299565b42116111075760405162461bcd60e51b815260206004820181905260248201527f4d757374207761697420666f7220636f6f6c646f776e20746f2066696e6973686044820152606401610a6c565b6103e882111561116c5760405162461bcd60e51b815260206004820152602a60248201527f4d6179206e6f74206e756b65206d6f7265207468616e20313025206f6620746f60448201526906b656e7320696e204c560b41b6064820152608401610a6c565b426013556016546040516370a0823160e01b81526001600160a01b03909116600482015260009030906370a0823190602401602060405180830381865afa1580156111bb573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906111df91906122f7565b905060006111f96127106111f38487611ba1565b90611bad565b9050801561121a5760165461121a906001600160a01b031661dead83611bb9565b6016546040805160016209351760e01b0319815290516001600160a01b0390921691829163fff6cae991600480830192600092919082900301818387803b15801561126457600080fd5b505af1158015611278573d6000803e3d6000fd5b50505050600193505050505b919050565b6005546001600160a01b031633146109f85760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610a6c565b6001600160a01b0383166113455760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610a6c565b6001600160a01b0382166113a65760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610a6c565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60006114138484610ffb565b90506000198114610919578181101561146e5760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e63650000006044820152606401610a6c565b61091984848484036112e3565b60006001600160a01b0384166114a35760405162461bcd60e51b8152600401610a6c90612310565b6001600160a01b0383166114c95760405162461bcd60e51b8152600401610a6c90612355565b6000821161152b5760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b6064820152608401610a6c565b6018546301000000900460ff16156118a6576005546001600160a01b0385811691161480159061156957506005546001600160a01b03848116911614155b801561157d57506001600160a01b03831615155b801561159457506001600160a01b03831661dead14155b80156115a3575060185460ff16155b156118a65760185462010000900460ff161580156115fe57506001600160a01b03841660009081526008602052604090205460ff161580156115fe57506001600160a01b03831660009081526008602052604090205460ff16155b156116405760405162461bcd60e51b815260206004820152601260248201527143616e2774207472616e73666572206e6f7760701b6044820152606401610a6c565b6001600160a01b03841660009081526017602052604090205460ff16801561168157506001600160a01b03831660009081526009602052604090205460ff16155b15611765576014548211156116f65760405162461bcd60e51b815260206004820152603560248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201527436b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760591b6064820152608401610a6c565b6015546001600160a01b03841660009081526020819052604090205461171c9084612299565b11156117605760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610a6c565b6118a6565b6001600160a01b03831660009081526017602052604090205460ff1680156117a657506001600160a01b03841660009081526009602052604090205460ff16155b1561181c576014548211156117605760405162461bcd60e51b815260206004820152603660248201527f53656c6c207472616e7366657220616d6f756e742065786365656473207468656044820152751036b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760511b6064820152608401610a6c565b6001600160a01b03831660009081526009602052604090205460ff166118a6576015546001600160a01b0384166000908152602081905260409020546118629084612299565b11156118a65760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610a6c565b30600090815260208190526040902054801580159081906118ca575060185460ff16155b80156118ef57506001600160a01b03861660009081526017602052604090205460ff16155b801561191457506001600160a01b03861660009081526008602052604090205460ff16155b80156119275750601854610100900460ff165b1561194d576018805460ff1916600117905561194282611ce3565b6018805460ff191690555b60185460ff1615801561197857506001600160a01b03851660009081526017602052604090205460ff165b80156119865750600f5460ff165b80156119a1575060105460115461199d9190612299565b4210155b80156119c557506001600160a01b03861660009081526008602052604090205460ff165b156119d4576119d2611eaa565b505b6001600160a01b03861660009081526008602052604090205460019060ff1680611a1657506001600160a01b03861660009081526008602052604090205460ff165b15611a1f575060005b8015611b0c576001600160a01b038716600090815260176020526040812054819060ff1615611a65576064600c5488611a589190612398565b611a6291906123af565b90505b6001600160a01b03881660009081526017602052604090205460ff1615611aa3576064600d5488611a969190612398565b611aa091906123af565b90505b8091506000611ac78a6001600160a01b031660009081526020819052604090205490565b9050878103611aeb57611ade6305f5e100896123af565b611ae890896123d1565b97505b611af583896123d1565b97508215611b0857611b088a3085611bb9565b5050505b611b17878787611bb9565b5060019695505050505050565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b03919091166000908152601760205260409020805460ff1916911515919091179055565b6000610fc18284612398565b6000610fc182846123af565b6001600160a01b038316611bdf5760405162461bcd60e51b8152600401610a6c90612310565b6001600160a01b038216611c055760405162461bcd60e51b8152600401610a6c90612355565b6001600160a01b03831660009081526020819052604090205481811015611c7d5760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610a6c565b6001600160a01b03848116600081815260208181526040808320878703905593871680835291849020805487019055925185815290927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a3610919565b6040805160028082526060820183526000926020830190803683370190505090503081600081518110611d1857611d18612254565b60200260200101906001600160a01b031690816001600160a01b0316815250507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611d96573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611dba91906122ac565b81600181518110611dcd57611dcd612254565b60200260200101906001600160a01b031690816001600160a01b031681525050611e18307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d846112e3565b601b5460405163791ac94760e01b81526001600160a01b037f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d81169263791ac94792611e749287926000928892919091169042906004016123e4565b600060405180830381600087803b158015611e8e57600080fd5b505af1158015611ea2573d6000803e3d6000fd5b505050505050565b426011556016546040516370a0823160e01b81526001600160a01b039091166004820152600090819030906370a0823190602401602060405180830381865afa158015611efb573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611f1f91906122f7565b90506000611f3e6127106111f3600e5485611ba190919063ffffffff16565b90508015611f5f57601654611f5f906001600160a01b031661dead83611bb9565b6016546040805160016209351760e01b0319815290516001600160a01b0390921691829163fff6cae991600480830192600092919082900301818387803b158015611fa957600080fd5b505af1158015611fbd573d6000803e3d6000fd5b505050506001935050505090565b600060208083528351808285015260005b81811015611ff857858101830151858201604001528201611fdc565b506000604082860101526040601f19601f8301168501019250505092915050565b8035801515811461128457600080fd5b60008060006040848603121561203e57600080fd5b833567ffffffffffffffff8082111561205657600080fd5b818601915086601f83011261206a57600080fd5b81358181111561207957600080fd5b8760208260051b850101111561208e57600080fd5b6020928301955093506120a49186019050612019565b90509250925092565b6001600160a01b038116811461109c57600080fd5b600080604083850312156120d557600080fd5b82356120e0816120ad565b946020939093013593505050565b60006020828403121561210057600080fd5b8135610fc1816120ad565b60006020828403121561211d57600080fd5b5035919050565b60008060006060848603121561213957600080fd5b8335612144816120ad565b92506020840135612154816120ad565b929592945050506040919091013590565b60006020828403121561217757600080fd5b610fc182612019565b60008060006060848603121561219557600080fd5b83359250602084013591506120a460408501612019565b600080604083850312156121bf57600080fd5b82356121ca816120ad565b91506121d860208401612019565b90509250929050565b600080604083850312156121f457600080fd5b82356121ff816120ad565b9150602083013561220f816120ad565b809150509250929050565b600181811c9082168061222e57607f821691505b60208210810361224e57634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b6000600182016122925761229261226a565b5060010190565b808201808211156109335761093361226a565b6000602082840312156122be57600080fd5b8151610fc1816120ad565b6000806000606084860312156122de57600080fd5b8351925060208401519150604084015190509250925092565b60006020828403121561230957600080fd5b5051919050565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b80820281158282048414176109335761093361226a565b6000826123cc57634e487b7160e01b600052601260045260246000fd5b500490565b818103818111156109335761093361226a565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156124345784516001600160a01b03168352938301939183019160010161240f565b50506001600160a01b0396909616606085015250505060800152939250505056fea2646970667358221220fe7b7c976064783d21b0952a3e127b7d09d4f23ccf12d04295c68e6fd66f647a64736f6c63430008130033
Deployed Bytecode Sourcemap
43497:12083:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4437:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;46213:259;;;;;;;;;;-1:-1:-1;46213:259:0;;;;;:::i;:::-;;:::i;:::-;;6854:226;;;;;;;;;;-1:-1:-1;6854:226:0;;;;;:::i;:::-;;:::i;:::-;;;2047:14:1;;2040:22;2022:41;;2010:2;1995:18;6854:226:0;1882:187:1;43792:63:0;;;;;;;;;;-1:-1:-1;43792:63:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;46985:110;;;;;;;;;;-1:-1:-1;46985:110:0;;;;;:::i;:::-;;:::i;44390:121::-;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;2700:32:1;;;2682:51;;2670:2;2655:18;44390:121:0;2511:228:1;5557:108:0;;;;;;;;;;-1:-1:-1;5645:12:0;;5557:108;;;2890:25:1;;;2878:2;2863:18;5557:108:0;2744:177:1;44217:47:0;;;;;;;;;;;;;;;;44046:38;;;;;;;;;;;;;;;;49044:305;;;;;;;;;;-1:-1:-1;49044:305:0;;;;;:::i;:::-;;:::i;44130:42::-;;;;;;;;;;;;;;;;44888:69;;;;;;;;;;-1:-1:-1;44888:69:0;;;;-1:-1:-1;;;;;44888:69:0;;;44091:32;;;;;;;;;;-1:-1:-1;44091:32:0;;;;;;;;5399:93;;;;;;;;;;-1:-1:-1;5399:93:0;;5482:2;3737:36:1;;3725:2;3710:18;5399:93:0;3595:184:1;46480:168:0;;;;;;;;;;-1:-1:-1;46480:168:0;;;;;:::i;:::-;;:::i;8364:263::-;;;;;;;;;;-1:-1:-1;8364:263:0;;;;;:::i;:::-;;:::i;44813:66::-;;;;;;;;;;;;;;;;44518:28;;;;;;;;;;-1:-1:-1;44518:28:0;;;;-1:-1:-1;;;;;44518:28:0;;;44733:33;;;;;;;;;;-1:-1:-1;44733:33:0;;;;;;;;;;;48434:122;;;;;;;;;;-1:-1:-1;48520:12:0;;48534:13;;48434:122;;;4143:25:1;;;4199:2;4184:18;;4177:34;;;;4116:18;48434:122:0;3969:248:1;5728:143:0;;;;;;;;;;-1:-1:-1;5728:143:0;;;;;:::i;:::-;-1:-1:-1;;;;;5845:18:0;5818:7;5845:18;;;;;;;;;;;;5728:143;19320:103;;;;;;;;;;;;;:::i;47871:555::-;;;;;;;;;;-1:-1:-1;47871:555:0;;;;;:::i;:::-;;:::i;46801:176::-;;;;;;;;;;;;;:::i;47103:169::-;;;;;;;;;;-1:-1:-1;47103:169:0;;;;;:::i;:::-;;:::i;43735:50::-;;;;;;;;;;-1:-1:-1;43735:50:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;45570:635;;;:::i;46656:137::-;;;;;;;;;;;;;:::i;18672:87::-;;;;;;;;;;-1:-1:-1;18745:6:0;;-1:-1:-1;;;;;18745:6:0;18672:87;;4656:104;;;;;;;;;;;;;:::i;47419:306::-;;;;;;;;;;-1:-1:-1;47419:306:0;;;;;:::i;:::-;;:::i;44271:35::-;;;;;;;;;;;;;;;;9130:498;;;;;;;;;;-1:-1:-1;9130:498:0;;;;;:::i;:::-;;:::i;44648:39::-;;;;;;;;;;-1:-1:-1;44648:39:0;;;;;;;;;;;44179:29;;;;;;;;;;;;;;;;48860:176;;;;;;;;;;-1:-1:-1;48860:176:0;;;;;:::i;:::-;;:::i;44555:57::-;;;;;;;;;;-1:-1:-1;44555:57:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;44775:29;;;;;;;;;;;;;;;;47280:131;;;;;;;;;;-1:-1:-1;47280:131:0;;;;;:::i;:::-;;:::i;44315:35::-;;;;;;;;;;;;;;;;44694:32;;;;;;;;;;-1:-1:-1;44694:32:0;;;;;;;;;;;6358:176;;;;;;;;;;-1:-1:-1;6358:176:0;;;;;:::i;:::-;;:::i;19578:238::-;;;;;;;;;;-1:-1:-1;19578:238:0;;;;;:::i;:::-;;:::i;44357:24::-;;;;;;;;;;;;;;;;54567:1010;;;;;;;;;;-1:-1:-1;54567:1010:0;;;;;:::i;:::-;;:::i;4437:100::-;4491:13;4524:5;4517:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4437:100;:::o;46213:259::-;18558:13;:11;:13::i;:::-;46355:9:::1;46350:115;46370:19:::0;;::::1;46350:115;;;46445:8;46411:18;:31;46430:8;;46439:1;46430:11;;;;;;;:::i;:::-;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;;;;46411:31:0::1;::::0;;::::1;::::0;::::1;::::0;;;;;;-1:-1:-1;46411:31:0;:42;;-1:-1:-1;;46411:42:0::1;::::0;::::1;;::::0;;;::::1;::::0;;46391:3;::::1;::::0;::::1;:::i;:::-;;;;46350:115;;;;46213:259:::0;;;:::o;6854:226::-;6962:4;3523:10;7018:32;3523:10;7034:7;7043:6;7018:8;:32::i;:::-;7068:4;7061:11;;;6854:226;;;;;:::o;46985:110::-;18558:13;:11;:13::i;:::-;47060:21:::1;:27:::0;46985:110::o;49044:305::-;49184:4;3523:10;49242:40;49258:6;3523:10;49275:6;49242:15;:40::i;:::-;49300:41;49315:6;49323:9;49334:6;49300:14;:41::i;:::-;49293:48;49044:305;-1:-1:-1;;;;;49044:305:0:o;46480:168::-;18558:13;:11;:13::i;:::-;46556:20:::1;:31:::0;;;::::1;;;;-1:-1:-1::0;;46556:31:0;;::::1;;::::0;;46603:37:::1;::::0;::::1;::::0;::::1;::::0;46579:8;2047:14:1;2040:22;2022:41;;2010:2;1995:18;;1882:187;46603:37:0::1;;;;;;;;46480:168:::0;:::o;8364:263::-;8477:4;3523:10;8533:64;3523:10;8549:7;8586:10;8558:25;3523:10;8549:7;8558:9;:25::i;:::-;:38;;;;:::i;:::-;8533:8;:64::i;19320:103::-;18558:13;:11;:13::i;:::-;19385:30:::1;19412:1;19385:18;:30::i;:::-;19320:103::o:0;47871:555::-;18558:13;:11;:13::i;:::-;48073:3:::1;48050:19;:26;;48028:127;;;::::0;-1:-1:-1;;;48028:127:0;;6377:2:1;48028:127:0::1;::::0;::::1;6359:21:1::0;6416:2;6396:18;;;6389:30;6455:34;6435:18;;;6428:62;-1:-1:-1;;;6506:18:1;;;6499:49;6565:19;;48028:127:0::1;;;;;;;;;48200:4;48188:8;:16;;:33;;;;-1:-1:-1::0;48208:13:0;48188:33:::1;48166:131;;;::::0;-1:-1:-1;;;48166:131:0;;6797:2:1;48166:131:0::1;::::0;::::1;6779:21:1::0;6836:2;6816:18;;;6809:30;6875:34;6855:18;;;6848:62;-1:-1:-1;;;6926:18:1;;;6919:46;6982:19;;48166:131:0::1;6595:412:1::0;48166:131:0::1;48308:15;:37:::0;;;;48356:16:::1;:27:::0;48394:13:::1;:24:::0;;-1:-1:-1;;48394:24:0::1;::::0;::::1;;::::0;;;::::1;::::0;;47871:555::o;46801:176::-;46853:4;18558:13;:11;:13::i;:::-;-1:-1:-1;46870:14:0::1;:22:::0;;-1:-1:-1;;46870:22:0::1;::::0;;46918:1:::1;46903:12;:16:::0;;;46930:13:::1;:17:::0;46870:22;46801:176;:::o;47103:169::-;18558:13;:11;:13::i;:::-;-1:-1:-1;;;;;47218:39:0;;;::::1;;::::0;;;:31:::1;:39;::::0;;;;:46;;-1:-1:-1;;47218:46:0::1;::::0;::::1;;::::0;;;::::1;::::0;;47103:169::o;45570:635::-;18558:13;:11;:13::i;:::-;45664:15:::1;-1:-1:-1::0;;;;;45664:23:0::1;;:25;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;;;;45646:55:0::1;;45724:4;45744:15;-1:-1:-1::0;;;;;45744:20:0::1;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;45646:131;::::0;-1:-1:-1;;;;;;45646:131:0::1;::::0;;;;;;-1:-1:-1;;;;;7498:15:1;;;45646:131:0::1;::::0;::::1;7480:34:1::0;7550:15;;7530:18;;;7523:43;7415:18;;45646:131:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;45630:13;:147:::0;;-1:-1:-1;;;;;;45630:147:0::1;-1:-1:-1::0;;;;;45630:147:0;;;::::1;::::0;;;::::1;::::0;;45790:62:::1;45807:4;45822:15;-1:-1:-1::0;;45790:8:0::1;:62::i;:::-;45891:13;::::0;45865:46:::1;::::0;-1:-1:-1;;;;;45891:13:0::1;::::0;45865:25:::1;:46::i;:::-;45924:15;-1:-1:-1::0;;;;;45924:31:0::1;;45963:9;45996:4;46016:24;46034:4;-1:-1:-1::0;;;;;5845:18:0;5818:7;5845:18;;;;;;;;;;;;5728:143;46016:24:::1;46055:1;46071::::0;46087:7:::1;18745:6:::0;;-1:-1:-1;;;;;18745:6:0;;18672:87;46087:7:::1;45924:211;::::0;::::1;::::0;;;-1:-1:-1;;;;;;45924:211:0;;;-1:-1:-1;;;;;7936:15:1;;;45924:211:0::1;::::0;::::1;7918:34:1::0;7968:18;;;7961:34;;;;8011:18;;;8004:34;;;;8054:18;;;8047:34;8118:15;;;8097:19;;;8090:44;46109:15:0::1;8150:19:1::0;;;8143:35;7852:19;;45924:211:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;46177:13:0::1;::::0;46148:49:::1;::::0;-1:-1:-1;;;;;;46177:13:0::1;::::0;46148:28:::1;:49::i;46656:137::-:0;18558:13;:11;:13::i;:::-;46709:12:::1;:19:::0;;-1:-1:-1;;46709:19:0::1;::::0;::::1;::::0;;46743:10:::1;::::0;46709:19;46743:15;46739:46:::1;;46773:12;46760:10;:25:::0;46656:137::o;4656:104::-;4712:13;4745:7;4738:14;;;;;:::i;47419:306::-;18558:13;:11;:13::i;:::-;47565::::1;::::0;-1:-1:-1;;;;;47565:13:0;;::::1;47557:21:::0;;::::1;::::0;47535:128:::1;;;::::0;-1:-1:-1;;;47535:128:0;;8702:2:1;47535:128:0::1;::::0;::::1;8684:21:1::0;8741:2;8721:18;;;8714:30;8780:34;8760:18;;;8753:62;8851:27;8831:18;;;8824:55;8896:19;;47535:128:0::1;8500:421:1::0;47535:128:0::1;47676:41;47705:4;47711:5;47676:28;:41::i;:::-;47419:306:::0;;:::o;9130:498::-;9248:4;3523:10;9248:4;9331:25;3523:10;9348:7;9331:9;:25::i;:::-;9304:52;;9409:15;9389:16;:35;;9367:122;;;;-1:-1:-1;;;9367:122:0;;9128:2:1;9367:122:0;;;9110:21:1;9167:2;9147:18;;;9140:30;9206:34;9186:18;;;9179:62;-1:-1:-1;;;9257:18:1;;;9250:35;9302:19;;9367:122:0;8926:401:1;9367:122:0;9525:60;9534:5;9541:7;9569:15;9550:16;:34;9525:8;:60::i;:::-;-1:-1:-1;9616:4:0;;9130:498;-1:-1:-1;;;;9130:498:0:o;48860:176::-;48964:4;48988:40;3523:10;49017:2;49021:6;48988:14;:40::i;:::-;48981:47;48860:176;-1:-1:-1;;;48860:176:0:o;47280:131::-;18558:13;:11;:13::i;:::-;-1:-1:-1;;;;;47365:27:0;;;::::1;;::::0;;;:18:::1;:27;::::0;;;;:38;;-1:-1:-1;;47365:38:0::1;::::0;::::1;;::::0;;;::::1;::::0;;47280:131::o;6358:176::-;-1:-1:-1;;;;;6499:18:0;;;6472:7;6499:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;6358:176::o;19578:238::-;18558:13;:11;:13::i;:::-;-1:-1:-1;;;;;19681:22:0;::::1;19659:110;;;::::0;-1:-1:-1;;;19659:110:0;;9534:2:1;19659:110:0::1;::::0;::::1;9516:21:1::0;9573:2;9553:18;;;9546:30;9612:34;9592:18;;;9585:62;-1:-1:-1;;;9663:18:1;;;9656:36;9709:19;;19659:110:0::1;9332:402:1::0;19659:110:0::1;19780:28;19799:8;19780:18;:28::i;:::-;19578:238:::0;:::o;54567:1010::-;54667:4;18558:13;:11;:13::i;:::-;54747:19:::1;;54724:20;;:42;;;;:::i;:::-;54706:15;:60;54684:142;;;::::0;-1:-1:-1;;;54684:142:0;;9941:2:1;54684:142:0::1;::::0;::::1;9923:21:1::0;;;9960:18;;;9953:30;10019:34;9999:18;;;9992:62;10071:18;;54684:142:0::1;9739:356:1::0;54684:142:0::1;54856:4;54845:7;:15;;54837:70;;;::::0;-1:-1:-1;;;54837:70:0;;10302:2:1;54837:70:0::1;::::0;::::1;10284:21:1::0;10341:2;10321:18;;;10314:30;10380:34;10360:18;;;10353:62;-1:-1:-1;;;10431:18:1;;;10424:40;10481:19;;54837:70:0::1;10100:406:1::0;54837:70:0::1;54941:15;54918:20;:38:::0;55057:13:::1;::::0;55042:29:::1;::::0;-1:-1:-1;;;55042:29:0;;-1:-1:-1;;;;;55057:13:0;;::::1;55042:29;::::0;::::1;2682:51:1::0;55011:28:0::1;::::0;55042:4:::1;::::0;:14:::1;::::0;2655:18:1;;55042:29:0::1;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;55011:60:::0;-1:-1:-1;55121:20:0::1;55144:44;55182:5;55144:33;55011:60:::0;55169:7;55144:24:::1;:33::i;:::-;:37:::0;::::1;:44::i;:::-;55121:67:::0;-1:-1:-1;55293:16:0;;55289:110:::1;;55342:13;::::0;55326:61:::1;::::0;-1:-1:-1;;;;;55342:13:0::1;55365:6;55374:12:::0;55326:15:::1;:61::i;:::-;55511:13;::::0;55536:11:::1;::::0;;-1:-1:-1;;;;;;55536:11:0;;;;-1:-1:-1;;;;;55511:13:0;;::::1;::::0;;;55536:9:::1;::::0;:11:::1;::::0;;::::1;::::0;55474:19:::1;::::0;55536:11;;;;;;;55474:19;55511:13;55536:11;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;55565:4;55558:11;;;;;18582:1;54567:1010:::0;;;:::o;18837:132::-;18745:6;;-1:-1:-1;;;;;18745:6:0;3523:10;18901:23;18893:68;;;;-1:-1:-1;;;18893:68:0;;10902:2:1;18893:68:0;;;10884:21:1;;;10921:18;;;10914:30;10980:34;10960:18;;;10953:62;11032:18;;18893:68:0;10700:356:1;13256:380:0;-1:-1:-1;;;;;13392:19:0;;13384:68;;;;-1:-1:-1;;;13384:68:0;;11263:2:1;13384:68:0;;;11245:21:1;11302:2;11282:18;;;11275:30;11341:34;11321:18;;;11314:62;-1:-1:-1;;;11392:18:1;;;11385:34;11436:19;;13384:68:0;11061:400:1;13384:68:0;-1:-1:-1;;;;;13471:21:0;;13463:68;;;;-1:-1:-1;;;13463:68:0;;11668:2:1;13463:68:0;;;11650:21:1;11707:2;11687:18;;;11680:30;11746:34;11726:18;;;11719:62;-1:-1:-1;;;11797:18:1;;;11790:32;11839:19;;13463:68:0;11466:398:1;13463:68:0;-1:-1:-1;;;;;13544:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;13596:32;;2890:25:1;;;13596:32:0;;2863:18:1;13596:32:0;;;;;;;13256:380;;;:::o;13927:502::-;14062:24;14089:25;14099:5;14106:7;14089:9;:25::i;:::-;14062:52;;-1:-1:-1;;14129:16:0;:37;14125:297;;14229:6;14209:16;:26;;14183:117;;;;-1:-1:-1;;;14183:117:0;;12071:2:1;14183:117:0;;;12053:21:1;12110:2;12090:18;;;12083:30;12149:31;12129:18;;;12122:59;12198:18;;14183:117:0;11869:353:1;14183:117:0;14344:51;14353:5;14360:7;14388:6;14369:16;:25;14344:8;:51::i;49357:3833::-;49474:4;-1:-1:-1;;;;;49499:18:0;;49491:68;;;;-1:-1:-1;;;49491:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;49578:16:0;;49570:64;;;;-1:-1:-1;;;49570:64:0;;;;;;;:::i;:::-;49662:1;49653:6;:10;49645:64;;;;-1:-1:-1;;;49645:64:0;;13239:2:1;49645:64:0;;;13221:21:1;13278:2;13258:18;;;13251:30;13317:34;13297:18;;;13290:62;-1:-1:-1;;;13368:18:1;;;13361:39;13417:19;;49645:64:0;13037:405:1;49645:64:0;49726:14;;;;;;;49722:1687;;;18745:6;;-1:-1:-1;;;;;49779:15:0;;;18745:6;;49779:15;;;;:49;;-1:-1:-1;18745:6:0;;-1:-1:-1;;;;;49815:13:0;;;18745:6;;49815:13;;49779:49;:86;;;;-1:-1:-1;;;;;;49849:16:0;;;;49779:86;:128;;;;-1:-1:-1;;;;;;49886:21:0;;49900:6;49886:21;;49779:128;:165;;;;-1:-1:-1;49929:15:0;;;;49928:16;49779:165;49757:1641;;;50006:12;;;;;;;50005:13;:92;;;;-1:-1:-1;;;;;;50045:24:0;;;;;;:18;:24;;;;;;;;50044:25;:52;;;;-1:-1:-1;;;;;;50074:22:0;;;;;;:18;:22;;;;;;;;50073:23;50044:52;49979:209;;;50140:28;;-1:-1:-1;;;50140:28:0;;13649:2:1;50140:28:0;;;13631:21:1;13688:2;13668:18;;;13661:30;-1:-1:-1;;;13707:18:1;;;13700:48;13765:18;;50140:28:0;13447:342:1;49979:209:0;-1:-1:-1;;;;;50262:31:0;;;;;;:25;:31;;;;;;;;:92;;;;-1:-1:-1;;;;;;50319:35:0;;;;;;:31;:35;;;;;;;;50318:36;50262:92;50236:1147;;;50441:20;;50431:6;:30;;50397:169;;;;-1:-1:-1;;;50397:169:0;;13996:2:1;50397:169:0;;;13978:21:1;14035:2;14015:18;;;14008:30;14074:34;14054:18;;;14047:62;-1:-1:-1;;;14125:18:1;;;14118:51;14186:19;;50397:169:0;13794:417:1;50397:169:0;50649:9;;-1:-1:-1;;;;;5845:18:0;;5818:7;5845:18;;;;;;;;;;;50623:22;;:6;:22;:::i;:::-;:35;;50589:140;;;;-1:-1:-1;;;50589:140:0;;14418:2:1;50589:140:0;;;14400:21:1;14457:2;14437:18;;;14430:30;-1:-1:-1;;;14476:18:1;;;14469:49;14535:18;;50589:140:0;14216:343:1;50589:140:0;50236:1147;;;-1:-1:-1;;;;;50827:29:0;;;;;;:25;:29;;;;;;;;:92;;;;-1:-1:-1;;;;;;50882:37:0;;;;;;:31;:37;;;;;;;;50881:38;50827:92;50801:582;;;51006:20;;50996:6;:30;;50962:170;;;;-1:-1:-1;;;50962:170:0;;14766:2:1;50962:170:0;;;14748:21:1;14805:2;14785:18;;;14778:30;14844:34;14824:18;;;14817:62;-1:-1:-1;;;14895:18:1;;;14888:52;14957:19;;50962:170:0;14564:418:1;50801:582:0;-1:-1:-1;;;;;51163:35:0;;;;;;:31;:35;;;;;;;;51158:225;;51283:9;;-1:-1:-1;;;;;5845:18:0;;5818:7;5845:18;;;;;;;;;;;51257:22;;:6;:22;:::i;:::-;:35;;51223:140;;;;-1:-1:-1;;;51223:140:0;;14418:2:1;51223:140:0;;;14400:21:1;14457:2;14437:18;;;14430:30;-1:-1:-1;;;14476:18:1;;;14469:49;14535:18;;51223:140:0;14216:343:1;51223:140:0;51470:4;51421:28;5845:18;;;;;;;;;;;51516:24;;;;;;;51569:52;;-1:-1:-1;51606:15:0;;;;51605:16;51569:52;:101;;;;-1:-1:-1;;;;;;51639:31:0;;;;;;:25;:31;;;;;;;;51638:32;51569:101;:143;;;;-1:-1:-1;;;;;;51688:24:0;;;;;;:18;:24;;;;;;;;51687:25;51569:143;:180;;;;-1:-1:-1;51729:20:0;;;;;;;51569:180;51551:358;;;51776:15;:22;;-1:-1:-1;;51776:22:0;51794:4;51776:22;;;51813:46;51838:20;51813:24;:46::i;:::-;51874:15;:23;;-1:-1:-1;;51874:23:0;;;51551:358;51940:15;;;;51939:16;:62;;;;-1:-1:-1;;;;;;51972:29:0;;;;;;:25;:29;;;;;;;;51939:62;:92;;;;-1:-1:-1;52018:13:0;;;;51939:92;:160;;;;;52084:15;;52067:14;;:32;;;;:::i;:::-;52048:15;:51;;51939:160;:201;;;;-1:-1:-1;;;;;;52116:24:0;;;;;;:18;:24;;;;;;;;51939:201;51921:287;;;52167:29;:27;:29::i;:::-;;51921:287;-1:-1:-1;;;;;52401:24:0;;52281:12;52401:24;;;:18;:24;;;;;;52296:4;;52401:24;;;:50;;-1:-1:-1;;;;;;52429:22:0;;;;;;:18;:22;;;;;;;;52401:50;52397:98;;;-1:-1:-1;52478:5:0;52397:98;52511:7;52507:616;;;-1:-1:-1;;;;;52593:31:0;;52535:12;52593:31;;;:25;:31;;;;;;52535:12;;52593:31;;52589:108;;;52678:3;52662:12;;52653:6;:21;;;;:::i;:::-;52652:29;;;;:::i;:::-;52645:36;;52589:108;-1:-1:-1;;;;;52715:29:0;;;;;;:25;:29;;;;;;;;52711:107;;;52799:3;52782:13;;52773:6;:22;;;;:::i;:::-;52772:30;;;;:::i;:::-;52765:37;;52711:107;52839:4;52832:11;;52860:19;52882:15;52892:4;-1:-1:-1;;;;;5845:18:0;5818:7;5845:18;;;;;;;;;;;;5728:143;52882:15;52860:37;;52931:6;52916:11;:21;52912:98;;52977:16;52986:7;52977:6;:16;:::i;:::-;52967:27;;:6;:27;:::i;:::-;52958:36;;52912:98;53033:13;53042:4;53033:6;:13;:::i;:::-;53024:22;-1:-1:-1;53065:8:0;;53061:50;;53075:36;53085:4;53099;53106;53075:9;:36::i;:::-;52520:603;;;52507:616;53133:27;53143:4;53149:2;53153:6;53133:9;:27::i;:::-;-1:-1:-1;53178:4:0;;49357:3833;-1:-1:-1;;;;;;49357:3833:0:o;19976:191::-;20069:6;;;-1:-1:-1;;;;;20086:17:0;;;-1:-1:-1;;;;;;20086:17:0;;;;;;;20119:40;;20069:6;;;20086:17;20069:6;;20119:40;;20050:16;;20119:40;20039:128;19976:191;:::o;47733:130::-;-1:-1:-1;;;;;47816:31:0;;;;;;;;:25;:31;;;;;:39;;-1:-1:-1;;47816:39:0;;;;;;;;;;47733:130::o;38106:98::-;38164:7;38191:5;38195:1;38191;:5;:::i;38212:98::-;38270:7;38297:5;38301:1;38297;:5;:::i;10098:877::-;-1:-1:-1;;;;;10229:18:0;;10221:68;;;;-1:-1:-1;;;10221:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;10308:16:0;;10300:64;;;;-1:-1:-1;;;10300:64:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;10450:15:0;;10428:19;10450:15;;;;;;;;;;;10498:21;;;;10476:109;;;;-1:-1:-1;;;10476:109:0;;15717:2:1;10476:109:0;;;15699:21:1;15756:2;15736:18;;;15729:30;15795:34;15775:18;;;15768:62;-1:-1:-1;;;15846:18:1;;;15839:36;15892:19;;10476:109:0;15515:402:1;10476:109:0;-1:-1:-1;;;;;10621:15:0;;;:9;:15;;;;;;;;;;;10639:20;;;10621:38;;10839:13;;;;;;;;;;:23;;;;;;10891:26;;2890:25:1;;;10839:13:0;;10891:26;;2863:18:1;10891:26:0;;;;;;;10930:37;15029:125;53198:593;53356:16;;;53370:1;53356:16;;;;;;;;53332:21;;53356:16;;;;;;;;;;-1:-1:-1;53356:16:0;53332:40;;53401:4;53383;53388:1;53383:7;;;;;;;;:::i;:::-;;;;;;:23;-1:-1:-1;;;;;53383:23:0;;;-1:-1:-1;;;;;53383:23:0;;;;;53427:15;-1:-1:-1;;;;;53427:20:0;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;53417:4;53422:1;53417:7;;;;;;;;:::i;:::-;;;;;;:32;-1:-1:-1;;;;;53417:32:0;;;-1:-1:-1;;;;;53417:32:0;;;;;53462:62;53479:4;53494:15;53512:11;53462:8;:62::i;:::-;53733:9;;53563:220;;-1:-1:-1;;;53563:220:0;;-1:-1:-1;;;;;53563:15:0;:66;;;;;:220;;53644:11;;53670:1;;53714:4;;53733:9;;;;;53757:15;;53563:220;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;53261:530;53198:593;:::o;53799:760::-;53890:15;53873:14;:32;54006:13;;53991:29;;-1:-1:-1;;;53991:29:0;;-1:-1:-1;;;;;54006:13:0;;;53991:29;;;2682:51:1;53856:4:0;;;;53991;;:14;;2655:18:1;;53991:29:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;53960:60;;54070:20;54093:77;54154:5;54093:42;54118:16;;54093:20;:24;;:42;;;;:::i;:77::-;54070:100;-1:-1:-1;54275:16:0;;54271:110;;54324:13;;54308:61;;-1:-1:-1;;;;;54324:13:0;54347:6;54356:12;54308:15;:61::i;:::-;54493:13;;54518:11;;;-1:-1:-1;;;;;;54518:11:0;;;;-1:-1:-1;;;;;54493:13:0;;;;;;54518:9;;:11;;;;;54456:19;;54518:11;;;;;;;54456:19;54493:13;54518:11;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;54547:4;54540:11;;;;;53799:760;:::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:160::-;632:20;;688:13;;681:21;671:32;;661:60;;717:1;714;707:12;732:689;824:6;832;840;893:2;881:9;872:7;868:23;864:32;861:52;;;909:1;906;899:12;861:52;949:9;936:23;978:18;1019:2;1011:6;1008:14;1005:34;;;1035:1;1032;1025:12;1005:34;1073:6;1062:9;1058:22;1048:32;;1118:7;1111:4;1107:2;1103:13;1099:27;1089:55;;1140:1;1137;1130:12;1089:55;1180:2;1167:16;1206:2;1198:6;1195:14;1192:34;;;1222:1;1219;1212:12;1192:34;1277:7;1270:4;1260:6;1257:1;1253:14;1249:2;1245:23;1241:34;1238:47;1235:67;;;1298:1;1295;1288:12;1235:67;1329:4;1321:13;;;;-1:-1:-1;1353:6:1;-1:-1:-1;1378:37:1;;1394:20;;;-1:-1:-1;1378:37:1;:::i;:::-;1368:47;;732:689;;;;;:::o;1426:131::-;-1:-1:-1;;;;;1501:31:1;;1491:42;;1481:70;;1547:1;1544;1537:12;1562:315;1630:6;1638;1691:2;1679:9;1670:7;1666:23;1662:32;1659:52;;;1707:1;1704;1697:12;1659:52;1746:9;1733:23;1765:31;1790:5;1765:31;:::i;:::-;1815:5;1867:2;1852:18;;;;1839:32;;-1:-1:-1;;;1562:315:1:o;2074:247::-;2133:6;2186:2;2174:9;2165:7;2161:23;2157:32;2154:52;;;2202:1;2199;2192:12;2154:52;2241:9;2228:23;2260:31;2285:5;2260:31;:::i;2326:180::-;2385:6;2438:2;2426:9;2417:7;2413:23;2409:32;2406:52;;;2454:1;2451;2444:12;2406:52;-1:-1:-1;2477:23:1;;2326:180;-1:-1:-1;2326:180:1:o;2926:456::-;3003:6;3011;3019;3072:2;3060:9;3051:7;3047:23;3043:32;3040:52;;;3088:1;3085;3078:12;3040:52;3127:9;3114:23;3146:31;3171:5;3146:31;:::i;:::-;3196:5;-1:-1:-1;3253:2:1;3238:18;;3225:32;3266:33;3225:32;3266:33;:::i;:::-;2926:456;;3318:7;;-1:-1:-1;;;3372:2:1;3357:18;;;;3344:32;;2926:456::o;3784:180::-;3840:6;3893:2;3881:9;3872:7;3868:23;3864:32;3861:52;;;3909:1;3906;3899:12;3861:52;3932:26;3948:9;3932:26;:::i;4222:316::-;4296:6;4304;4312;4365:2;4353:9;4344:7;4340:23;4336:32;4333:52;;;4381:1;4378;4371:12;4333:52;4417:9;4404:23;4394:33;;4474:2;4463:9;4459:18;4446:32;4436:42;;4497:35;4528:2;4517:9;4513:18;4497:35;:::i;4543:315::-;4608:6;4616;4669:2;4657:9;4648:7;4644:23;4640:32;4637:52;;;4685:1;4682;4675:12;4637:52;4724:9;4711:23;4743:31;4768:5;4743:31;:::i;:::-;4793:5;-1:-1:-1;4817:35:1;4848:2;4833:18;;4817:35;:::i;:::-;4807:45;;4543:315;;;;;:::o;4863:388::-;4931:6;4939;4992:2;4980:9;4971:7;4967:23;4963:32;4960:52;;;5008:1;5005;4998:12;4960:52;5047:9;5034:23;5066:31;5091:5;5066:31;:::i;:::-;5116:5;-1:-1:-1;5173:2:1;5158:18;;5145:32;5186:33;5145:32;5186:33;:::i;:::-;5238:7;5228:17;;;4863:388;;;;;:::o;5256:380::-;5335:1;5331:12;;;;5378;;;5399:61;;5453:4;5445:6;5441:17;5431:27;;5399:61;5506:2;5498:6;5495:14;5475:18;5472:38;5469:161;;5552:10;5547:3;5543:20;5540:1;5533:31;5587:4;5584:1;5577:15;5615:4;5612:1;5605:15;5469:161;;5256:380;;;:::o;5641:127::-;5702:10;5697:3;5693:20;5690:1;5683:31;5733:4;5730:1;5723:15;5757:4;5754:1;5747:15;5773:127;5834:10;5829:3;5825:20;5822:1;5815:31;5865:4;5862:1;5855:15;5889:4;5886:1;5879:15;5905:135;5944:3;5965:17;;;5962:43;;5985:18;;:::i;:::-;-1:-1:-1;6032:1:1;6021:13;;5905:135::o;6045:125::-;6110:9;;;6131:10;;;6128:36;;;6144:18;;:::i;7012:251::-;7082:6;7135:2;7123:9;7114:7;7110:23;7106:32;7103:52;;;7151:1;7148;7141:12;7103:52;7183:9;7177:16;7202:31;7227:5;7202:31;:::i;8189:306::-;8277:6;8285;8293;8346:2;8334:9;8325:7;8321:23;8317:32;8314:52;;;8362:1;8359;8352:12;8314:52;8391:9;8385:16;8375:26;;8441:2;8430:9;8426:18;8420:25;8410:35;;8485:2;8474:9;8470:18;8464:25;8454:35;;8189:306;;;;;:::o;10511:184::-;10581:6;10634:2;10622:9;10613:7;10609:23;10605:32;10602:52;;;10650:1;10647;10640:12;10602:52;-1:-1:-1;10673:16:1;;10511:184;-1:-1:-1;10511:184:1:o;12227:401::-;12429:2;12411:21;;;12468:2;12448:18;;;12441:30;12507:34;12502:2;12487:18;;12480:62;-1:-1:-1;;;12573:2:1;12558:18;;12551:35;12618:3;12603:19;;12227:401::o;12633:399::-;12835:2;12817:21;;;12874:2;12854:18;;;12847:30;12913:34;12908:2;12893:18;;12886:62;-1:-1:-1;;;12979:2:1;12964:18;;12957:33;13022:3;13007:19;;12633:399::o;14987:168::-;15060:9;;;15091;;15108:15;;;15102:22;;15088:37;15078:71;;15129:18;;:::i;15160:217::-;15200:1;15226;15216:132;;15270:10;15265:3;15261:20;15258:1;15251:31;15305:4;15302:1;15295:15;15333:4;15330:1;15323:15;15216:132;-1:-1:-1;15362:9:1;;15160:217::o;15382:128::-;15449:9;;;15470:11;;;15467:37;;;15484:18;;:::i;16054:980::-;16316:4;16364:3;16353:9;16349:19;16395:6;16384:9;16377:25;16421:2;16459:6;16454:2;16443:9;16439:18;16432:34;16502:3;16497:2;16486:9;16482:18;16475:31;16526:6;16561;16555:13;16592:6;16584;16577:22;16630:3;16619:9;16615:19;16608:26;;16669:2;16661:6;16657:15;16643:29;;16690:1;16700:195;16714:6;16711:1;16708:13;16700:195;;;16779:13;;-1:-1:-1;;;;;16775:39:1;16763:52;;16870:15;;;;16835:12;;;;16811:1;16729:9;16700:195;;;-1:-1:-1;;;;;;;16951:32:1;;;;16946:2;16931:18;;16924:60;-1:-1:-1;;;17015:3:1;17000:19;16993:35;16912:3;16054:980;-1:-1:-1;;;16054:980:1:o
Swarm Source
ipfs://fe7b7c976064783d21b0952a3e127b7d09d4f23ccf12d04295c68e6fd66f647a
Loading...
Loading
Loading...
Loading
Multichain Portfolio | 30 Chains
Chain | Token | Portfolio % | Price | Amount | Value |
---|
Loading...
Loading
[ Download: CSV Export ]
[ Download: CSV Export ]
A contract address hosts a smart contract, which is a set of code stored on the blockchain that runs when predetermined conditions are met. Learn more about addresses in our Knowledge Base.