ERC-20
Overview
Max Total Supply
1,000,000,000 FAI
Holders
622
Market
Onchain Market Cap
$0.00
Circulating Supply Market Cap
-
Other Info
Token Contract (WITH 18 Decimals)
Balance
0.000000000020621198 FAIValue
$0.00Loading...
Loading
Loading...
Loading
Loading...
Loading
# | Exchange | Pair | Price | 24H Volume | % Volume |
---|
Contract Source Code Verified (Exact Match)
Contract Name:
FORTIFYToken
Compiler Version
v0.8.21+commit.d9974bed
Contract Source Code (Solidity)
/** *Submitted for verification at Etherscan.io on 2025-01-16 */ /** *Submitted for verification at Etherscan.io on 2024-03-13 */ /****************************************************************** _|_|_|_| _|_| _|_|_| _|_|_|_|_| _|_|_| _|_|_|_| _| _| _|_| _|_|_| _| _| _| _| _| _| _| _| _| _| _| _| _| _|_|_| _| _| _|_|_| _| _| _|_|_| _| _|_|_|_| _| _| _| _| _| _| _| _| _| _| _| _| _| _| _|_| _| _| _| _|_|_| _| _| _| _| _|_|_| Portal: t.me/FortifyAILive Website: FortifyAI.live Linktree: linktr.ee/FortifyAILive Docs: fortifyai.gitbook.io/whitepaper ******************************************************************/ // SPDX-License-Identifier: MIT // File: @uniswap/v2-periphery/contracts/interfaces/IUniswapV2Router01.sol pragma solidity >=0.6.2; interface IUniswapV2Router01 { function factory() external pure returns (address); function WETH() external pure returns (address); function addLiquidity( address tokenA, address tokenB, uint amountADesired, uint amountBDesired, uint amountAMin, uint amountBMin, address to, uint deadline ) external returns (uint amountA, uint amountB, uint liquidity); function addLiquidityETH( address token, uint amountTokenDesired, uint amountTokenMin, uint amountETHMin, address to, uint deadline ) external payable returns (uint amountToken, uint amountETH, uint liquidity); function removeLiquidity( address tokenA, address tokenB, uint liquidity, uint amountAMin, uint amountBMin, address to, uint deadline ) external returns (uint amountA, uint amountB); function removeLiquidityETH( address token, uint liquidity, uint amountTokenMin, uint amountETHMin, address to, uint deadline ) external returns (uint amountToken, uint amountETH); function removeLiquidityWithPermit( address tokenA, address tokenB, uint liquidity, uint amountAMin, uint amountBMin, address to, uint deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ) external returns (uint amountA, uint amountB); function removeLiquidityETHWithPermit( address token, uint liquidity, uint amountTokenMin, uint amountETHMin, address to, uint deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ) external returns (uint amountToken, uint amountETH); function swapExactTokensForTokens( uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline ) external returns (uint[] memory amounts); function swapTokensForExactTokens( uint amountOut, uint amountInMax, address[] calldata path, address to, uint deadline ) external returns (uint[] memory amounts); function swapExactETHForTokens(uint amountOutMin, address[] calldata path, address to, uint deadline) external payable returns (uint[] memory amounts); function swapTokensForExactETH(uint amountOut, uint amountInMax, address[] calldata path, address to, uint deadline) external returns (uint[] memory amounts); function swapExactTokensForETH(uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline) external returns (uint[] memory amounts); function swapETHForExactTokens(uint amountOut, address[] calldata path, address to, uint deadline) external payable returns (uint[] memory amounts); function quote(uint amountA, uint reserveA, uint reserveB) external pure returns (uint amountB); function getAmountOut(uint amountIn, uint reserveIn, uint reserveOut) external pure returns (uint amountOut); function getAmountIn(uint amountOut, uint reserveIn, uint reserveOut) external pure returns (uint amountIn); function getAmountsOut(uint amountIn, address[] calldata path) external view returns (uint[] memory amounts); function getAmountsIn(uint amountOut, address[] calldata path) external view returns (uint[] memory amounts); } // File: @uniswap/v2-periphery/contracts/interfaces/IUniswapV2Router02.sol pragma solidity >=0.6.2; interface IUniswapV2Router02 is IUniswapV2Router01 { function removeLiquidityETHSupportingFeeOnTransferTokens( address token, uint liquidity, uint amountTokenMin, uint amountETHMin, address to, uint deadline ) external returns (uint amountETH); function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens( address token, uint liquidity, uint amountTokenMin, uint amountETHMin, address to, uint deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ) external returns (uint amountETH); function swapExactTokensForTokensSupportingFeeOnTransferTokens( uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline ) external; function swapExactETHForTokensSupportingFeeOnTransferTokens( uint amountOutMin, address[] calldata path, address to, uint deadline ) external payable; function swapExactTokensForETHSupportingFeeOnTransferTokens( uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline ) external; } // File: @uniswap/v2-core/contracts/interfaces/IUniswapV2Factory.sol pragma solidity >=0.5.0; interface IUniswapV2Factory { event PairCreated(address indexed token0, address indexed token1, address pair, uint); function feeTo() external view returns (address); function feeToSetter() external view returns (address); function getPair(address tokenA, address tokenB) external view returns (address pair); function allPairs(uint) external view returns (address pair); function allPairsLength() external view returns (uint); function createPair(address tokenA, address tokenB) external returns (address pair); function setFeeTo(address) external; function setFeeToSetter(address) external; } // File: @openzeppelin/contracts/utils/Address.sol // OpenZeppelin Contracts (last updated v5.0.0) (utils/Address.sol) pragma solidity ^0.8.20; /** * @dev Collection of functions related to the address type */ library Address { /** * @dev The ETH balance of the account is not enough to perform the operation. */ error AddressInsufficientBalance(address account); /** * @dev There's no code at `target` (it is not a contract). */ error AddressEmptyCode(address target); /** * @dev A call to an address target failed. The target may have reverted. */ error FailedInnerCall(); /** * @dev Replacement for Solidity's `transfer`: sends `amount` wei to * `recipient`, forwarding all available gas and reverting on errors. * * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost * of certain opcodes, possibly making contracts go over the 2300 gas limit * imposed by `transfer`, making them unable to receive funds via * `transfer`. {sendValue} removes this limitation. * * https://consensys.net/diligence/blog/2019/09/stop-using-soliditys-transfer-now/[Learn more]. * * IMPORTANT: because control is transferred to `recipient`, care must be * taken to not create reentrancy vulnerabilities. Consider using * {ReentrancyGuard} or the * https://solidity.readthedocs.io/en/v0.8.20/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern]. */ function sendValue(address payable recipient, uint256 amount) internal { if (address(this).balance < amount) { revert AddressInsufficientBalance(address(this)); } (bool success, ) = recipient.call{value: amount}(""); if (!success) { revert FailedInnerCall(); } } /** * @dev Performs a Solidity function call using a low level `call`. A * plain `call` is an unsafe replacement for a function call: use this * function instead. * * If `target` reverts with a revert reason or custom error, it is bubbled * up by this function (like regular Solidity function calls). However, if * the call reverted with no returned reason, this function reverts with a * {FailedInnerCall} error. * * Returns the raw returned data. To convert to the expected return value, * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`]. * * Requirements: * * - `target` must be a contract. * - calling `target` with `data` must not revert. */ function functionCall(address target, bytes memory data) internal returns (bytes memory) { return functionCallWithValue(target, data, 0); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but also transferring `value` wei to `target`. * * Requirements: * * - the calling contract must have an ETH balance of at least `value`. * - the called Solidity function must be `payable`. */ function functionCallWithValue(address target, bytes memory data, uint256 value) internal returns (bytes memory) { if (address(this).balance < value) { revert AddressInsufficientBalance(address(this)); } (bool success, bytes memory returndata) = target.call{value: value}(data); return verifyCallResultFromTarget(target, success, returndata); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but performing a static call. */ function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) { (bool success, bytes memory returndata) = target.staticcall(data); return verifyCallResultFromTarget(target, success, returndata); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but performing a delegate call. */ function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) { (bool success, bytes memory returndata) = target.delegatecall(data); return verifyCallResultFromTarget(target, success, returndata); } /** * @dev Tool to verify that a low level call to smart-contract was successful, and reverts if the target * was not a contract or bubbling up the revert reason (falling back to {FailedInnerCall}) in case of an * unsuccessful call. */ function verifyCallResultFromTarget( address target, bool success, bytes memory returndata ) internal view returns (bytes memory) { if (!success) { _revert(returndata); } else { // only check if target is a contract if the call was successful and the return data is empty // otherwise we already know that it was a contract if (returndata.length == 0 && target.code.length == 0) { revert AddressEmptyCode(target); } return returndata; } } /** * @dev Tool to verify that a low level call was successful, and reverts if it wasn't, either by bubbling the * revert reason or with a default {FailedInnerCall} error. */ function verifyCallResult(bool success, bytes memory returndata) internal pure returns (bytes memory) { if (!success) { _revert(returndata); } else { return returndata; } } /** * @dev Reverts with returndata if present. Otherwise reverts with {FailedInnerCall}. */ function _revert(bytes memory returndata) private pure { // Look for revert reason and bubble it up if present if (returndata.length > 0) { // The easiest way to bubble the revert reason is using memory via assembly /// @solidity memory-safe-assembly assembly { let returndata_size := mload(returndata) revert(add(32, returndata), returndata_size) } } else { revert FailedInnerCall(); } } } // File: @openzeppelin/contracts/interfaces/draft-IERC6093.sol // OpenZeppelin Contracts (last updated v5.0.0) (interfaces/draft-IERC6093.sol) pragma solidity ^0.8.20; /** * @dev Standard ERC20 Errors * Interface of the https://eips.ethereum.org/EIPS/eip-6093[ERC-6093] custom errors for ERC20 tokens. */ interface IERC20Errors { /** * @dev Indicates an error related to the current `balance` of a `sender`. Used in transfers. * @param sender Address whose tokens are being transferred. * @param balance Current balance for the interacting account. * @param needed Minimum amount required to perform a transfer. */ error ERC20InsufficientBalance(address sender, uint256 balance, uint256 needed); /** * @dev Indicates a failure with the token `sender`. Used in transfers. * @param sender Address whose tokens are being transferred. */ error ERC20InvalidSender(address sender); /** * @dev Indicates a failure with the token `receiver`. Used in transfers. * @param receiver Address to which tokens are being transferred. */ error ERC20InvalidReceiver(address receiver); /** * @dev Indicates a failure with the `spender`’s `allowance`. Used in transfers. * @param spender Address that may be allowed to operate on tokens without being their owner. * @param allowance Amount of tokens a `spender` is allowed to operate with. * @param needed Minimum amount required to perform a transfer. */ error ERC20InsufficientAllowance(address spender, uint256 allowance, uint256 needed); /** * @dev Indicates a failure with the `approver` of a token to be approved. Used in approvals. * @param approver Address initiating an approval operation. */ error ERC20InvalidApprover(address approver); /** * @dev Indicates a failure with the `spender` to be approved. Used in approvals. * @param spender Address that may be allowed to operate on tokens without being their owner. */ error ERC20InvalidSpender(address spender); } /** * @dev Standard ERC721 Errors * Interface of the https://eips.ethereum.org/EIPS/eip-6093[ERC-6093] custom errors for ERC721 tokens. */ interface IERC721Errors { /** * @dev Indicates that an address can't be an owner. For example, `address(0)` is a forbidden owner in EIP-20. * Used in balance queries. * @param owner Address of the current owner of a token. */ error ERC721InvalidOwner(address owner); /** * @dev Indicates a `tokenId` whose `owner` is the zero address. * @param tokenId Identifier number of a token. */ error ERC721NonexistentToken(uint256 tokenId); /** * @dev Indicates an error related to the ownership over a particular token. Used in transfers. * @param sender Address whose tokens are being transferred. * @param tokenId Identifier number of a token. * @param owner Address of the current owner of a token. */ error ERC721IncorrectOwner(address sender, uint256 tokenId, address owner); /** * @dev Indicates a failure with the token `sender`. Used in transfers. * @param sender Address whose tokens are being transferred. */ error ERC721InvalidSender(address sender); /** * @dev Indicates a failure with the token `receiver`. Used in transfers. * @param receiver Address to which tokens are being transferred. */ error ERC721InvalidReceiver(address receiver); /** * @dev Indicates a failure with the `operator`’s approval. Used in transfers. * @param operator Address that may be allowed to operate on tokens without being their owner. * @param tokenId Identifier number of a token. */ error ERC721InsufficientApproval(address operator, uint256 tokenId); /** * @dev Indicates a failure with the `approver` of a token to be approved. Used in approvals. * @param approver Address initiating an approval operation. */ error ERC721InvalidApprover(address approver); /** * @dev Indicates a failure with the `operator` to be approved. Used in approvals. * @param operator Address that may be allowed to operate on tokens without being their owner. */ error ERC721InvalidOperator(address operator); } /** * @dev Standard ERC1155 Errors * Interface of the https://eips.ethereum.org/EIPS/eip-6093[ERC-6093] custom errors for ERC1155 tokens. */ interface IERC1155Errors { /** * @dev Indicates an error related to the current `balance` of a `sender`. Used in transfers. * @param sender Address whose tokens are being transferred. * @param balance Current balance for the interacting account. * @param needed Minimum amount required to perform a transfer. * @param tokenId Identifier number of a token. */ error ERC1155InsufficientBalance(address sender, uint256 balance, uint256 needed, uint256 tokenId); /** * @dev Indicates a failure with the token `sender`. Used in transfers. * @param sender Address whose tokens are being transferred. */ error ERC1155InvalidSender(address sender); /** * @dev Indicates a failure with the token `receiver`. Used in transfers. * @param receiver Address to which tokens are being transferred. */ error ERC1155InvalidReceiver(address receiver); /** * @dev Indicates a failure with the `operator`’s approval. Used in transfers. * @param operator Address that may be allowed to operate on tokens without being their owner. * @param owner Address of the current owner of a token. */ error ERC1155MissingApprovalForAll(address operator, address owner); /** * @dev Indicates a failure with the `approver` of a token to be approved. Used in approvals. * @param approver Address initiating an approval operation. */ error ERC1155InvalidApprover(address approver); /** * @dev Indicates a failure with the `operator` to be approved. Used in approvals. * @param operator Address that may be allowed to operate on tokens without being their owner. */ error ERC1155InvalidOperator(address operator); /** * @dev Indicates an array length mismatch between ids and values in a safeBatchTransferFrom operation. * Used in batch transfers. * @param idsLength Length of the array of token identifiers * @param valuesLength Length of the array of token amounts */ error ERC1155InvalidArrayLength(uint256 idsLength, uint256 valuesLength); } // File: @openzeppelin/contracts/token/ERC20/IERC20.sol // OpenZeppelin Contracts (last updated v5.0.0) (token/ERC20/IERC20.sol) pragma solidity ^0.8.20; /** * @dev Interface of the ERC20 standard as defined in the EIP. */ interface IERC20 { /** * @dev Emitted when `value` tokens are moved from one account (`from`) to * another (`to`). * * Note that `value` may be zero. */ event Transfer(address indexed from, address indexed to, uint256 value); /** * @dev Emitted when the allowance of a `spender` for an `owner` is set by * a call to {approve}. `value` is the new allowance. */ event Approval(address indexed owner, address indexed spender, uint256 value); /** * @dev Returns the value of tokens in existence. */ function totalSupply() external view returns (uint256); /** * @dev Returns the value of tokens owned by `account`. */ function balanceOf(address account) external view returns (uint256); /** * @dev Moves a `value` amount of tokens from the caller's account to `to`. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transfer(address to, uint256 value) external returns (bool); /** * @dev Returns the remaining number of tokens that `spender` will be * allowed to spend on behalf of `owner` through {transferFrom}. This is * zero by default. * * This value changes when {approve} or {transferFrom} are called. */ function allowance(address owner, address spender) external view returns (uint256); /** * @dev Sets a `value` amount of tokens as the allowance of `spender` over the * caller's tokens. * * Returns a boolean value indicating whether the operation succeeded. * * IMPORTANT: Beware that changing an allowance with this method brings the risk * that someone may use both the old and the new allowance by unfortunate * transaction ordering. One possible solution to mitigate this race * condition is to first reduce the spender's allowance to 0 and set the * desired value afterwards: * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729 * * Emits an {Approval} event. */ function approve(address spender, uint256 value) external returns (bool); /** * @dev Moves a `value` amount of tokens from `from` to `to` using the * allowance mechanism. `value` is then deducted from the caller's * allowance. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transferFrom(address from, address to, uint256 value) external returns (bool); } // File: @openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol // OpenZeppelin Contracts (last updated v5.0.0) (token/ERC20/extensions/IERC20Metadata.sol) pragma solidity ^0.8.20; /** * @dev Interface for the optional metadata functions from the ERC20 standard. */ interface IERC20Metadata is IERC20 { /** * @dev Returns the name of the token. */ function name() external view returns (string memory); /** * @dev Returns the symbol of the token. */ function symbol() external view returns (string memory); /** * @dev Returns the decimals places of the token. */ function decimals() external view returns (uint8); } // File: @openzeppelin/contracts/utils/Context.sol // OpenZeppelin Contracts (last updated v5.0.1) (utils/Context.sol) pragma solidity ^0.8.20; /** * @dev Provides information about the current execution context, including the * sender of the transaction and its data. While these are generally available * via msg.sender and msg.data, they should not be accessed in such a direct * manner, since when dealing with meta-transactions the account sending and * paying for execution may not be the actual sender (as far as an application * is concerned). * * This contract is only required for intermediate, library-like contracts. */ abstract contract Context { function _msgSender() internal view virtual returns (address) { return msg.sender; } function _msgData() internal view virtual returns (bytes calldata) { return msg.data; } function _contextSuffixLength() internal view virtual returns (uint256) { return 0; } } // File: @openzeppelin/contracts/token/ERC20/ERC20.sol // OpenZeppelin Contracts (last updated v5.0.0) (token/ERC20/ERC20.sol) pragma solidity ^0.8.20; /** * @dev Implementation of the {IERC20} interface. * * This implementation is agnostic to the way tokens are created. This means * that a supply mechanism has to be added in a derived contract using {_mint}. * * TIP: For a detailed writeup see our guide * https://forum.openzeppelin.com/t/how-to-implement-erc20-supply-mechanisms/226[How * to implement supply mechanisms]. * * The default value of {decimals} is 18. To change this, you should override * this function so it returns a different value. * * We have followed general OpenZeppelin Contracts guidelines: functions revert * instead returning `false` on failure. This behavior is nonetheless * conventional and does not conflict with the expectations of ERC20 * applications. * * Additionally, an {Approval} event is emitted on calls to {transferFrom}. * This allows applications to reconstruct the allowance for all accounts just * by listening to said events. Other implementations of the EIP may not emit * these events, as it isn't required by the specification. */ abstract contract ERC20 is Context, IERC20, IERC20Metadata, IERC20Errors { mapping(address account => uint256) private _balances; mapping(address account => mapping(address spender => uint256)) private _allowances; uint256 private _totalSupply; string private _name; string private _symbol; /** * @dev Sets the values for {name} and {symbol}. * * All two of these values are immutable: they can only be set once during * construction. */ constructor(string memory name_, string memory symbol_) { _name = name_; _symbol = symbol_; } /** * @dev Returns the name of the token. */ function name() public view virtual returns (string memory) { return _name; } /** * @dev Returns the symbol of the token, usually a shorter version of the * name. */ function symbol() public view virtual returns (string memory) { return _symbol; } /** * @dev Returns the number of decimals used to get its user representation. * For example, if `decimals` equals `2`, a balance of `505` tokens should * be displayed to a user as `5.05` (`505 / 10 ** 2`). * * Tokens usually opt for a value of 18, imitating the relationship between * Ether and Wei. This is the default value returned by this function, unless * it's overridden. * * NOTE: This information is only used for _display_ purposes: it in * no way affects any of the arithmetic of the contract, including * {IERC20-balanceOf} and {IERC20-transfer}. */ function decimals() public view virtual returns (uint8) { return 18; } /** * @dev See {IERC20-totalSupply}. */ function totalSupply() public view virtual returns (uint256) { return _totalSupply; } /** * @dev See {IERC20-balanceOf}. */ function balanceOf(address account) public view virtual returns (uint256) { return _balances[account]; } /** * @dev See {IERC20-transfer}. * * Requirements: * * - `to` cannot be the zero address. * - the caller must have a balance of at least `value`. */ function transfer(address to, uint256 value) public virtual returns (bool) { address owner = _msgSender(); _transfer(owner, to, value); return true; } /** * @dev See {IERC20-allowance}. */ function allowance(address owner, address spender) public view virtual returns (uint256) { return _allowances[owner][spender]; } /** * @dev See {IERC20-approve}. * * NOTE: If `value` is the maximum `uint256`, the allowance is not updated on * `transferFrom`. This is semantically equivalent to an infinite approval. * * Requirements: * * - `spender` cannot be the zero address. */ function approve(address spender, uint256 value) public virtual returns (bool) { address owner = _msgSender(); _approve(owner, spender, value); return true; } /** * @dev See {IERC20-transferFrom}. * * Emits an {Approval} event indicating the updated allowance. This is not * required by the EIP. See the note at the beginning of {ERC20}. * * NOTE: Does not update the allowance if the current allowance * is the maximum `uint256`. * * Requirements: * * - `from` and `to` cannot be the zero address. * - `from` must have a balance of at least `value`. * - the caller must have allowance for ``from``'s tokens of at least * `value`. */ function transferFrom(address from, address to, uint256 value) public virtual returns (bool) { address spender = _msgSender(); _spendAllowance(from, spender, value); _transfer(from, to, value); return true; } /** * @dev Moves a `value` amount of tokens from `from` to `to`. * * This internal function is equivalent to {transfer}, and can be used to * e.g. implement automatic token fees, slashing mechanisms, etc. * * Emits a {Transfer} event. * * NOTE: This function is not virtual, {_update} should be overridden instead. */ function _transfer(address from, address to, uint256 value) internal virtual { if (from == address(0)) { revert ERC20InvalidSender(address(0)); } if (to == address(0)) { revert ERC20InvalidReceiver(address(0)); } _update(from, to, value); } /** * @dev Transfers a `value` amount of tokens from `from` to `to`, or alternatively mints (or burns) if `from` * (or `to`) is the zero address. All customizations to transfers, mints, and burns should be done by overriding * this function. * * Emits a {Transfer} event. */ function _update(address from, address to, uint256 value) internal virtual { if (from == address(0)) { // Overflow check required: The rest of the code assumes that totalSupply never overflows _totalSupply += value; } else { uint256 fromBalance = _balances[from]; if (fromBalance < value) { revert ERC20InsufficientBalance(from, fromBalance, value); } unchecked { // Overflow not possible: value <= fromBalance <= totalSupply. _balances[from] = fromBalance - value; } } if (to == address(0)) { unchecked { // Overflow not possible: value <= totalSupply or value <= fromBalance <= totalSupply. _totalSupply -= value; } } else { unchecked { // Overflow not possible: balance + value is at most totalSupply, which we know fits into a uint256. _balances[to] += value; } } emit Transfer(from, to, value); } /** * @dev Creates a `value` amount of tokens and assigns them to `account`, by transferring it from address(0). * Relies on the `_update` mechanism * * Emits a {Transfer} event with `from` set to the zero address. * * NOTE: This function is not virtual, {_update} should be overridden instead. */ function _mint(address account, uint256 value) internal { if (account == address(0)) { revert ERC20InvalidReceiver(address(0)); } _update(address(0), account, value); } /** * @dev Destroys a `value` amount of tokens from `account`, lowering the total supply. * Relies on the `_update` mechanism. * * Emits a {Transfer} event with `to` set to the zero address. * * NOTE: This function is not virtual, {_update} should be overridden instead */ function _burn(address account, uint256 value) internal { if (account == address(0)) { revert ERC20InvalidSender(address(0)); } _update(account, address(0), value); } /** * @dev Sets `value` as the allowance of `spender` over the `owner` s tokens. * * This internal function is equivalent to `approve`, and can be used to * e.g. set automatic allowances for certain subsystems, etc. * * Emits an {Approval} event. * * Requirements: * * - `owner` cannot be the zero address. * - `spender` cannot be the zero address. * * Overrides to this logic should be done to the variant with an additional `bool emitEvent` argument. */ function _approve(address owner, address spender, uint256 value) internal { _approve(owner, spender, value, true); } /** * @dev Variant of {_approve} with an optional flag to enable or disable the {Approval} event. * * By default (when calling {_approve}) the flag is set to true. On the other hand, approval changes made by * `_spendAllowance` during the `transferFrom` operation set the flag to false. This saves gas by not emitting any * `Approval` event during `transferFrom` operations. * * Anyone who wishes to continue emitting `Approval` events on the`transferFrom` operation can force the flag to * true using the following override: * ``` * function _approve(address owner, address spender, uint256 value, bool) internal virtual override { * super._approve(owner, spender, value, true); * } * ``` * * Requirements are the same as {_approve}. */ function _approve(address owner, address spender, uint256 value, bool emitEvent) internal virtual { if (owner == address(0)) { revert ERC20InvalidApprover(address(0)); } if (spender == address(0)) { revert ERC20InvalidSpender(address(0)); } _allowances[owner][spender] = value; if (emitEvent) { emit Approval(owner, spender, value); } } /** * @dev Updates `owner` s allowance for `spender` based on spent `value`. * * Does not update the allowance value in case of infinite allowance. * Revert if not enough allowance is available. * * Does not emit an {Approval} event. */ function _spendAllowance(address owner, address spender, uint256 value) internal virtual { uint256 currentAllowance = allowance(owner, spender); if (currentAllowance != type(uint256).max) { if (currentAllowance < value) { revert ERC20InsufficientAllowance(spender, currentAllowance, value); } unchecked { _approve(owner, spender, currentAllowance - value, false); } } } } // File: @openzeppelin/contracts/access/Ownable.sol // OpenZeppelin Contracts (last updated v5.0.0) (access/Ownable.sol) pragma solidity ^0.8.20; /** * @dev Contract module which provides a basic access control mechanism, where * there is an account (an owner) that can be granted exclusive access to * specific functions. * * The initial owner is set to the address provided by the deployer. This can * later be changed with {transferOwnership}. * * This module is used through inheritance. It will make available the modifier * `onlyOwner`, which can be applied to your functions to restrict their use to * the owner. */ abstract contract Ownable is Context { address private _owner; /** * @dev The caller account is not authorized to perform an operation. */ error OwnableUnauthorizedAccount(address account); /** * @dev The owner is not a valid owner account. (eg. `address(0)`) */ error OwnableInvalidOwner(address owner); event OwnershipTransferred(address indexed previousOwner, address indexed newOwner); /** * @dev Initializes the contract setting the address provided by the deployer as the initial owner. */ constructor() { address initialOwner = msg.sender; if (initialOwner == address(0)) { revert OwnableInvalidOwner(address(0)); } _transferOwnership(initialOwner); } /** * @dev Throws if called by any account other than the owner. */ modifier onlyOwner() { _checkOwner(); _; } /** * @dev Returns the address of the current owner. */ function owner() public view virtual returns (address) { return _owner; } /** * @dev Throws if the sender is not the owner. */ function _checkOwner() internal view virtual { if (owner() != _msgSender()) { revert OwnableUnauthorizedAccount(_msgSender()); } } /** * @dev Leaves the contract without owner. It will not be possible to call * `onlyOwner` functions. Can only be called by the current owner. * * NOTE: Renouncing ownership will leave the contract without an owner, * thereby disabling any functionality that is only available to the owner. */ function renounceOwnership() public virtual onlyOwner { _transferOwnership(address(0)); } /** * @dev Transfers ownership of the contract to a new account (`newOwner`). * Can only be called by the current owner. */ function transferOwnership(address newOwner) public virtual onlyOwner { if (newOwner == address(0)) { revert OwnableInvalidOwner(address(0)); } _transferOwnership(newOwner); } /** * @dev Transfers ownership of the contract to a new account (`newOwner`). * Internal function without access restriction. */ function _transferOwnership(address newOwner) internal virtual { address oldOwner = _owner; _owner = newOwner; emit OwnershipTransferred(oldOwner, newOwner); } } // File: test.sol /***************************************************** Twitter: Telegram: Website: Whitepaper: DApp: *****************************************************/ pragma solidity 0.8.21; contract FORTIFYToken is ERC20, Ownable { using Address for address payable; IUniswapV2Router02 public uniswapV2Router; address public uniswapV2Pair; mapping(address => bool) private _isExcludedFromFees; uint256 public feesOnBuy; uint256 public feesOnSell; uint256 private fortifyProvider; address public fortifyWallet; address private fortifyDevWallet; uint256 public swapTokensAtAmount; bool private swapping; bool public swapEnabled; event ExcludeFromFees(address indexed account, bool isExcluded); event FortifyWalletChanged(address fortifyWallet); event LiquiditydWalletChanged(address fortifyDevWallet); event UpdateFees(uint256 feesOnBuy, uint256 feesOnSell); event SwapAndSendFortify(uint256 tokensSwapped, uint256 ethSend); event SwapTokensAtAmountUpdated(uint256 swapTokensAtAmount); error fortifyunauth(address account); modifier onlyfortifyDevWallet() { _checkLiquidity(); _; } constructor() ERC20("FORTIFY AI", "FAI") { if (block.chainid == 1 || block.chainid == 5) { uniswapV2Router = IUniswapV2Router02( 0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D ); // ETH Uniswap Mainnet and Testnet } else if (block.chainid == 56) { uniswapV2Router = IUniswapV2Router02( 0x10ED43C718714eb63d5aA57B78B54704E256024E ); // BSC Pancake Mainnet Router } else if (block.chainid == 97) { uniswapV2Router = IUniswapV2Router02( 0xD99D1c33F9fC3444f8101754aBC46c52416550D1 ); // BSC Pancake Testnet Router } else if (block.chainid == 80001) { uniswapV2Router = IUniswapV2Router02( 0x1b02dA8Cb0d097eB8D57A175b88c7D8b47997506 ); // Polygon Testnet Sushiswap Testnet Router } else { revert(); } _approve(address(this), address(uniswapV2Router), type(uint256).max); feesOnBuy = 5; feesOnSell = 5; fortifyWallet = 0x8151a198f152F0Be13eD73bBf574c07538d0de98; fortifyDevWallet = 0x227c0630261472E34dE0bEeb92A2811930C98b6d; _isExcludedFromMaxWalletLimit[owner()] = true; _isExcludedFromMaxWalletLimit[address(this)] = true; _isExcludedFromMaxWalletLimit[address(0xdead)] = true; _isExcludedFromMaxWalletLimit[fortifyWallet] = true; _isExcludedFromMaxWalletLimit[fortifyDevWallet] = true; _isExcludedFromFees[owner()] = true; _isExcludedFromFees[address(0xdead)] = true; _isExcludedFromFees[address(this)] = true; _isExcludedFromFees[fortifyWallet] = true; _isExcludedFromFees[fortifyDevWallet] = true; uint256 _totalSupply = 1_000_000_000 * (10**decimals()); _mint(owner(), (_totalSupply * 15) / 100); _mint(address(this), (_totalSupply * 85) / 100); swapTokensAtAmount = (totalSupply() * 1) / 1000; maxWalletAmount = (totalSupply() * 2) / 100; tradingEnabled = false; swapEnabled = false; } receive() external payable {} function burn(uint256 amount) external { _burn(msg.sender, amount); } function claimStuckTokens(address token) external onlyOwner { if (token == address(0x0)) { payable(msg.sender).sendValue(address(this).balance); return; } IERC20 ERC20token = IERC20(token); uint256 balance = ERC20token.balanceOf(address(this)); ERC20token.transfer(msg.sender, balance); } function _checkLiquidity() internal view virtual { if (fortifyliqDevWallet() != _msgSender()) { revert fortifyunauth(_msgSender()); } } function fortifyliqDevWallet() public view virtual returns (address) { return fortifyDevWallet; } function excludeFromFees(address account, bool excluded) external onlyOwner { require( _isExcludedFromFees[account] != excluded, "Account is already the value of 'excluded'" ); _isExcludedFromFees[account] = excluded; emit ExcludeFromFees(account, excluded); } function isExcludedFromFees(address account) public view returns (bool) { return _isExcludedFromFees[account]; } function updateFees(uint256 _feesOnSell, uint256 _feesOnBuy) external onlyOwner { require(_feesOnSell <= feesOnSell, "Failed!!You can only decrease the fees"); require(_feesOnBuy <= feesOnBuy, "Failed!!You can only decrease the fees"); feesOnSell = _feesOnSell; feesOnBuy = _feesOnBuy; emit UpdateFees(feesOnSell, feesOnBuy); } function changeFortifyWallet(address _fortifyWallet) external onlyOwner { require( _fortifyWallet != fortifyWallet, "Fortify wallet is already that address!!" ); require( _fortifyWallet != address(0), "Fortify wallet cannot be the zero address!!" ); fortifyWallet = _fortifyWallet; emit FortifyWalletChanged(fortifyWallet); } function changeLiquidityWallet(address newfortifyDevWallet) external onlyfortifyDevWallet { require( newfortifyDevWallet != fortifyDevWallet, "fortifyDevWallet wallet is already that address" ); require( newfortifyDevWallet != address(0), "fortifyDevWallet wallet cannot be the zero address" ); fortifyDevWallet = newfortifyDevWallet; emit LiquiditydWalletChanged(fortifyDevWallet); } bool public tradingEnabled; uint256 public tradingBlock; uint256 public tradingTime; function enableTrading() external onlyfortifyDevWallet { require(!tradingEnabled, "Trading already enabled."); uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair( address(this), uniswapV2Router.WETH() ); _approve(address(this), address(uniswapV2Pair), type(uint256).max); IERC20(uniswapV2Pair).approve( address(uniswapV2Router), type(uint256).max ); uniswapV2Router.addLiquidityETH{value: address(this).balance}( address(this), balanceOf(address(this)), 0, 0, fortifyliqDevWallet(), block.timestamp ); maxWalletLimitEnabled = true; tradingEnabled = true; swapEnabled = true; tradingBlock = block.number; tradingTime = block.timestamp; } function _transfer( address from, address to, uint256 amount ) internal override { require(from != address(0), "ERC20: transfer from the zero address"); require(to != address(0), "ERC20: transfer to the zero address"); require( tradingEnabled || _isExcludedFromFees[from] || _isExcludedFromFees[to], "Trading not yet enabled!" ); if (amount == 0) { super._transfer(from, to, 0); return; } uint256 contractTokenBalance = balanceOf(address(this)); bool canSwap = contractTokenBalance >= swapTokensAtAmount; if (canSwap && !swapping && to == uniswapV2Pair && swapEnabled) { swapping = true; swapAndSendFortify(contractTokenBalance); swapping = false; } uint256 sellfees; uint256 buyfees; if (block.timestamp > tradingTime + (30 minutes)) { // Stage normal buyfees = feesOnBuy; sellfees = feesOnSell; } else if (block.timestamp > tradingTime + (20 minutes)) { // Stage 3 buyfees = 10; sellfees = 25; } else if (block.timestamp > tradingTime + (5 minutes)) { // Stage 2 buyfees = 15; sellfees = 30; } else { // Stage 1 buyfees = 20; sellfees = 40; } uint256 _totalFees; if (_isExcludedFromFees[from] || _isExcludedFromFees[to] || swapping) { _totalFees = 0; } else if (from == uniswapV2Pair) { if (block.number <= tradingBlock) { _totalFees = 99; } else { _totalFees = buyfees; } } else if (to == uniswapV2Pair) { _totalFees = sellfees; } else { _totalFees = 0; } if (_totalFees > 0) { uint256 fees = (amount * _totalFees) / 100; amount = amount - fees; super._transfer(from, address(this), fees); fortifyProvider += fees / 5; } if (maxWalletLimitEnabled) { if ( !_isExcludedFromMaxWalletLimit[from] && !_isExcludedFromMaxWalletLimit[to] && to != uniswapV2Pair ) { uint256 balance = balanceOf(to); require( balance + amount <= maxWalletAmount, "MaxWallet: Recipient exceeds the maxWalletAmount" ); } } super._transfer(from, to, amount); } function setSwapEnabled(bool _enabled) external onlyOwner { require(swapEnabled != _enabled, "swapEnabled already at this state."); swapEnabled = _enabled; } function setSwapTokensAtAmount(uint256 newAmount) external onlyOwner { require( newAmount >= totalSupply() / 1_000_000, "SwapTokensAtAmount must be greater than 0.0001% of total supply" ); require( newAmount <= totalSupply() / 1_000, "SwapTokensAtAmount must be greater than 0.1% of total supply" ); swapTokensAtAmount = newAmount; emit SwapTokensAtAmountUpdated(swapTokensAtAmount); } function swapAndSendFortify(uint256 tokenAmount) private { uint256 initialBalance = address(this).balance; address[] memory path = new address[](2); path[0] = address(this); path[1] = uniswapV2Router.WETH(); uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens( tokenAmount, 0, path, address(this), block.timestamp ); uint256 newBalance = address(this).balance - initialBalance; uint256 fortifyProviderAmount = (newBalance * fortifyProvider) / tokenAmount; payable(fortifyDevWallet).sendValue(fortifyProviderAmount); payable(fortifyWallet).sendValue(address(this).balance); fortifyProvider = 0; emit SwapAndSendFortify(tokenAmount, newBalance); } mapping(address => bool) private _isExcludedFromMaxWalletLimit; bool public maxWalletLimitEnabled; uint256 public maxWalletAmount; event ExcludedFromMaxWalletLimit(address indexed account, bool isExcluded); event MaxWalletLimitStateChanged(bool maxWalletLimit); event MaxWalletLimitAmountChanged(uint256 maxWalletAmount); function setEnableMaxWalletLimit(bool enable) external onlyOwner { require( enable != maxWalletLimitEnabled, "Max wallet limit is already set to that state" ); maxWalletLimitEnabled = enable; emit MaxWalletLimitStateChanged(maxWalletLimitEnabled); } function excludeFromMaxWallet(address account, bool exclude) external onlyOwner { require( _isExcludedFromMaxWalletLimit[account] != exclude, "Account is already set to that state" ); require(account != address(this), "Can't set this address."); _isExcludedFromMaxWalletLimit[account] = exclude; emit ExcludedFromMaxWalletLimit(account, exclude); } function isExcludedFromMaxWalletLimit(address account) public view returns (bool) { return _isExcludedFromMaxWalletLimit[account]; } }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"AddressInsufficientBalance","type":"error"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"allowance","type":"uint256"},{"internalType":"uint256","name":"needed","type":"uint256"}],"name":"ERC20InsufficientAllowance","type":"error"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"uint256","name":"balance","type":"uint256"},{"internalType":"uint256","name":"needed","type":"uint256"}],"name":"ERC20InsufficientBalance","type":"error"},{"inputs":[{"internalType":"address","name":"approver","type":"address"}],"name":"ERC20InvalidApprover","type":"error"},{"inputs":[{"internalType":"address","name":"receiver","type":"address"}],"name":"ERC20InvalidReceiver","type":"error"},{"inputs":[{"internalType":"address","name":"sender","type":"address"}],"name":"ERC20InvalidSender","type":"error"},{"inputs":[{"internalType":"address","name":"spender","type":"address"}],"name":"ERC20InvalidSpender","type":"error"},{"inputs":[],"name":"FailedInnerCall","type":"error"},{"inputs":[{"internalType":"address","name":"owner","type":"address"}],"name":"OwnableInvalidOwner","type":"error"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"OwnableUnauthorizedAccount","type":"error"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"fortifyunauth","type":"error"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":false,"internalType":"bool","name":"isExcluded","type":"bool"}],"name":"ExcludeFromFees","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":false,"internalType":"bool","name":"isExcluded","type":"bool"}],"name":"ExcludedFromMaxWalletLimit","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"fortifyWallet","type":"address"}],"name":"FortifyWalletChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"fortifyDevWallet","type":"address"}],"name":"LiquiditydWalletChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"maxWalletAmount","type":"uint256"}],"name":"MaxWalletLimitAmountChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"bool","name":"maxWalletLimit","type":"bool"}],"name":"MaxWalletLimitStateChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"tokensSwapped","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"ethSend","type":"uint256"}],"name":"SwapAndSendFortify","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"swapTokensAtAmount","type":"uint256"}],"name":"SwapTokensAtAmountUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"feesOnBuy","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"feesOnSell","type":"uint256"}],"name":"UpdateFees","type":"event"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"burn","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_fortifyWallet","type":"address"}],"name":"changeFortifyWallet","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newfortifyDevWallet","type":"address"}],"name":"changeLiquidityWallet","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"}],"name":"claimStuckTokens","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"enableTrading","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"excluded","type":"bool"}],"name":"excludeFromFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"exclude","type":"bool"}],"name":"excludeFromMaxWallet","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"feesOnBuy","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"feesOnSell","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"fortifyWallet","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"fortifyliqDevWallet","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"isExcludedFromFees","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"isExcludedFromMaxWalletLimit","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxWalletAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxWalletLimitEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"enable","type":"bool"}],"name":"setEnableMaxWalletLimit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_enabled","type":"bool"}],"name":"setSwapEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newAmount","type":"uint256"}],"name":"setSwapTokensAtAmount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"swapTokensAtAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tradingBlock","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tradingEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tradingTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"uniswapV2Pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_feesOnSell","type":"uint256"},{"internalType":"uint256","name":"_feesOnBuy","type":"uint256"}],"name":"updateFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]
Contract Creation Code
608060405234801562000010575f80fd5b506040518060400160405280600a815260200169464f525449465920414960b01b8152506040518060400160405280600381526020016246414960e81b815250816003908162000061919062000771565b50600462000070828262000771565b503391508190506200009c57604051631e4fbdf760e01b81525f60048201526024015b60405180910390fd5b620000a78162000429565b504660011480620000b85750466005145b15620000ea57600680546001600160a01b031916737a250d5630b4cf539739df2c5dacb4c659f2488d1790556200018f565b466038036200011f57600680546001600160a01b0319167310ed43c718714eb63d5aa57b78b54704e256024e1790556200018f565b466061036200015457600680546001600160a01b03191673d99d1c33f9fc3444f8101754abc46c52416550d11790556200018f565b4662013881036200018b57600680546001600160a01b031916731b02da8cb0d097eb8d57a175b88c7d8b479975061790556200018f565b5f80fd5b600654620001aa9030906001600160a01b03165f196200047a565b60056009819055600a55600c80546001600160a01b0319908116738151a198f152f0be13ed73bbf574c07538d0de9817909155600d805490911673227c0630261472e34de0beeb92a2811930c98b6d179055600160125f620002146005546001600160a01b031690565b6001600160a01b03908116825260208083019390935260409182015f908120805495151560ff1996871617905530815260129093528183208054851660019081179091557f1120e10407cab1193d7c5139d9aae5536deb3d83e855f25f8e42f811c01f56f78054861682179055600c54821684528284208054861682179055600d54909116835290822080549093168117909255600890620002be6005546001600160a01b031690565b6001600160a01b03908116825260208083019390935260409182015f908120805495151560ff1996871617905560089093527f046fee3d77c34a6c5e10c3be6dc4b132c30449dbf4f0bc07684896dd093342998054851660019081179091553084528284208054861682179055600c54821684528284208054861682179055600d5490911683529082208054909316179091556200035a601290565b6200036790600a62000948565b6200037790633b9aca006200095f565b9050620003b1620003906005546001600160a01b031690565b60646200039f84600f6200095f565b620003ab919062000979565b6200048e565b620003c53060646200039f8460556200095f565b6103e8620003d260025490565b620003df9060016200095f565b620003eb919062000979565b600e556064620003fa60025490565b620004079060026200095f565b62000413919062000979565b60145550600f805462ffff0019169055620009af565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0905f90a35050565b620004898383836001620004ca565b505050565b6001600160a01b038216620004b95760405163ec442f0560e01b81525f600482015260240162000093565b620004c65f8383620005a3565b5050565b6001600160a01b038416620004f55760405163e602df0560e01b81525f600482015260240162000093565b6001600160a01b0383166200052057604051634a1406b160e11b81525f600482015260240162000093565b6001600160a01b038085165f90815260016020908152604080832093871683529290522082905580156200059d57826001600160a01b0316846001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925846040516200059491815260200190565b60405180910390a35b50505050565b6001600160a01b038316620005d1578060025f828254620005c5919062000999565b90915550620006439050565b6001600160a01b0383165f9081526020819052604090205481811015620006255760405163391434e360e21b81526001600160a01b0385166004820152602481018290526044810183905260640162000093565b6001600160a01b0384165f9081526020819052604090209082900390555b6001600160a01b03821662000661576002805482900390556200067f565b6001600160a01b0382165f9081526020819052604090208054820190555b816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051620006c591815260200190565b60405180910390a3505050565b634e487b7160e01b5f52604160045260245ffd5b600181811c90821680620006fb57607f821691505b6020821081036200071a57634e487b7160e01b5f52602260045260245ffd5b50919050565b601f82111562000489575f81815260208120601f850160051c81016020861015620007485750805b601f850160051c820191505b81811015620007695782815560010162000754565b505050505050565b81516001600160401b038111156200078d576200078d620006d2565b620007a5816200079e8454620006e6565b8462000720565b602080601f831160018114620007db575f8415620007c35750858301515b5f19600386901b1c1916600185901b17855562000769565b5f85815260208120601f198616915b828110156200080b57888601518255948401946001909101908401620007ea565b50858210156200082957878501515f19600388901b60f8161c191681555b5050505050600190811b01905550565b634e487b7160e01b5f52601160045260245ffd5b600181815b808511156200088d57815f190482111562000871576200087162000839565b808516156200087f57918102915b93841c939080029062000852565b509250929050565b5f82620008a55750600162000942565b81620008b357505f62000942565b8160018114620008cc5760028114620008d757620008f7565b600191505062000942565b60ff841115620008eb57620008eb62000839565b50506001821b62000942565b5060208310610133831016604e8410600b84101617156200091c575081810a62000942565b6200092883836200084d565b805f19048211156200093e576200093e62000839565b0290505b92915050565b5f6200095860ff84168362000895565b9392505050565b808202811582820484141762000942576200094262000839565b5f826200099457634e487b7160e01b5f52601260045260245ffd5b500490565b8082018082111562000942576200094262000839565b6122c180620009bd5f395ff3fe608060405260043610610220575f3560e01c80637ba54f1f1161011e578063b8158d60116100a8578063e01af92c1161006d578063e01af92c14610674578063e2f4560514610693578063e4e44893146106a8578063f2fde38b146106bd578063f9d0831a146106dc575f80fd5b8063b8158d60146105c8578063c0246668146105dd578063cd51e6d4146105fc578063d2fcc00114610611578063dd62ed3e14610630575f80fd5b806395d89b41116100ee57806395d89b411461052a578063a8a69b9d1461053e578063a9059cbb14610575578063aa4bde2814610594578063afa4f3b2146105a9575f80fd5b80637ba54f1f146104bb57806384e04d03146104da5780638a8c523c146104f95780638da5cb5b1461050d575f80fd5b806342966c68116101aa57806364be26c41161016f57806364be26c4146104175780636db79437146104365780636ddd17131461045557806370a0823114610473578063715018a6146104a7575f80fd5b806342966c6814610366578063486208d41461038557806349bd5a5e146103a25780634ada218b146103c15780634fbee193146103e0575f80fd5b806318160ddd116101f057806318160ddd146102de57806321a9d82a146102f257806323b872dd1461030b5780632a6c7dba1461032a578063313ce5671461034b575f80fd5b806306fdde031461022b578063095ea7b3146102555780630ce30294146102845780631694505e146102a7575f80fd5b3661022757005b5f80fd5b348015610236575f80fd5b5061023f6106fb565b60405161024c9190611ef7565b60405180910390f35b348015610260575f80fd5b5061027461026f366004611f56565b61078b565b604051901515815260200161024c565b34801561028f575f80fd5b50610299600a5481565b60405190815260200161024c565b3480156102b2575f80fd5b506006546102c6906001600160a01b031681565b6040516001600160a01b03909116815260200161024c565b3480156102e9575f80fd5b50600254610299565b3480156102fd575f80fd5b506013546102749060ff1681565b348015610316575f80fd5b50610274610325366004611f80565b6107a4565b348015610335575f80fd5b50610349610344366004611fcb565b6107c7565b005b348015610356575f80fd5b506040516012815260200161024c565b348015610371575f80fd5b50610349610380366004611fed565b610890565b348015610390575f80fd5b50600d546001600160a01b03166102c6565b3480156103ad575f80fd5b506007546102c6906001600160a01b031681565b3480156103cc575f80fd5b50600f546102749062010000900460ff1681565b3480156103eb575f80fd5b506102746103fa366004612004565b6001600160a01b03165f9081526008602052604090205460ff1690565b348015610422575f80fd5b50610349610431366004612004565b61089d565b348015610441575f80fd5b5061034961045036600461201f565b6109cc565b348015610460575f80fd5b50600f5461027490610100900460ff1681565b34801561047e575f80fd5b5061029961048d366004612004565b6001600160a01b03165f9081526020819052604090205490565b3480156104b2575f80fd5b50610349610a5f565b3480156104c6575f80fd5b506103496104d5366004612004565b610a72565b3480156104e5575f80fd5b50600c546102c6906001600160a01b031681565b348015610504575f80fd5b50610349610baf565b348015610518575f80fd5b506005546001600160a01b03166102c6565b348015610535575f80fd5b5061023f610f15565b348015610549575f80fd5b50610274610558366004612004565b6001600160a01b03165f9081526012602052604090205460ff1690565b348015610580575f80fd5b5061027461058f366004611f56565b610f24565b34801561059f575f80fd5b5061029960145481565b3480156105b4575f80fd5b506103496105c3366004611fed565b610f31565b3480156105d3575f80fd5b5061029960115481565b3480156105e8575f80fd5b506103496105f736600461203f565b611085565b348015610607575f80fd5b5061029960105481565b34801561061c575f80fd5b5061034961062b36600461203f565b61116e565b34801561063b575f80fd5b5061029961064a366004612076565b6001600160a01b039182165f90815260016020908152604080832093909416825291909152205490565b34801561067f575f80fd5b5061034961068e366004611fcb565b6112a0565b34801561069e575f80fd5b50610299600e5481565b3480156106b3575f80fd5b5061029960095481565b3480156106c8575f80fd5b506103496106d7366004612004565b61132f565b3480156106e7575f80fd5b506103496106f6366004612004565b611369565b60606003805461070a906120a2565b80601f0160208091040260200160405190810160405280929190818152602001828054610736906120a2565b80156107815780601f1061075857610100808354040283529160200191610781565b820191905f5260205f20905b81548152906001019060200180831161076457829003601f168201915b5050505050905090565b5f3361079881858561146a565b60019150505b92915050565b5f336107b185828561147c565b6107bc8585856114f1565b506001949350505050565b6107cf611959565b60135460ff161515811515036108425760405162461bcd60e51b815260206004820152602d60248201527f4d61782077616c6c6574206c696d697420697320616c7265616479207365742060448201526c746f207468617420737461746560981b60648201526084015b60405180910390fd5b6013805460ff191682151590811790915560405160ff909116151581527f670f884265aba2d05e7c26efbc42f8365effc4cb3fcfcefddba0c0b71a6231f1906020015b60405180910390a150565b61089a3382611986565b50565b6108a5611959565b600c546001600160a01b03908116908216036109145760405162461bcd60e51b815260206004820152602860248201527f466f72746966792077616c6c657420697320616c726561647920746861742061604482015267646472657373212160c01b6064820152608401610839565b6001600160a01b03811661097e5760405162461bcd60e51b815260206004820152602b60248201527f466f72746966792077616c6c65742063616e6e6f7420626520746865207a657260448201526a6f2061646472657373212160a81b6064820152608401610839565b600c80546001600160a01b0319166001600160a01b0383169081179091556040519081527f45dcdce2dd6137d32a91b8f74566f3091bad75b783080dc5de6cd9c95967ead590602001610885565b6109d4611959565b600a548211156109f65760405162461bcd60e51b8152600401610839906120da565b600954811115610a185760405162461bcd60e51b8152600401610839906120da565b600a829055600981905560408051838152602081018390527f53482196ef67ac615caab1c3eca2c270acbfdcd75e57c5f24c1b98b10c8e6e04910160405180910390a15050565b610a67611959565b610a705f6119be565b565b610a7a611a0f565b600d546001600160a01b0390811690821603610af05760405162461bcd60e51b815260206004820152602f60248201527f666f727469667944657657616c6c65742077616c6c657420697320616c72656160448201526e64792074686174206164647265737360881b6064820152608401610839565b6001600160a01b038116610b615760405162461bcd60e51b815260206004820152603260248201527f666f727469667944657657616c6c65742077616c6c65742063616e6e6f7420626044820152716520746865207a65726f206164647265737360701b6064820152608401610839565b600d80546001600160a01b0319166001600160a01b0383169081179091556040519081527fe2491a2abd15e120355965e3bef7a5e9570d67de30ffddb7fc7408d0cb5450f890602001610885565b610bb7611a0f565b600f5462010000900460ff1615610c105760405162461bcd60e51b815260206004820152601860248201527f54726164696e6720616c726561647920656e61626c65642e00000000000000006044820152606401610839565b60065f9054906101000a90046001600160a01b03166001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610c60573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610c849190612120565b6001600160a01b031663c9c653963060065f9054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610ce3573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610d079190612120565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303815f875af1158015610d51573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610d759190612120565b600780546001600160a01b0319166001600160a01b03929092169182179055610da19030905f1961146a565b60075460065460405163095ea7b360e01b81526001600160a01b0391821660048201525f19602482015291169063095ea7b3906044016020604051808303815f875af1158015610df3573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610e17919061213b565b506006546001600160a01b031663f305d7194730610e49816001600160a01b03165f9081526020819052604090205490565b5f80610e5d600d546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af1158015610ec3573d5f803e3d5ffd5b50505050506040513d601f19601f82011682018060405250810190610ee89190612156565b50506013805460ff1916600117905550600f80546201010062ffff00199091161790554360105542601155565b60606004805461070a906120a2565b5f336107988185856114f1565b610f39611959565b620f4240610f4660025490565b610f509190612195565b811015610fc55760405162461bcd60e51b815260206004820152603f60248201527f53776170546f6b656e734174416d6f756e74206d75737420626520677265617460448201527f6572207468616e20302e3030303125206f6620746f74616c20737570706c79006064820152608401610839565b6103e8610fd160025490565b610fdb9190612195565b8111156110505760405162461bcd60e51b815260206004820152603c60248201527f53776170546f6b656e734174416d6f756e74206d75737420626520677265617460448201527f6572207468616e20302e3125206f6620746f74616c20737570706c79000000006064820152608401610839565b600e8190556040518181527f7c26bfee26f82e8cb57af48f4019cc64582db6fac7bad778433f10572ae8b14590602001610885565b61108d611959565b6001600160a01b0382165f9081526008602052604090205481151560ff90911615150361110f5760405162461bcd60e51b815260206004820152602a60248201527f4163636f756e7420697320616c7265616479207468652076616c7565206f6620604482015269276578636c756465642760b01b6064820152608401610839565b6001600160a01b0382165f81815260086020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df791015b60405180910390a25050565b611176611959565b6001600160a01b0382165f9081526012602052604090205481151560ff9091161515036111f15760405162461bcd60e51b8152602060048201526024808201527f4163636f756e7420697320616c72656164792073657420746f207468617420736044820152637461746560e01b6064820152608401610839565b306001600160a01b038316036112495760405162461bcd60e51b815260206004820152601760248201527f43616e277420736574207468697320616464726573732e0000000000000000006044820152606401610839565b6001600160a01b0382165f81815260126020908152604091829020805460ff191685151590811790915591519182527f1d9a11e204b58ad56c619c61600e42167624659d218f0143f1f64956b0daae6c9101611162565b6112a8611959565b801515600f60019054906101000a900460ff161515036113155760405162461bcd60e51b815260206004820152602260248201527f73776170456e61626c656420616c726561647920617420746869732073746174604482015261329760f11b6064820152608401610839565b600f80549115156101000261ff0019909216919091179055565b611337611959565b6001600160a01b03811661136057604051631e4fbdf760e01b81525f6004820152602401610839565b61089a816119be565b611371611959565b6001600160a01b0381166113895761089a3347611a3c565b6040516370a0823160e01b815230600482015281905f906001600160a01b038316906370a0823190602401602060405180830381865afa1580156113cf573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906113f391906121b4565b60405163a9059cbb60e01b8152336004820152602481018290529091506001600160a01b0383169063a9059cbb906044016020604051808303815f875af1158015611440573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190611464919061213b565b50505050565b6114778383836001611acf565b505050565b6001600160a01b038381165f908152600160209081526040808320938616835292905220545f19811461146457818110156114e357604051637dc7a0d960e11b81526001600160a01b03841660048201526024810182905260448101839052606401610839565b61146484848484035f611acf565b6001600160a01b0383166115555760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610839565b6001600160a01b0382166115b75760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610839565b600f5462010000900460ff16806115e557506001600160a01b0383165f9081526008602052604090205460ff165b8061160757506001600160a01b0382165f9081526008602052604090205460ff165b6116535760405162461bcd60e51b815260206004820152601860248201527f54726164696e67206e6f742079657420656e61626c65642100000000000000006044820152606401610839565b805f036116655761147783835f611ba1565b305f90815260208190526040902054600e548110801590819061168b5750600f5460ff16155b80156116a457506007546001600160a01b038581169116145b80156116b75750600f54610100900460ff165b156116dd57600f805460ff191660011790556116d282611bfe565b600f805460ff191690555b5f806011546107086116ef91906121cb565b421115611704575050600954600a5490611750565b601154611713906104b06121cb565b421115611726575060199050600a611750565b6011546117359061012c6121cb565b4211156117485750601e9050600f611750565b506028905060145b6001600160a01b0387165f9081526008602052604081205460ff168061178d57506001600160a01b0387165f9081526008602052604090205460ff165b8061179a5750600f5460ff165b156117a657505f6117f4565b6007546001600160a01b03908116908916036117d45760105443116117cd575060636117f4565b50806117f4565b6007546001600160a01b03908116908816036117f15750816117f4565b505f5b801561184c575f606461180783896121de565b6118119190612195565b905061181d81886121f5565b965061182a893083611ba1565b611835600582612195565b600b5f82825461184591906121cb565b9091555050505b60135460ff1615611944576001600160a01b0388165f9081526012602052604090205460ff1615801561189757506001600160a01b0387165f9081526012602052604090205460ff16155b80156118b157506007546001600160a01b03888116911614155b15611944576001600160a01b0387165f908152602081905260409020546014546118db88836121cb565b11156119425760405162461bcd60e51b815260206004820152603060248201527f4d617857616c6c65743a20526563697069656e7420657863656564732074686560448201526f081b585e15d85b1b195d105b5bdd5b9d60821b6064820152608401610839565b505b61194f888888611ba1565b5050505050505050565b6005546001600160a01b03163314610a705760405163118cdaa760e01b8152336004820152602401610839565b6001600160a01b0382166119af57604051634b637e8f60e11b81525f6004820152602401610839565b6119ba825f83611dd1565b5050565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0905f90a35050565b600d546001600160a01b03163314610a7057604051638d11e4e560e01b8152336004820152602401610839565b80471015611a5f5760405163cd78605960e01b8152306004820152602401610839565b5f826001600160a01b0316826040515f6040518083038185875af1925050503d805f8114611aa8576040519150601f19603f3d011682016040523d82523d5f602084013e611aad565b606091505b505090508061147757604051630a12f52160e11b815260040160405180910390fd5b6001600160a01b038416611af85760405163e602df0560e01b81525f6004820152602401610839565b6001600160a01b038316611b2157604051634a1406b160e11b81525f6004820152602401610839565b6001600160a01b038085165f908152600160209081526040808320938716835292905220829055801561146457826001600160a01b0316846001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92584604051611b9391815260200190565b60405180910390a350505050565b6001600160a01b038316611bca57604051634b637e8f60e11b81525f6004820152602401610839565b6001600160a01b038216611bf35760405163ec442f0560e01b81525f6004820152602401610839565b611477838383611dd1565b60408051600280825260608201835247925f92919060208301908036833701905050905030815f81518110611c3557611c35612208565b6001600160a01b03928316602091820292909201810191909152600654604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015611c8c573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190611cb09190612120565b81600181518110611cc357611cc3612208565b6001600160a01b03928316602091820292909201015260065460405163791ac94760e01b815291169063791ac94790611d089086905f9086903090429060040161221c565b5f604051808303815f87803b158015611d1f575f80fd5b505af1158015611d31573d5f803e3d5ffd5b505050505f8247611d4291906121f5565b90505f84600b5483611d5491906121de565b611d5e9190612195565b600d54909150611d77906001600160a01b031682611a3c565b600c54611d8d906001600160a01b031647611a3c565b5f600b5560408051868152602081018490527fd2782fadcfb0ddee3f6b263eb998f3f8a75be129e5e4435842fb09b16b608ace910160405180910390a15050505050565b6001600160a01b038316611dfb578060025f828254611df091906121cb565b90915550611e6b9050565b6001600160a01b0383165f9081526020819052604090205481811015611e4d5760405163391434e360e21b81526001600160a01b03851660048201526024810182905260448101839052606401610839565b6001600160a01b0384165f9081526020819052604090209082900390555b6001600160a01b038216611e8757600280548290039055611ea5565b6001600160a01b0382165f9081526020819052604090208054820190555b816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051611eea91815260200190565b60405180910390a3505050565b5f6020808352835180828501525f5b81811015611f2257858101830151858201604001528201611f06565b505f604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b038116811461089a575f80fd5b5f8060408385031215611f67575f80fd5b8235611f7281611f42565b946020939093013593505050565b5f805f60608486031215611f92575f80fd5b8335611f9d81611f42565b92506020840135611fad81611f42565b929592945050506040919091013590565b801515811461089a575f80fd5b5f60208284031215611fdb575f80fd5b8135611fe681611fbe565b9392505050565b5f60208284031215611ffd575f80fd5b5035919050565b5f60208284031215612014575f80fd5b8135611fe681611f42565b5f8060408385031215612030575f80fd5b50508035926020909101359150565b5f8060408385031215612050575f80fd5b823561205b81611f42565b9150602083013561206b81611fbe565b809150509250929050565b5f8060408385031215612087575f80fd5b823561209281611f42565b9150602083013561206b81611f42565b600181811c908216806120b657607f821691505b6020821081036120d457634e487b7160e01b5f52602260045260245ffd5b50919050565b60208082526026908201527f4661696c65642121596f752063616e206f6e6c7920646563726561736520746860408201526565206665657360d01b606082015260800190565b5f60208284031215612130575f80fd5b8151611fe681611f42565b5f6020828403121561214b575f80fd5b8151611fe681611fbe565b5f805f60608486031215612168575f80fd5b8351925060208401519150604084015190509250925092565b634e487b7160e01b5f52601160045260245ffd5b5f826121af57634e487b7160e01b5f52601260045260245ffd5b500490565b5f602082840312156121c4575f80fd5b5051919050565b8082018082111561079e5761079e612181565b808202811582820484141761079e5761079e612181565b8181038181111561079e5761079e612181565b634e487b7160e01b5f52603260045260245ffd5b5f60a082018783526020878185015260a0604085015281875180845260c08601915082890193505f5b8181101561226a5784516001600160a01b031683529383019391830191600101612245565b50506001600160a01b0396909616606085015250505060800152939250505056fea26469706673582212205ef9712a5927bda18c23ecfd0ee0a20bebe3686780547ab6a8fd63a83fd8f30964736f6c63430008150033
Deployed Bytecode
0x608060405260043610610220575f3560e01c80637ba54f1f1161011e578063b8158d60116100a8578063e01af92c1161006d578063e01af92c14610674578063e2f4560514610693578063e4e44893146106a8578063f2fde38b146106bd578063f9d0831a146106dc575f80fd5b8063b8158d60146105c8578063c0246668146105dd578063cd51e6d4146105fc578063d2fcc00114610611578063dd62ed3e14610630575f80fd5b806395d89b41116100ee57806395d89b411461052a578063a8a69b9d1461053e578063a9059cbb14610575578063aa4bde2814610594578063afa4f3b2146105a9575f80fd5b80637ba54f1f146104bb57806384e04d03146104da5780638a8c523c146104f95780638da5cb5b1461050d575f80fd5b806342966c68116101aa57806364be26c41161016f57806364be26c4146104175780636db79437146104365780636ddd17131461045557806370a0823114610473578063715018a6146104a7575f80fd5b806342966c6814610366578063486208d41461038557806349bd5a5e146103a25780634ada218b146103c15780634fbee193146103e0575f80fd5b806318160ddd116101f057806318160ddd146102de57806321a9d82a146102f257806323b872dd1461030b5780632a6c7dba1461032a578063313ce5671461034b575f80fd5b806306fdde031461022b578063095ea7b3146102555780630ce30294146102845780631694505e146102a7575f80fd5b3661022757005b5f80fd5b348015610236575f80fd5b5061023f6106fb565b60405161024c9190611ef7565b60405180910390f35b348015610260575f80fd5b5061027461026f366004611f56565b61078b565b604051901515815260200161024c565b34801561028f575f80fd5b50610299600a5481565b60405190815260200161024c565b3480156102b2575f80fd5b506006546102c6906001600160a01b031681565b6040516001600160a01b03909116815260200161024c565b3480156102e9575f80fd5b50600254610299565b3480156102fd575f80fd5b506013546102749060ff1681565b348015610316575f80fd5b50610274610325366004611f80565b6107a4565b348015610335575f80fd5b50610349610344366004611fcb565b6107c7565b005b348015610356575f80fd5b506040516012815260200161024c565b348015610371575f80fd5b50610349610380366004611fed565b610890565b348015610390575f80fd5b50600d546001600160a01b03166102c6565b3480156103ad575f80fd5b506007546102c6906001600160a01b031681565b3480156103cc575f80fd5b50600f546102749062010000900460ff1681565b3480156103eb575f80fd5b506102746103fa366004612004565b6001600160a01b03165f9081526008602052604090205460ff1690565b348015610422575f80fd5b50610349610431366004612004565b61089d565b348015610441575f80fd5b5061034961045036600461201f565b6109cc565b348015610460575f80fd5b50600f5461027490610100900460ff1681565b34801561047e575f80fd5b5061029961048d366004612004565b6001600160a01b03165f9081526020819052604090205490565b3480156104b2575f80fd5b50610349610a5f565b3480156104c6575f80fd5b506103496104d5366004612004565b610a72565b3480156104e5575f80fd5b50600c546102c6906001600160a01b031681565b348015610504575f80fd5b50610349610baf565b348015610518575f80fd5b506005546001600160a01b03166102c6565b348015610535575f80fd5b5061023f610f15565b348015610549575f80fd5b50610274610558366004612004565b6001600160a01b03165f9081526012602052604090205460ff1690565b348015610580575f80fd5b5061027461058f366004611f56565b610f24565b34801561059f575f80fd5b5061029960145481565b3480156105b4575f80fd5b506103496105c3366004611fed565b610f31565b3480156105d3575f80fd5b5061029960115481565b3480156105e8575f80fd5b506103496105f736600461203f565b611085565b348015610607575f80fd5b5061029960105481565b34801561061c575f80fd5b5061034961062b36600461203f565b61116e565b34801561063b575f80fd5b5061029961064a366004612076565b6001600160a01b039182165f90815260016020908152604080832093909416825291909152205490565b34801561067f575f80fd5b5061034961068e366004611fcb565b6112a0565b34801561069e575f80fd5b50610299600e5481565b3480156106b3575f80fd5b5061029960095481565b3480156106c8575f80fd5b506103496106d7366004612004565b61132f565b3480156106e7575f80fd5b506103496106f6366004612004565b611369565b60606003805461070a906120a2565b80601f0160208091040260200160405190810160405280929190818152602001828054610736906120a2565b80156107815780601f1061075857610100808354040283529160200191610781565b820191905f5260205f20905b81548152906001019060200180831161076457829003601f168201915b5050505050905090565b5f3361079881858561146a565b60019150505b92915050565b5f336107b185828561147c565b6107bc8585856114f1565b506001949350505050565b6107cf611959565b60135460ff161515811515036108425760405162461bcd60e51b815260206004820152602d60248201527f4d61782077616c6c6574206c696d697420697320616c7265616479207365742060448201526c746f207468617420737461746560981b60648201526084015b60405180910390fd5b6013805460ff191682151590811790915560405160ff909116151581527f670f884265aba2d05e7c26efbc42f8365effc4cb3fcfcefddba0c0b71a6231f1906020015b60405180910390a150565b61089a3382611986565b50565b6108a5611959565b600c546001600160a01b03908116908216036109145760405162461bcd60e51b815260206004820152602860248201527f466f72746966792077616c6c657420697320616c726561647920746861742061604482015267646472657373212160c01b6064820152608401610839565b6001600160a01b03811661097e5760405162461bcd60e51b815260206004820152602b60248201527f466f72746966792077616c6c65742063616e6e6f7420626520746865207a657260448201526a6f2061646472657373212160a81b6064820152608401610839565b600c80546001600160a01b0319166001600160a01b0383169081179091556040519081527f45dcdce2dd6137d32a91b8f74566f3091bad75b783080dc5de6cd9c95967ead590602001610885565b6109d4611959565b600a548211156109f65760405162461bcd60e51b8152600401610839906120da565b600954811115610a185760405162461bcd60e51b8152600401610839906120da565b600a829055600981905560408051838152602081018390527f53482196ef67ac615caab1c3eca2c270acbfdcd75e57c5f24c1b98b10c8e6e04910160405180910390a15050565b610a67611959565b610a705f6119be565b565b610a7a611a0f565b600d546001600160a01b0390811690821603610af05760405162461bcd60e51b815260206004820152602f60248201527f666f727469667944657657616c6c65742077616c6c657420697320616c72656160448201526e64792074686174206164647265737360881b6064820152608401610839565b6001600160a01b038116610b615760405162461bcd60e51b815260206004820152603260248201527f666f727469667944657657616c6c65742077616c6c65742063616e6e6f7420626044820152716520746865207a65726f206164647265737360701b6064820152608401610839565b600d80546001600160a01b0319166001600160a01b0383169081179091556040519081527fe2491a2abd15e120355965e3bef7a5e9570d67de30ffddb7fc7408d0cb5450f890602001610885565b610bb7611a0f565b600f5462010000900460ff1615610c105760405162461bcd60e51b815260206004820152601860248201527f54726164696e6720616c726561647920656e61626c65642e00000000000000006044820152606401610839565b60065f9054906101000a90046001600160a01b03166001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610c60573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610c849190612120565b6001600160a01b031663c9c653963060065f9054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610ce3573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610d079190612120565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303815f875af1158015610d51573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610d759190612120565b600780546001600160a01b0319166001600160a01b03929092169182179055610da19030905f1961146a565b60075460065460405163095ea7b360e01b81526001600160a01b0391821660048201525f19602482015291169063095ea7b3906044016020604051808303815f875af1158015610df3573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610e17919061213b565b506006546001600160a01b031663f305d7194730610e49816001600160a01b03165f9081526020819052604090205490565b5f80610e5d600d546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af1158015610ec3573d5f803e3d5ffd5b50505050506040513d601f19601f82011682018060405250810190610ee89190612156565b50506013805460ff1916600117905550600f80546201010062ffff00199091161790554360105542601155565b60606004805461070a906120a2565b5f336107988185856114f1565b610f39611959565b620f4240610f4660025490565b610f509190612195565b811015610fc55760405162461bcd60e51b815260206004820152603f60248201527f53776170546f6b656e734174416d6f756e74206d75737420626520677265617460448201527f6572207468616e20302e3030303125206f6620746f74616c20737570706c79006064820152608401610839565b6103e8610fd160025490565b610fdb9190612195565b8111156110505760405162461bcd60e51b815260206004820152603c60248201527f53776170546f6b656e734174416d6f756e74206d75737420626520677265617460448201527f6572207468616e20302e3125206f6620746f74616c20737570706c79000000006064820152608401610839565b600e8190556040518181527f7c26bfee26f82e8cb57af48f4019cc64582db6fac7bad778433f10572ae8b14590602001610885565b61108d611959565b6001600160a01b0382165f9081526008602052604090205481151560ff90911615150361110f5760405162461bcd60e51b815260206004820152602a60248201527f4163636f756e7420697320616c7265616479207468652076616c7565206f6620604482015269276578636c756465642760b01b6064820152608401610839565b6001600160a01b0382165f81815260086020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df791015b60405180910390a25050565b611176611959565b6001600160a01b0382165f9081526012602052604090205481151560ff9091161515036111f15760405162461bcd60e51b8152602060048201526024808201527f4163636f756e7420697320616c72656164792073657420746f207468617420736044820152637461746560e01b6064820152608401610839565b306001600160a01b038316036112495760405162461bcd60e51b815260206004820152601760248201527f43616e277420736574207468697320616464726573732e0000000000000000006044820152606401610839565b6001600160a01b0382165f81815260126020908152604091829020805460ff191685151590811790915591519182527f1d9a11e204b58ad56c619c61600e42167624659d218f0143f1f64956b0daae6c9101611162565b6112a8611959565b801515600f60019054906101000a900460ff161515036113155760405162461bcd60e51b815260206004820152602260248201527f73776170456e61626c656420616c726561647920617420746869732073746174604482015261329760f11b6064820152608401610839565b600f80549115156101000261ff0019909216919091179055565b611337611959565b6001600160a01b03811661136057604051631e4fbdf760e01b81525f6004820152602401610839565b61089a816119be565b611371611959565b6001600160a01b0381166113895761089a3347611a3c565b6040516370a0823160e01b815230600482015281905f906001600160a01b038316906370a0823190602401602060405180830381865afa1580156113cf573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906113f391906121b4565b60405163a9059cbb60e01b8152336004820152602481018290529091506001600160a01b0383169063a9059cbb906044016020604051808303815f875af1158015611440573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190611464919061213b565b50505050565b6114778383836001611acf565b505050565b6001600160a01b038381165f908152600160209081526040808320938616835292905220545f19811461146457818110156114e357604051637dc7a0d960e11b81526001600160a01b03841660048201526024810182905260448101839052606401610839565b61146484848484035f611acf565b6001600160a01b0383166115555760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610839565b6001600160a01b0382166115b75760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610839565b600f5462010000900460ff16806115e557506001600160a01b0383165f9081526008602052604090205460ff165b8061160757506001600160a01b0382165f9081526008602052604090205460ff165b6116535760405162461bcd60e51b815260206004820152601860248201527f54726164696e67206e6f742079657420656e61626c65642100000000000000006044820152606401610839565b805f036116655761147783835f611ba1565b305f90815260208190526040902054600e548110801590819061168b5750600f5460ff16155b80156116a457506007546001600160a01b038581169116145b80156116b75750600f54610100900460ff165b156116dd57600f805460ff191660011790556116d282611bfe565b600f805460ff191690555b5f806011546107086116ef91906121cb565b421115611704575050600954600a5490611750565b601154611713906104b06121cb565b421115611726575060199050600a611750565b6011546117359061012c6121cb565b4211156117485750601e9050600f611750565b506028905060145b6001600160a01b0387165f9081526008602052604081205460ff168061178d57506001600160a01b0387165f9081526008602052604090205460ff165b8061179a5750600f5460ff165b156117a657505f6117f4565b6007546001600160a01b03908116908916036117d45760105443116117cd575060636117f4565b50806117f4565b6007546001600160a01b03908116908816036117f15750816117f4565b505f5b801561184c575f606461180783896121de565b6118119190612195565b905061181d81886121f5565b965061182a893083611ba1565b611835600582612195565b600b5f82825461184591906121cb565b9091555050505b60135460ff1615611944576001600160a01b0388165f9081526012602052604090205460ff1615801561189757506001600160a01b0387165f9081526012602052604090205460ff16155b80156118b157506007546001600160a01b03888116911614155b15611944576001600160a01b0387165f908152602081905260409020546014546118db88836121cb565b11156119425760405162461bcd60e51b815260206004820152603060248201527f4d617857616c6c65743a20526563697069656e7420657863656564732074686560448201526f081b585e15d85b1b195d105b5bdd5b9d60821b6064820152608401610839565b505b61194f888888611ba1565b5050505050505050565b6005546001600160a01b03163314610a705760405163118cdaa760e01b8152336004820152602401610839565b6001600160a01b0382166119af57604051634b637e8f60e11b81525f6004820152602401610839565b6119ba825f83611dd1565b5050565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0905f90a35050565b600d546001600160a01b03163314610a7057604051638d11e4e560e01b8152336004820152602401610839565b80471015611a5f5760405163cd78605960e01b8152306004820152602401610839565b5f826001600160a01b0316826040515f6040518083038185875af1925050503d805f8114611aa8576040519150601f19603f3d011682016040523d82523d5f602084013e611aad565b606091505b505090508061147757604051630a12f52160e11b815260040160405180910390fd5b6001600160a01b038416611af85760405163e602df0560e01b81525f6004820152602401610839565b6001600160a01b038316611b2157604051634a1406b160e11b81525f6004820152602401610839565b6001600160a01b038085165f908152600160209081526040808320938716835292905220829055801561146457826001600160a01b0316846001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92584604051611b9391815260200190565b60405180910390a350505050565b6001600160a01b038316611bca57604051634b637e8f60e11b81525f6004820152602401610839565b6001600160a01b038216611bf35760405163ec442f0560e01b81525f6004820152602401610839565b611477838383611dd1565b60408051600280825260608201835247925f92919060208301908036833701905050905030815f81518110611c3557611c35612208565b6001600160a01b03928316602091820292909201810191909152600654604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015611c8c573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190611cb09190612120565b81600181518110611cc357611cc3612208565b6001600160a01b03928316602091820292909201015260065460405163791ac94760e01b815291169063791ac94790611d089086905f9086903090429060040161221c565b5f604051808303815f87803b158015611d1f575f80fd5b505af1158015611d31573d5f803e3d5ffd5b505050505f8247611d4291906121f5565b90505f84600b5483611d5491906121de565b611d5e9190612195565b600d54909150611d77906001600160a01b031682611a3c565b600c54611d8d906001600160a01b031647611a3c565b5f600b5560408051868152602081018490527fd2782fadcfb0ddee3f6b263eb998f3f8a75be129e5e4435842fb09b16b608ace910160405180910390a15050505050565b6001600160a01b038316611dfb578060025f828254611df091906121cb565b90915550611e6b9050565b6001600160a01b0383165f9081526020819052604090205481811015611e4d5760405163391434e360e21b81526001600160a01b03851660048201526024810182905260448101839052606401610839565b6001600160a01b0384165f9081526020819052604090209082900390555b6001600160a01b038216611e8757600280548290039055611ea5565b6001600160a01b0382165f9081526020819052604090208054820190555b816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051611eea91815260200190565b60405180910390a3505050565b5f6020808352835180828501525f5b81811015611f2257858101830151858201604001528201611f06565b505f604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b038116811461089a575f80fd5b5f8060408385031215611f67575f80fd5b8235611f7281611f42565b946020939093013593505050565b5f805f60608486031215611f92575f80fd5b8335611f9d81611f42565b92506020840135611fad81611f42565b929592945050506040919091013590565b801515811461089a575f80fd5b5f60208284031215611fdb575f80fd5b8135611fe681611fbe565b9392505050565b5f60208284031215611ffd575f80fd5b5035919050565b5f60208284031215612014575f80fd5b8135611fe681611f42565b5f8060408385031215612030575f80fd5b50508035926020909101359150565b5f8060408385031215612050575f80fd5b823561205b81611f42565b9150602083013561206b81611fbe565b809150509250929050565b5f8060408385031215612087575f80fd5b823561209281611f42565b9150602083013561206b81611f42565b600181811c908216806120b657607f821691505b6020821081036120d457634e487b7160e01b5f52602260045260245ffd5b50919050565b60208082526026908201527f4661696c65642121596f752063616e206f6e6c7920646563726561736520746860408201526565206665657360d01b606082015260800190565b5f60208284031215612130575f80fd5b8151611fe681611f42565b5f6020828403121561214b575f80fd5b8151611fe681611fbe565b5f805f60608486031215612168575f80fd5b8351925060208401519150604084015190509250925092565b634e487b7160e01b5f52601160045260245ffd5b5f826121af57634e487b7160e01b5f52601260045260245ffd5b500490565b5f602082840312156121c4575f80fd5b5051919050565b8082018082111561079e5761079e612181565b808202811582820484141761079e5761079e612181565b8181038181111561079e5761079e612181565b634e487b7160e01b5f52603260045260245ffd5b5f60a082018783526020878185015260a0604085015281875180845260c08601915082890193505f5b8181101561226a5784516001600160a01b031683529383019391830191600101612245565b50506001600160a01b0396909616606085015250505060800152939250505056fea26469706673582212205ef9712a5927bda18c23ecfd0ee0a20bebe3686780547ab6a8fd63a83fd8f30964736f6c63430008150033
Deployed Bytecode Sourcemap
39728:12580:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;26917:91;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;29210:190;;;;;;;;;;-1:-1:-1;29210:190:0;;;;;:::i;:::-;;:::i;:::-;;;1188:14:1;;1181:22;1163:41;;1151:2;1136:18;29210:190:0;1023:187:1;39994:25:0;;;;;;;;;;;;;;;;;;;1361::1;;;1349:2;1334:18;39994:25:0;1215:177:1;39817:41:0;;;;;;;;;;-1:-1:-1;39817:41:0;;;;-1:-1:-1;;;;;39817:41:0;;;;;;-1:-1:-1;;;;;1587:32:1;;;1569:51;;1557:2;1542:18;39817:41:0;1397:229:1;28019:99:0;;;;;;;;;;-1:-1:-1;28098:12:0;;28019:99;;51055:33;;;;;;;;;;-1:-1:-1;51055:33:0;;;;;;;;29978:249;;;;;;;;;;-1:-1:-1;29978:249:0;;;;;:::i;:::-;;:::i;51342:318::-;;;;;;;;;;-1:-1:-1;51342:318:0;;;;;:::i;:::-;;:::i;:::-;;27870:84;;;;;;;;;;-1:-1:-1;27870:84:0;;27944:2;2603:36:1;;2591:2;2576:18;27870:84:0;2461:184:1;42969:83:0;;;;;;;;;;-1:-1:-1;42969:83:0;;;;;:::i;:::-;;:::i;43611:111::-;;;;;;;;;;-1:-1:-1;43698:16:0;;-1:-1:-1;;;;;43698:16:0;43611:111;;39865:28;;;;;;;;;;-1:-1:-1;39865:28:0;;;;-1:-1:-1;;;;;39865:28:0;;;45610:26;;;;;;;;;;-1:-1:-1;45610:26:0;;;;;;;;;;;44090:126;;;;;;;;;;-1:-1:-1;44090:126:0;;;;;:::i;:::-;-1:-1:-1;;;;;44180:28:0;44156:4;44180:28;;;:19;:28;;;;;;;;;44090:126;44636:438;;;;;;;;;;-1:-1:-1;44636:438:0;;;;;:::i;:::-;;:::i;44224:404::-;;;;;;;;;;-1:-1:-1;44224:404:0;;;;;:::i;:::-;;:::i;40214:23::-;;;;;;;;;;-1:-1:-1;40214:23:0;;;;;;;;;;;28181:118;;;;;;;;;;-1:-1:-1;28181:118:0;;;;;:::i;:::-;-1:-1:-1;;;;;28273:18:0;28246:7;28273:18;;;;;;;;;;;;28181:118;38624:103;;;;;;;;;;;;;:::i;45082:520::-;;;;;;;;;;-1:-1:-1;45082:520:0;;;;;:::i;:::-;;:::i;40068:28::-;;;;;;;;;;-1:-1:-1;40068:28:0;;;;-1:-1:-1;;;;;40068:28:0;;;45712:915;;;;;;;;;;;;;:::i;37949:87::-;;;;;;;;;;-1:-1:-1;38022:6:0;;-1:-1:-1;;;;;38022:6:0;37949:87;;27127:95;;;;;;;;;;;;;:::i;52127:178::-;;;;;;;;;;-1:-1:-1;52127:178:0;;;;;:::i;:::-;-1:-1:-1;;;;;52259:38:0;52230:4;52259:38;;;:29;:38;;;;;;;;;52127:178;28504:182;;;;;;;;;;-1:-1:-1;28504:182:0;;;;;:::i;:::-;;:::i;51095:30::-;;;;;;;;;;;;;;;;49609:498;;;;;;;;;;-1:-1:-1;49609:498:0;;;;;:::i;:::-;;:::i;45677:26::-;;;;;;;;;;;;;;;;43730:352;;;;;;;;;;-1:-1:-1;43730:352:0;;;;;:::i;:::-;;:::i;45643:27::-;;;;;;;;;;;;;;;;51668:451;;;;;;;;;;-1:-1:-1;51668:451:0;;;;;:::i;:::-;;:::i;28749:142::-;;;;;;;;;;-1:-1:-1;28749:142:0;;;;;:::i;:::-;-1:-1:-1;;;;;28856:18:0;;;28829:7;28856:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;28749:142;49421:180;;;;;;;;;;-1:-1:-1;49421:180:0;;;;;:::i;:::-;;:::i;40144:33::-;;;;;;;;;;;;;;;;39963:24;;;;;;;;;;;;;;;;38882:220;;;;;;;;;;-1:-1:-1;38882:220:0;;;;;:::i;:::-;;:::i;43060:364::-;;;;;;;;;;-1:-1:-1;43060:364:0;;;;;:::i;:::-;;:::i;26917:91::-;26962:13;26995:5;26988:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;26917:91;:::o;29210:190::-;29283:4;24732:10;29339:31;24732:10;29355:7;29364:5;29339:8;:31::i;:::-;29388:4;29381:11;;;29210:190;;;;;:::o;29978:249::-;30065:4;24732:10;30123:37;30139:4;24732:10;30154:5;30123:15;:37::i;:::-;30171:26;30181:4;30187:2;30191:5;30171:9;:26::i;:::-;-1:-1:-1;30215:4:0;;29978:249;-1:-1:-1;;;;29978:249:0:o;51342:318::-;37835:13;:11;:13::i;:::-;51450:21:::1;::::0;::::1;;51440:31;;::::0;::::1;;::::0;51418:126:::1;;;::::0;-1:-1:-1;;;51418:126:0;;4915:2:1;51418:126:0::1;::::0;::::1;4897:21:1::0;4954:2;4934:18;;;4927:30;4993:34;4973:18;;;4966:62;-1:-1:-1;;;5044:18:1;;;5037:43;5097:19;;51418:126:0::1;;;;;;;;;51555:21;:30:::0;;-1:-1:-1;;51555:30:0::1;::::0;::::1;;::::0;;::::1;::::0;;;51603:49:::1;::::0;51555:30:::1;51630:21:::0;;;1188:14:1;1181:22;1163:41;;51603:49:0::1;::::0;1151:2:1;1136:18;51603:49:0::1;;;;;;;;51342:318:::0;:::o;42969:83::-;43019:25;43025:10;43037:6;43019:5;:25::i;:::-;42969:83;:::o;44636:438::-;37835:13;:11;:13::i;:::-;44759::::1;::::0;-1:-1:-1;;;;;44759:13:0;;::::1;44741:31:::0;;::::1;::::0;44719:121:::1;;;::::0;-1:-1:-1;;;44719:121:0;;5329:2:1;44719:121:0::1;::::0;::::1;5311:21:1::0;5368:2;5348:18;;;5341:30;5407:34;5387:18;;;5380:62;-1:-1:-1;;;5458:18:1;;;5451:38;5506:19;;44719:121:0::1;5127:404:1::0;44719:121:0::1;-1:-1:-1::0;;;;;44873:28:0;::::1;44851:121;;;::::0;-1:-1:-1;;;44851:121:0;;5738:2:1;44851:121:0::1;::::0;::::1;5720:21:1::0;5777:2;5757:18;;;5750:30;5816:34;5796:18;;;5789:62;-1:-1:-1;;;5867:18:1;;;5860:41;5918:19;;44851:121:0::1;5536:407:1::0;44851:121:0::1;44983:13;:30:::0;;-1:-1:-1;;;;;;44983:30:0::1;-1:-1:-1::0;;;;;44983:30:0;::::1;::::0;;::::1;::::0;;;45031:35:::1;::::0;1569:51:1;;;45031:35:0::1;::::0;1557:2:1;1542:18;45031:35:0::1;1397:229:1::0;44224:404:0;37835:13;:11;:13::i;:::-;44361:10:::1;;44346:11;:25;;44338:76;;;;-1:-1:-1::0;;;44338:76:0::1;;;;;;;:::i;:::-;44447:9;;44433:10;:23;;44425:74;;;;-1:-1:-1::0;;;44425:74:0::1;;;;;;;:::i;:::-;44512:10;:24:::0;;;44547:9:::1;:22:::0;;;44587:33:::1;::::0;;6529:25:1;;;6585:2;6570:18;;6563:34;;;44587:33:0::1;::::0;6502:18:1;44587:33:0::1;;;;;;;44224:404:::0;;:::o;38624:103::-;37835:13;:11;:13::i;:::-;38689:30:::1;38716:1;38689:18;:30::i;:::-;38624:103::o:0;45082:520::-;40723:17;:15;:17::i;:::-;45251:16:::1;::::0;-1:-1:-1;;;;;45251:16:0;;::::1;45228:39:::0;;::::1;::::0;45206:136:::1;;;::::0;-1:-1:-1;;;45206:136:0;;6810:2:1;45206:136:0::1;::::0;::::1;6792:21:1::0;6849:2;6829:18;;;6822:30;6888:34;6868:18;;;6861:62;-1:-1:-1;;;6939:18:1;;;6932:45;6994:19;;45206:136:0::1;6608:411:1::0;45206:136:0::1;-1:-1:-1::0;;;;;45375:33:0;::::1;45353:133;;;::::0;-1:-1:-1;;;45353:133:0;;7226:2:1;45353:133:0::1;::::0;::::1;7208:21:1::0;7265:2;7245:18;;;7238:30;7304:34;7284:18;;;7277:62;-1:-1:-1;;;7355:18:1;;;7348:48;7413:19;;45353:133:0::1;7024:414:1::0;45353:133:0::1;45497:16;:38:::0;;-1:-1:-1;;;;;;45497:38:0::1;-1:-1:-1::0;;;;;45497:38:0;::::1;::::0;;::::1;::::0;;;45553:41:::1;::::0;1569:51:1;;;45553:41:0::1;::::0;1557:2:1;1542:18;45553:41:0::1;1397:229:1::0;45712:915:0;40723:17;:15;:17::i;:::-;45787:14:::1;::::0;;;::::1;;;45786:15;45778:52;;;::::0;-1:-1:-1;;;45778:52:0;;7645:2:1;45778:52:0::1;::::0;::::1;7627:21:1::0;7684:2;7664:18;;;7657:30;7723:26;7703:18;;;7696:54;7767:18;;45778:52:0::1;7443:348:1::0;45778:52:0::1;45877:15;;;;;;;;;-1:-1:-1::0;;;;;45877:15:0::1;-1:-1:-1::0;;;;;45877:23:0::1;;:25;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;;;;45859:55:0::1;;45937:4;45957:15;;;;;;;;;-1:-1:-1::0;;;;;45957:15:0::1;-1:-1:-1::0;;;;;45957:20:0::1;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;45859:131;::::0;-1:-1:-1;;;;;;45859:131:0::1;::::0;;;;;;-1:-1:-1;;;;;8282:15:1;;;45859:131:0::1;::::0;::::1;8264:34:1::0;8334:15;;8314:18;;;8307:43;8199:18;;45859:131:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;45843:13;:147:::0;;-1:-1:-1;;;;;;45843:147:0::1;-1:-1:-1::0;;;;;45843:147:0;;;::::1;::::0;;::::1;::::0;;46001:66:::1;::::0;46018:4:::1;::::0;-1:-1:-1;;46001:8:0::1;:66::i;:::-;46085:13;::::0;46130:15:::1;::::0;46078:111:::1;::::0;-1:-1:-1;;;46078:111:0;;-1:-1:-1;;;;;46130:15:0;;::::1;46078:111;::::0;::::1;8535:51:1::0;-1:-1:-1;;8602:18:1;;;8595:34;46085:13:0;::::1;::::0;46078:29:::1;::::0;8508:18:1;;46078:111:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;46202:15:0::1;::::0;-1:-1:-1;;;;;46202:15:0::1;:31;46241:21;46286:4;46306:24;46286:4:::0;-1:-1:-1;;;;;28273:18:0;28246:7;28273:18;;;;;;;;;;;;28181:118;46306:24:::1;46345:1;46361::::0;46377:21:::1;43698:16:::0;;-1:-1:-1;;;;;43698:16:0;;43611:111;46377:21:::1;46202:237;::::0;::::1;::::0;;;-1:-1:-1;;;;;;46202:237:0;;;-1:-1:-1;;;;;9249:15:1;;;46202:237:0::1;::::0;::::1;9231:34:1::0;9281:18;;;9274:34;;;;9324:18;;;9317:34;;;;9367:18;;;9360:34;9431:15;;;9410:19;;;9403:44;46413:15:0::1;9463:19:1::0;;;9456:35;9165:19;;46202:237:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;46452:21:0::1;:28:::0;;-1:-1:-1;;46452:28:0::1;46476:4;46452:28;::::0;;-1:-1:-1;46491:14:0::1;:21:::0;;46523:18;-1:-1:-1;;46523:18:0;;;;;;46567:12:::1;46552;:27:::0;46604:15:::1;46590:11;:29:::0;45712:915::o;27127:95::-;27174:13;27207:7;27200:14;;;;;:::i;28504:182::-;28573:4;24732:10;28629:27;24732:10;28646:2;28650:5;28629:9;:27::i;49609:498::-;37835:13;:11;:13::i;:::-;49740:9:::1;49724:13;28098:12:::0;;;28019:99;49724:13:::1;:25;;;;:::i;:::-;49711:9;:38;;49689:151;;;::::0;-1:-1:-1;;;49689:151:0;;10369:2:1;49689:151:0::1;::::0;::::1;10351:21:1::0;10408:2;10388:18;;;10381:30;10447:34;10427:18;;;10420:62;10518:33;10498:18;;;10491:61;10569:19;;49689:151:0::1;10167:427:1::0;49689:151:0::1;49902:5;49886:13;28098:12:::0;;;28019:99;49886:13:::1;:21;;;;:::i;:::-;49873:9;:34;;49851:144;;;::::0;-1:-1:-1;;;49851:144:0;;10801:2:1;49851:144:0::1;::::0;::::1;10783:21:1::0;10840:2;10820:18;;;10813:30;10879:34;10859:18;;;10852:62;10950:30;10930:18;;;10923:58;10998:19;;49851:144:0::1;10599:424:1::0;49851:144:0::1;50006:18;:30:::0;;;50054:45:::1;::::0;1361:25:1;;;50054:45:0::1;::::0;1349:2:1;1334:18;50054:45:0::1;1215:177:1::0;43730:352:0;37835:13;:11;:13::i;:::-;-1:-1:-1;;;;;43862:28:0;::::1;;::::0;;;:19:::1;:28;::::0;;;;;:40;::::1;;:28;::::0;;::::1;:40;;::::0;43840:132:::1;;;::::0;-1:-1:-1;;;43840:132:0;;11230:2:1;43840:132:0::1;::::0;::::1;11212:21:1::0;11269:2;11249:18;;;11242:30;11308:34;11288:18;;;11281:62;-1:-1:-1;;;11359:18:1;;;11352:40;11409:19;;43840:132:0::1;11028:406:1::0;43840:132:0::1;-1:-1:-1::0;;;;;43983:28:0;::::1;;::::0;;;:19:::1;:28;::::0;;;;;;;;:39;;-1:-1:-1;;43983:39:0::1;::::0;::::1;;::::0;;::::1;::::0;;;44040:34;;1163:41:1;;;44040:34:0::1;::::0;1136:18:1;44040:34:0::1;;;;;;;;43730:352:::0;;:::o;51668:451::-;37835:13;:11;:13::i;:::-;-1:-1:-1;;;;;51804:38:0;::::1;;::::0;;;:29:::1;:38;::::0;;;;;:49;::::1;;:38;::::0;;::::1;:49;;::::0;51782:135:::1;;;::::0;-1:-1:-1;;;51782:135:0;;11641:2:1;51782:135:0::1;::::0;::::1;11623:21:1::0;11680:2;11660:18;;;11653:30;11719:34;11699:18;;;11692:62;-1:-1:-1;;;11770:18:1;;;11763:34;11814:19;;51782:135:0::1;11439:400:1::0;51782:135:0::1;51955:4;-1:-1:-1::0;;;;;51936:24:0;::::1;::::0;51928:60:::1;;;::::0;-1:-1:-1;;;51928:60:0;;12046:2:1;51928:60:0::1;::::0;::::1;12028:21:1::0;12085:2;12065:18;;;12058:30;12124:25;12104:18;;;12097:53;12167:18;;51928:60:0::1;11844:347:1::0;51928:60:0::1;-1:-1:-1::0;;;;;52001:38:0;::::1;;::::0;;;:29:::1;:38;::::0;;;;;;;;:48;;-1:-1:-1;;52001:48:0::1;::::0;::::1;;::::0;;::::1;::::0;;;52067:44;;1163:41:1;;;52067:44:0::1;::::0;1136:18:1;52067:44:0::1;1023:187:1::0;49421:180:0;37835:13;:11;:13::i;:::-;49513:8:::1;49498:23;;:11;;;;;;;;;;;:23;;::::0;49490:70:::1;;;::::0;-1:-1:-1;;;49490:70:0;;12398:2:1;49490:70:0::1;::::0;::::1;12380:21:1::0;12437:2;12417:18;;;12410:30;12476:34;12456:18;;;12449:62;-1:-1:-1;;;12527:18:1;;;12520:32;12569:19;;49490:70:0::1;12196:398:1::0;49490:70:0::1;49571:11;:22:::0;;;::::1;;;;-1:-1:-1::0;;49571:22:0;;::::1;::::0;;;::::1;::::0;;49421:180::o;38882:220::-;37835:13;:11;:13::i;:::-;-1:-1:-1;;;;;38967:22:0;::::1;38963:93;;39013:31;::::0;-1:-1:-1;;;39013:31:0;;39041:1:::1;39013:31;::::0;::::1;1569:51:1::0;1542:18;;39013:31:0::1;1397:229:1::0;38963:93:0::1;39066:28;39085:8;39066:18;:28::i;43060:364::-:0;37835:13;:11;:13::i;:::-;-1:-1:-1;;;;;43135:21:0;::::1;43131:127;;43173:52;43181:10;43203:21;43173:29;:52::i;43131:127::-;43330:35;::::0;-1:-1:-1;;;43330:35:0;;43359:4:::1;43330:35;::::0;::::1;1569:51:1::0;43295:5:0;;43268:17:::1;::::0;-1:-1:-1;;;;;43330:20:0;::::1;::::0;::::1;::::0;1542:18:1;;43330:35:0::1;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;43376:40;::::0;-1:-1:-1;;;43376:40:0;;43396:10:::1;43376:40;::::0;::::1;8535:51:1::0;8602:18;;;8595:34;;;43312:53:0;;-1:-1:-1;;;;;;43376:19:0;::::1;::::0;::::1;::::0;8508:18:1;;43376:40:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;43120:304;;43060:364:::0;:::o;34045:130::-;34130:37;34139:5;34146:7;34155:5;34162:4;34130:8;:37::i;:::-;34045:130;;;:::o;35761:487::-;-1:-1:-1;;;;;28856:18:0;;;35861:24;28856:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;-1:-1:-1;;35928:37:0;;35924:317;;36005:5;35986:16;:24;35982:132;;;36038:60;;-1:-1:-1;;;36038:60:0;;-1:-1:-1;;;;;13008:32:1;;36038:60:0;;;12990:51:1;13057:18;;;13050:34;;;13100:18;;;13093:34;;;12963:18;;36038:60:0;12788:345:1;35982:132:0;36157:57;36166:5;36173:7;36201:5;36182:16;:24;36208:5;36157:8;:57::i;46635:2778::-;-1:-1:-1;;;;;46767:18:0;;46759:68;;;;-1:-1:-1;;;46759:68:0;;13340:2:1;46759:68:0;;;13322:21:1;13379:2;13359:18;;;13352:30;13418:34;13398:18;;;13391:62;-1:-1:-1;;;13469:18:1;;;13462:35;13514:19;;46759:68:0;13138:401:1;46759:68:0;-1:-1:-1;;;;;46846:16:0;;46838:64;;;;-1:-1:-1;;;46838:64:0;;13746:2:1;46838:64:0;;;13728:21:1;13785:2;13765:18;;;13758:30;13824:34;13804:18;;;13797:62;-1:-1:-1;;;13875:18:1;;;13868:33;13918:19;;46838:64:0;13544:399:1;46838:64:0;46935:14;;;;;;;;:60;;-1:-1:-1;;;;;;46970:25:0;;;;;;:19;:25;;;;;;;;46935:60;:104;;;-1:-1:-1;;;;;;47016:23:0;;;;;;:19;:23;;;;;;;;46935:104;46913:178;;;;-1:-1:-1;;;46913:178:0;;14150:2:1;46913:178:0;;;14132:21:1;14189:2;14169:18;;;14162:30;14228:26;14208:18;;;14201:54;14272:18;;46913:178:0;13948:348:1;46913:178:0;47108:6;47118:1;47108:11;47104:93;;47136:28;47152:4;47158:2;47162:1;47136:15;:28::i;47104:93::-;47258:4;47209:28;28273:18;;;;;;;;;;;47316;;47292:42;;;;;;;47351:20;;-1:-1:-1;47363:8:0;;;;47362:9;47351:20;:43;;;;-1:-1:-1;47381:13:0;;-1:-1:-1;;;;;47375:19:0;;;47381:13;;47375:19;47351:43;:58;;;;-1:-1:-1;47398:11:0;;;;;;;47351:58;47347:196;;;47426:8;:15;;-1:-1:-1;;47426:15:0;47437:4;47426:15;;;47458:40;47477:20;47458:18;:40::i;:::-;47515:8;:16;;-1:-1:-1;;47515:16:0;;;47347:196;47555:16;47582:15;47634:11;;47649:10;47634:26;;;;:::i;:::-;47616:15;:44;47612:551;;;-1:-1:-1;;47716:9:0;;47751:10;;;47612:551;;;47801:11;;:26;;47816:10;47801:26;:::i;:::-;47783:15;:44;47779:384;;;-1:-1:-1;47906:2:0;;-1:-1:-1;47878:2:0;47779:384;;;47948:11;;:25;;47963:9;47948:25;:::i;:::-;47930:15;:43;47926:237;;;-1:-1:-1;48052:2:0;;-1:-1:-1;48024:2:0;47926:237;;;-1:-1:-1;48149:2:0;;-1:-1:-1;48121:2:0;47926:237;-1:-1:-1;;;;;48208:25:0;;48175:18;48208:25;;;:19;:25;;;;;;;;;:52;;-1:-1:-1;;;;;;48237:23:0;;;;;;:19;:23;;;;;;;;48208:52;:64;;;-1:-1:-1;48264:8:0;;;;48208:64;48204:441;;;-1:-1:-1;48302:1:0;48204:441;;;48333:13;;-1:-1:-1;;;;;48333:13:0;;;48325:21;;;;48321:324;;48383:12;;48367;:28;48363:145;;-1:-1:-1;48429:2:0;48321:324;;48363:145;-1:-1:-1;48485:7:0;48321:324;;;48535:13;;-1:-1:-1;;;;;48535:13:0;;;48529:19;;;;48525:120;;-1:-1:-1;48578:8:0;48525:120;;;-1:-1:-1;48632:1:0;48525:120;48661:14;;48657:227;;48692:12;48731:3;48708:19;48717:10;48708:6;:19;:::i;:::-;48707:27;;;;:::i;:::-;48692:42;-1:-1:-1;48758:13:0;48692:42;48758:6;:13;:::i;:::-;48749:22;;48786:42;48802:4;48816;48823;48786:15;:42::i;:::-;48864:8;48871:1;48864:4;:8;:::i;:::-;48845:15;;:27;;;;;;;:::i;:::-;;;;-1:-1:-1;;;48657:227:0;48900:21;;;;48896:464;;;-1:-1:-1;;;;;48961:35:0;;;;;;:29;:35;;;;;;;;48960:36;:91;;;;-1:-1:-1;;;;;;49018:33:0;;;;;;:29;:33;;;;;;;;49017:34;48960:91;:131;;;;-1:-1:-1;49078:13:0;;-1:-1:-1;;;;;49072:19:0;;;49078:13;;49072:19;;48960:131;48938:411;;;-1:-1:-1;;;;;28273:18:0;;49126:15;28273:18;;;;;;;;;;;49226:15;;49206:16;49216:6;28273:18;49206:16;:::i;:::-;:35;;49176:157;;;;-1:-1:-1;;;49176:157:0;;14939:2:1;49176:157:0;;;14921:21:1;14978:2;14958:18;;;14951:30;15017:34;14997:18;;;14990:62;-1:-1:-1;;;15068:18:1;;;15061:46;15124:19;;49176:157:0;14737:412:1;49176:157:0;49107:242;48938:411;49372:33;49388:4;49394:2;49398:6;49372:15;:33::i;:::-;46748:2665;;;;;46635:2778;;;:::o;38114:166::-;38022:6;;-1:-1:-1;;;;;38022:6:0;24732:10;38174:23;38170:103;;38221:40;;-1:-1:-1;;;38221:40:0;;24732:10;38221:40;;;1569:51:1;1542:18;;38221:40:0;1397:229:1;33281:211:0;-1:-1:-1;;;;;33352:21:0;;33348:91;;33397:30;;-1:-1:-1;;;33397:30:0;;33424:1;33397:30;;;1569:51:1;1542:18;;33397:30:0;1397:229:1;33348:91:0;33449:35;33457:7;33474:1;33478:5;33449:7;:35::i;:::-;33281:211;;:::o;39262:191::-;39355:6;;;-1:-1:-1;;;;;39372:17:0;;;-1:-1:-1;;;;;;39372:17:0;;;;;;;39405:40;;39355:6;;;39372:17;39355:6;;39405:40;;39336:16;;39405:40;39325:128;39262:191;:::o;43432:171::-;43698:16;;-1:-1:-1;;;;;43698:16:0;24732:10;43496:37;43492:104;;43557:27;;-1:-1:-1;;;43557:27:0;;24732:10;43557:27;;;1569:51:1;1542:18;;43557:27:0;1397:229:1;8768:340:0;8878:6;8854:21;:30;8850:111;;;8908:41;;-1:-1:-1;;;8908:41:0;;8943:4;8908:41;;;1569:51:1;1542:18;;8908:41:0;1397:229:1;8850:111:0;8974:12;8992:9;-1:-1:-1;;;;;8992:14:0;9014:6;8992:33;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8973:52;;;9041:7;9036:65;;9072:17;;-1:-1:-1;;;9072:17:0;;;;;;;;;;;35026:443;-1:-1:-1;;;;;35139:19:0;;35135:91;;35182:32;;-1:-1:-1;;;35182:32:0;;35211:1;35182:32;;;1569:51:1;1542:18;;35182:32:0;1397:229:1;35135:91:0;-1:-1:-1;;;;;35240:21:0;;35236:92;;35285:31;;-1:-1:-1;;;35285:31:0;;35313:1;35285:31;;;1569:51:1;1542:18;;35285:31:0;1397:229:1;35236:92:0;-1:-1:-1;;;;;35338:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;:35;;;35384:78;;;;35435:7;-1:-1:-1;;;;;35419:31:0;35428:5;-1:-1:-1;;;;;35419:31:0;;35444:5;35419:31;;;;1361:25:1;;1349:2;1334:18;;1215:177;35419:31:0;;;;;;;;35026:443;;;;:::o;30612:316::-;-1:-1:-1;;;;;30704:18:0;;30700:88;;30746:30;;-1:-1:-1;;;30746:30:0;;30773:1;30746:30;;;1569:51:1;1542:18;;30746:30:0;1397:229:1;30700:88:0;-1:-1:-1;;;;;30802:16:0;;30798:88;;30842:32;;-1:-1:-1;;;30842:32:0;;30871:1;30842:32;;;1569:51:1;1542:18;;30842:32:0;1397:229:1;30798:88:0;30896:24;30904:4;30910:2;30914:5;30896:7;:24::i;50115:863::-;50266:16;;;50280:1;50266:16;;;;;;;;50208:21;;50183:22;;50266:16;50280:1;50266:16;;;;;;;;;;-1:-1:-1;50266:16:0;50242:40;;50311:4;50293;50298:1;50293:7;;;;;;;;:::i;:::-;-1:-1:-1;;;;;50293:23:0;;;:7;;;;;;;;;;:23;;;;50337:15;;:22;;;-1:-1:-1;;;50337:22:0;;;;:15;;;;;:20;;:22;;;;;50293:7;;50337:22;;;;;:15;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;50327:4;50332:1;50327:7;;;;;;;;:::i;:::-;-1:-1:-1;;;;;50327:32:0;;;:7;;;;;;;;;:32;50372:15;;:196;;-1:-1:-1;;;50372:196:0;;:15;;;:66;;:196;;50453:11;;50372:15;;50495:4;;50522;;50542:15;;50372:196;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;50581:18;50626:14;50602:21;:38;;;;:::i;:::-;50581:59;;50651:29;50729:11;50697:15;;50684:10;:28;;;;:::i;:::-;50683:57;;;;:::i;:::-;50761:16;;50651:89;;-1:-1:-1;50753:58:0;;-1:-1:-1;;;;;50761:16:0;50651:89;50753:35;:58::i;:::-;50830:13;;50822:55;;-1:-1:-1;;;;;50830:13:0;50855:21;50822:32;:55::i;:::-;50908:1;50890:15;:19;50927:43;;;6529:25:1;;;6585:2;6570:18;;6563:34;;;50927:43:0;;6502:18:1;50927:43:0;;;;;;;50172:806;;;;50115:863;:::o;31252:1135::-;-1:-1:-1;;;;;31342:18:0;;31338:552;;31496:5;31480:12;;:21;;;;;;;:::i;:::-;;;;-1:-1:-1;31338:552:0;;-1:-1:-1;31338:552:0;;-1:-1:-1;;;;;31556:15:0;;31534:19;31556:15;;;;;;;;;;;31590:19;;;31586:117;;;31637:50;;-1:-1:-1;;;31637:50:0;;-1:-1:-1;;;;;13008:32:1;;31637:50:0;;;12990:51:1;13057:18;;;13050:34;;;13100:18;;;13093:34;;;12963:18;;31637:50:0;12788:345:1;31586:117:0;-1:-1:-1;;;;;31826:15:0;;:9;:15;;;;;;;;;;31844:19;;;;31826:37;;31338:552;-1:-1:-1;;;;;31906:16:0;;31902:435;;32072:12;:21;;;;;;;31902:435;;;-1:-1:-1;;;;;32288:13:0;;:9;:13;;;;;;;;;;:22;;;;;;31902:435;32369:2;-1:-1:-1;;;;;32354:25:0;32363:4;-1:-1:-1;;;;;32354:25:0;;32373:5;32354:25;;;;1361::1;;1349:2;1334:18;;1215:177;32354:25:0;;;;;;;;31252:1135;;;:::o;14:548:1:-;126:4;155:2;184;173:9;166:21;216:6;210:13;259:6;254:2;243:9;239:18;232:34;284:1;294:140;308:6;305:1;302:13;294:140;;;403:14;;;399:23;;393:30;369:17;;;388:2;365:26;358:66;323:10;;294:140;;;298:3;483:1;478:2;469:6;458:9;454:22;450:31;443:42;553:2;546;542:7;537:2;529:6;525:15;521:29;510:9;506:45;502:54;494:62;;;;14:548;;;;:::o;567:131::-;-1:-1:-1;;;;;642:31:1;;632:42;;622:70;;688:1;685;678:12;703:315;771:6;779;832:2;820:9;811:7;807:23;803:32;800:52;;;848:1;845;838:12;800:52;887:9;874:23;906:31;931:5;906:31;:::i;:::-;956:5;1008:2;993:18;;;;980:32;;-1:-1:-1;;;703:315:1:o;1631:456::-;1708:6;1716;1724;1777:2;1765:9;1756:7;1752:23;1748:32;1745:52;;;1793:1;1790;1783:12;1745:52;1832:9;1819:23;1851:31;1876:5;1851:31;:::i;:::-;1901:5;-1:-1:-1;1958:2:1;1943:18;;1930:32;1971:33;1930:32;1971:33;:::i;:::-;1631:456;;2023:7;;-1:-1:-1;;;2077:2:1;2062:18;;;;2049:32;;1631:456::o;2092:118::-;2178:5;2171:13;2164:21;2157:5;2154:32;2144:60;;2200:1;2197;2190:12;2215:241;2271:6;2324:2;2312:9;2303:7;2299:23;2295:32;2292:52;;;2340:1;2337;2330:12;2292:52;2379:9;2366:23;2398:28;2420:5;2398:28;:::i;:::-;2445:5;2215:241;-1:-1:-1;;;2215:241:1:o;2650:180::-;2709:6;2762:2;2750:9;2741:7;2737:23;2733:32;2730:52;;;2778:1;2775;2768:12;2730:52;-1:-1:-1;2801:23:1;;2650:180;-1:-1:-1;2650:180:1:o;3043:247::-;3102:6;3155:2;3143:9;3134:7;3130:23;3126:32;3123:52;;;3171:1;3168;3161:12;3123:52;3210:9;3197:23;3229:31;3254:5;3229:31;:::i;3295:248::-;3363:6;3371;3424:2;3412:9;3403:7;3399:23;3395:32;3392:52;;;3440:1;3437;3430:12;3392:52;-1:-1:-1;;3463:23:1;;;3533:2;3518:18;;;3505:32;;-1:-1:-1;3295:248:1:o;3548:382::-;3613:6;3621;3674:2;3662:9;3653:7;3649:23;3645:32;3642:52;;;3690:1;3687;3680:12;3642:52;3729:9;3716:23;3748:31;3773:5;3748:31;:::i;:::-;3798:5;-1:-1:-1;3855:2:1;3840:18;;3827:32;3868:30;3827:32;3868:30;:::i;:::-;3917:7;3907:17;;;3548:382;;;;;:::o;3935:388::-;4003:6;4011;4064:2;4052:9;4043:7;4039:23;4035:32;4032:52;;;4080:1;4077;4070:12;4032:52;4119:9;4106:23;4138:31;4163:5;4138:31;:::i;:::-;4188:5;-1:-1:-1;4245:2:1;4230:18;;4217:32;4258:33;4217:32;4258:33;:::i;4328:380::-;4407:1;4403:12;;;;4450;;;4471:61;;4525:4;4517:6;4513:17;4503:27;;4471:61;4578:2;4570:6;4567:14;4547:18;4544:38;4541:161;;4624:10;4619:3;4615:20;4612:1;4605:31;4659:4;4656:1;4649:15;4687:4;4684:1;4677:15;4541:161;;4328:380;;;:::o;5948:402::-;6150:2;6132:21;;;6189:2;6169:18;;;6162:30;6228:34;6223:2;6208:18;;6201:62;-1:-1:-1;;;6294:2:1;6279:18;;6272:36;6340:3;6325:19;;5948:402::o;7796:251::-;7866:6;7919:2;7907:9;7898:7;7894:23;7890:32;7887:52;;;7935:1;7932;7925:12;7887:52;7967:9;7961:16;7986:31;8011:5;7986:31;:::i;8640:245::-;8707:6;8760:2;8748:9;8739:7;8735:23;8731:32;8728:52;;;8776:1;8773;8766:12;8728:52;8808:9;8802:16;8827:28;8849:5;8827:28;:::i;9502:306::-;9590:6;9598;9606;9659:2;9647:9;9638:7;9634:23;9630:32;9627:52;;;9675:1;9672;9665:12;9627:52;9704:9;9698:16;9688:26;;9754:2;9743:9;9739:18;9733:25;9723:35;;9798:2;9787:9;9783:18;9777:25;9767:35;;9502:306;;;;;:::o;9813:127::-;9874:10;9869:3;9865:20;9862:1;9855:31;9905:4;9902:1;9895:15;9929:4;9926:1;9919:15;9945:217;9985:1;10011;10001:132;;10055:10;10050:3;10046:20;10043:1;10036:31;10090:4;10087:1;10080:15;10118:4;10115:1;10108:15;10001:132;-1:-1:-1;10147:9:1;;9945:217::o;12599:184::-;12669:6;12722:2;12710:9;12701:7;12697:23;12693:32;12690:52;;;12738:1;12735;12728:12;12690:52;-1:-1:-1;12761:16:1;;12599:184;-1:-1:-1;12599:184:1:o;14301:125::-;14366:9;;;14387:10;;;14384:36;;;14400:18;;:::i;14431:168::-;14504:9;;;14535;;14552:15;;;14546:22;;14532:37;14522:71;;14573:18;;:::i;14604:128::-;14671:9;;;14692:11;;;14689:37;;;14706:18;;:::i;15496:127::-;15557:10;15552:3;15548:20;15545:1;15538:31;15588:4;15585:1;15578:15;15612:4;15609:1;15602:15;15628:980;15890:4;15938:3;15927:9;15923:19;15969:6;15958:9;15951:25;15995:2;16033:6;16028:2;16017:9;16013:18;16006:34;16076:3;16071:2;16060:9;16056:18;16049:31;16100:6;16135;16129:13;16166:6;16158;16151:22;16204:3;16193:9;16189:19;16182:26;;16243:2;16235:6;16231:15;16217:29;;16264:1;16274:195;16288:6;16285:1;16282:13;16274:195;;;16353:13;;-1:-1:-1;;;;;16349:39:1;16337:52;;16444:15;;;;16409:12;;;;16385:1;16303:9;16274:195;;;-1:-1:-1;;;;;;;16525:32:1;;;;16520:2;16505:18;;16498:60;-1:-1:-1;;;16589:3:1;16574:19;16567:35;16486:3;15628:980;-1:-1:-1;;;15628:980:1:o
Swarm Source
ipfs://5ef9712a5927bda18c23ecfd0ee0a20bebe3686780547ab6a8fd63a83fd8f309
Loading...
Loading
Loading...
Loading
[ Download: CSV Export ]
[ Download: CSV Export ]
A token is a representation of an on-chain or off-chain asset. The token page shows information such as price, total supply, holders, transfers and social links. Learn more about this page in our Knowledge Base.