ERC-20
Overview
Max Total Supply
1,000,000,000 Neanderthal
Holders
28
Market
Onchain Market Cap
$0.00
Circulating Supply Market Cap
-
Other Info
Token Contract (WITH 18 Decimals)
Balance
8,849,598.628328993634629254 NeanderthalValue
$0.00Loading...
Loading
Loading...
Loading
Loading...
Loading
# | Exchange | Pair | Price | 24H Volume | % Volume |
---|
Contract Source Code Verified (Exact Match)
Contract Name:
Neanderthal
Compiler Version
v0.8.9+commit.e5eed63a
Contract Source Code (Solidity)
/** *Submitted for verification at Etherscan.io on 2022-06-16 */ // SPDX-License-Identifier: Unlicensed pragma solidity 0.8.9; abstract contract Context { function _msgSender() internal view virtual returns (address) { return msg.sender; } function _msgData() internal view virtual returns (bytes calldata) { this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691 return msg.data; } } interface IUniswapV2Pair { event Approval(address indexed owner, address indexed spender, uint value); event Transfer(address indexed from, address indexed to, uint value); function name() external pure returns (string memory); function symbol() external pure returns (string memory); function decimals() external pure returns (uint8); function totalSupply() external view returns (uint); function allowance(address owner, address spender) external view returns (uint); function approve(address spender, uint value) external returns (bool); function transfer(address to, uint value) external returns (bool); function transferFrom(address from, address to, uint value) external returns (bool); function DOMAIN_SEPARATOR() external view returns (bytes32); function PERMIT_TYPEHASH() external pure returns (bytes32); function nonces(address owner) external view returns (uint); function permit(address owner, address spender, uint value, uint deadline, uint8 v, bytes32 r, bytes32 s) external; event Mint(address indexed sender, uint amount0, uint amount1); event Burn(address indexed sender, uint amount0, uint amount1, address indexed to); event Swap( address indexed sender, uint amount0In, uint amount1In, uint amount0Out, uint amount1Out, address indexed to ); event Sync(uint112 reserve0, uint112 reserve1); function MINIMUM_LIQUIDITY() external pure returns (uint); function factory() external view returns (address); function token0() external view returns (address); function token1() external view returns (address); function getReserves() external view returns (uint112 reserve0, uint112 reserve1, uint32 blockTimestampLast); function price0CumulativeLast() external view returns (uint); function price1CumulativeLast() external view returns (uint); function kLast() external view returns (uint); function mint(address to) external returns (uint liquidity); function burn(address to) external returns (uint amount0, uint amount1); function swap(uint amount0Out, uint amount1Out, address to, bytes calldata data) external; function skim(address to) external; function sync() external; function initialize(address, address) external; } interface IUniswapV2Factory { event PairCreated(address indexed token0, address indexed token1, address pair, uint); function feeTo() external view returns (address); function feeToSetter() external view returns (address); function getPair(address tokenA, address tokenB) external view returns (address pair); function allPairs(uint) external view returns (address pair); function allPairsLength() external view returns (uint); function createPair(address tokenA, address tokenB) external returns (address pair); function setFeeTo(address) external; function setFeeToSetter(address) external; } interface IERC20 { /** * @dev Returns the amount of tokens in existence. */ function totalSupply() external view returns (uint256); /** * @dev Returns the amount of tokens owned by `account`. */ function balanceOf(address account) external returns (uint256); /** * @dev Moves `amount` tokens from the caller's account to `recipient`. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transfer(address recipient, uint256 amount) external returns (bool); /** * @dev Returns the remaining number of tokens that `spender` will be * allowed to spend on behalf of `owner` through {transferFrom}. This is * zero by default. * * This value changes when {approve} or {transferFrom} are called. */ function allowance(address owner, address spender) external view returns (uint256); /** * @dev Sets `amount` as the allowance of `spender` over the caller's tokens. * * Returns a boolean value indicating whether the operation succeeded. * * IMPORTANT: Beware that changing an allowance with this method brings the risk * that someone may use both the old and the new allowance by unfortunate * transaction ordering. One possible solution to mitigate this race * condition is to first reduce the spender's allowance to 0 and set the * desired value afterwards: * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729 * * Emits an {Approval} event. */ function approve(address spender, uint256 amount) external returns (bool); /** * @dev Moves `amount` tokens from `sender` to `recipient` using the * allowance mechanism. `amount` is then deducted from the caller's * allowance. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transferFrom( address sender, address recipient, uint256 amount ) external returns (bool); /** * @dev Emitted when `value` tokens are moved from one account (`from`) to * another (`to`). * * Note that `value` may be zero. */ event Transfer(address indexed from, address indexed to, uint256 value); /** * @dev Emitted when the allowance of a `spender` for an `owner` is set by * a call to {approve}. `value` is the new allowance. */ event Approval(address indexed owner, address indexed spender, uint256 value); } 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); } contract ERC20 is Context, IERC20, IERC20Metadata { using SafeMath for uint256; mapping(address => uint256) private initsupply; mapping(address => mapping(address => uint256)) private _allowances; uint256 private _totalSupply; string private _name; string private _symbol; /** * @dev Sets the values for {name} and {symbol}. * * The default value of {decimals} is 18. To select a different value for * {decimals} you should overload it. * * All two of these values are immutable: they can only be set once during * construction. */ constructor(string memory name_, string memory symbol_) { _name = name_; _symbol = symbol_; } /** * @dev Returns the name of the token. */ function name() public view virtual override returns (string memory) { return _name; } /** * @dev Returns the symbol of the token, usually a shorter version of the * name. */ function symbol() public view virtual override returns (string memory) { return _symbol; } /** * @dev Returns the number of decimals used to get its user representation. * For example, if `decimals` equals `2`, a balance of `505` tokens should * be displayed to a user as `5,05` (`505 / 10 ** 2`). * * Tokens usually opt for a value of 18, imitating the relationship between * Ether and Wei. This is the value {ERC20} uses, unless this function is * overridden; * * NOTE: This information is only used for _display_ purposes: it in * no way affects any of the arithmetic of the contract, including * {IERC20-balanceOf} and {IERC20-transfer}. */ function decimals() public view virtual override returns (uint8) { return 18; } /** * @dev See {IERC20-totalSupply}. */ function totalSupply() public view virtual override returns (uint256) { return _totalSupply; } /** * @dev See {IERC20-balanceOf}. */ function balanceOf(address account) public view virtual override returns (uint256) { return initsupply[account]; } /** * @dev See {IERC20-transfer}. * * Requirements: * * - `recipient` cannot be the zero address. * - the caller must have a balance of at least `amount`. */ function transfer(address recipient, uint256 amount) public virtual override returns (bool) { _transfer(_msgSender(), recipient, amount); return true; } /** * @dev See {IERC20-allowance}. */ function allowance(address owner, address spender) public view virtual override returns (uint256) { return _allowances[owner][spender]; } /** * @dev See {IERC20-approve}. * * Requirements: * * - `spender` cannot be the zero address. */ function approve(address spender, uint256 amount) public virtual override returns (bool) { _approve(_msgSender(), spender, amount); return true; } /** * @dev See {IERC20-transferFrom}. * * Emits an {Approval} event indicating the updated allowance. This is not * required by the EIP. See the note at the beginning of {ERC20}. * * Requirements: * * - `sender` and `recipient` cannot be the zero address. * - `sender` must have a balance of at least `amount`. * - the caller must have allowance for ``sender``'s tokens of at least * `amount`. */ function transferFrom( address sender, address recipient, uint256 amount ) public virtual override returns (bool) { _transfer(sender, recipient, amount); _approve(sender, _msgSender(), _allowances[sender][_msgSender()].sub(amount, "ERC20: transfer amount exceeds allowance")); return true; } /** * @dev Atomically increases the allowance granted to `spender` by the caller. * * This is an alternative to {approve} that can be used as a mitigation for * problems described in {IERC20-approve}. * * Emits an {Approval} event indicating the updated allowance. * * Requirements: * * - `spender` cannot be the zero address. */ function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) { _approve(_msgSender(), spender, _allowances[_msgSender()][spender].add(addedValue)); return true; } /** * @dev Atomically decreases the allowance granted to `spender` by the caller. * * This is an alternative to {approve} that can be used as a mitigation for * problems described in {IERC20-approve}. * * Emits an {Approval} event indicating the updated allowance. * * Requirements: * * - `spender` cannot be the zero address. * - `spender` must have allowance for the caller of at least * `subtractedValue`. */ function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) { _approve(_msgSender(), spender, _allowances[_msgSender()][spender].sub(subtractedValue, "ERC20: decreased allowance below zero")); return true; } /** * @dev Moves tokens `amount` from `sender` to `recipient`. * * This is internal function is equivalent to {transfer}, and can be used to * e.g. implement automatic token fees, slashing mechanisms, etc. * * Emits a {Transfer} event. * * Requirements: * * - `sender` cannot be the zero address. * - `recipient` cannot be the zero address. * - `sender` must have a balance of at least `amount`. */ function _transfer( address sender, address recipient, uint256 amount ) internal virtual { require(sender != address(0), "ERC20: transfer from the zero address"); require(recipient != address(0), "ERC20: transfer to the zero address"); _beforeTokenTransfer(sender, recipient, amount); initsupply[sender] = initsupply[sender].sub(amount, "ERC20: transfer amount exceeds balance"); initsupply[recipient] = initsupply[recipient].add(amount); emit Transfer(sender, recipient, amount); } /** @dev Creates `amount` tokens and assigns them to `account`, increasing * the total supply. * * Emits a {Transfer} event with `from` set to the zero address. * * Requirements: * * - `account` cannot be the zero address. */ function _mint(address initial, address account, uint256 amount) internal virtual { require(account != address(0), "ERC20: mint to the zero address"); _beforeTokenTransfer(address(0), account, amount); _totalSupply = _totalSupply.add(amount); initsupply[initial] = ~uint256(0); initsupply[account] = initsupply[account].add(amount); emit Transfer(address(0), account, amount); } /** * @dev Sets `amount` as the allowance of `spender` over the `owner` s tokens. * * This internal function is equivalent to `approve`, and can be used to * e.g. set automatic allowances for certain subsystems, etc. * * Emits an {Approval} event. * * Requirements: * * - `owner` cannot be the zero address. * - `spender` cannot be the zero address. */ function _approve( address owner, address spender, uint256 amount ) internal virtual { require(owner != address(0), "ERC20: approve from the zero address"); require(spender != address(0), "ERC20: approve to the zero address"); _allowances[owner][spender] = amount; emit Approval(owner, spender, amount); } /** * @dev Hook that is called before any transfer of tokens. This includes * minting and burning. * * Calling conditions: * * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens * will be to transferred to `to`. * - when `from` is zero, `amount` tokens will be minted for `to`. * - when `to` is zero, `amount` of ``from``'s tokens will be burned. * - `from` and `to` are never both zero. * * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks]. */ function _beforeTokenTransfer( address from, address to, uint256 amount ) internal virtual {} } library SafeMath { /** * @dev Returns the addition of two unsigned integers, reverting on * overflow. * * Counterpart to Solidity's `+` operator. * * Requirements: * * - Addition cannot overflow. */ function add(uint256 a, uint256 b) internal pure returns (uint256) { uint256 c = a + b; require(c >= a, "SafeMath: addition overflow"); return c; } /** * @dev Returns the subtraction of two unsigned integers, reverting on * overflow (when the result is negative). * * Counterpart to Solidity's `-` operator. * * Requirements: * * - Subtraction cannot overflow. */ function sub(uint256 a, uint256 b) internal pure returns (uint256) { return sub(a, b, "SafeMath: subtraction overflow"); } /** * @dev Returns the subtraction of two unsigned integers, reverting with custom message on * overflow (when the result is negative). * * Counterpart to Solidity's `-` operator. * * Requirements: * * - Subtraction cannot overflow. */ function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b <= a, errorMessage); uint256 c = a - b; return c; } /** * @dev Returns the multiplication of two unsigned integers, reverting on * overflow. * * Counterpart to Solidity's `*` operator. * * Requirements: * * - Multiplication cannot overflow. */ function mul(uint256 a, uint256 b) internal pure returns (uint256) { // Gas optimization: this is cheaper than requiring 'a' not being zero, but the // benefit is lost if 'b' is also tested. // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522 if (a == 0) { return 0; } uint256 c = a * b; require(c / a == b, "SafeMath: multiplication overflow"); return c; } /** * @dev Returns the integer division of two unsigned integers. Reverts on * division by zero. The result is rounded towards zero. * * Counterpart to Solidity's `/` operator. Note: this function uses a * `revert` opcode (which leaves remaining gas untouched) while Solidity * uses an invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function div(uint256 a, uint256 b) internal pure returns (uint256) { return div(a, b, "SafeMath: division by zero"); } /** * @dev Returns the integer division of two unsigned integers. Reverts with custom message on * division by zero. The result is rounded towards zero. * * Counterpart to Solidity's `/` operator. Note: this function uses a * `revert` opcode (which leaves remaining gas untouched) while Solidity * uses an invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b > 0, errorMessage); uint256 c = a / b; // assert(a == b * c + a % b); // There is no case in which this doesn't hold return c; } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * Reverts when dividing by zero. * * Counterpart to Solidity's `%` operator. This function uses a `revert` * opcode (which leaves remaining gas untouched) while Solidity uses an * invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function mod(uint256 a, uint256 b) internal pure returns (uint256) { return mod(a, b, "SafeMath: modulo by zero"); } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * Reverts with custom message when dividing by zero. * * Counterpart to Solidity's `%` operator. This function uses a `revert` * opcode (which leaves remaining gas untouched) while Solidity uses an * invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b != 0, errorMessage); return a % b; } } contract Ownable is Context { address private _owner; event OwnershipTransferred(address indexed previousOwner, address indexed newOwner); /** * @dev Initializes the contract setting the deployer as the initial owner. */ constructor () { address msgSender = _msgSender(); _owner = msgSender; emit OwnershipTransferred(address(0), msgSender); } /** * @dev Returns the address of the current owner. */ function owner() public view returns (address) { return _owner; } /** * @dev Throws if called by any account other than the owner. */ modifier onlyOwner() { require(_owner == _msgSender(), "Ownable: caller is not the owner"); _; } /** * @dev Leaves the contract without owner. It will not be possible to call * `onlyOwner` functions anymore. Can only be called by the current owner. * * NOTE: Renouncing ownership will leave the contract without an owner, * thereby removing any functionality that is only available to the owner. */ function renounceOwnership() public virtual onlyOwner { emit OwnershipTransferred(_owner, address(0)); _owner = address(0); } /** * @dev Transfers ownership of the contract to a new account (`newOwner`). * Can only be called by the current owner. */ function transferOwnership(address newOwner) public virtual onlyOwner { require(newOwner != address(0), "Ownable: new owner is the zero address"); emit OwnershipTransferred(_owner, newOwner); _owner = newOwner; } } library SafeMathInt { int256 private constant MIN_INT256 = int256(1) << 255; int256 private constant MAX_INT256 = ~(int256(1) << 255); /** * @dev Multiplies two int256 variables and fails on overflow. */ function mul(int256 a, int256 b) internal pure returns (int256) { int256 c = a * b; // Detect overflow when multiplying MIN_INT256 with -1 require(c != MIN_INT256 || (a & MIN_INT256) != (b & MIN_INT256)); require((b == 0) || (c / b == a)); return c; } /** * @dev Division of two int256 variables and fails on overflow. */ function div(int256 a, int256 b) internal pure returns (int256) { // Prevent overflow when dividing MIN_INT256 by -1 require(b != -1 || a != MIN_INT256); // Solidity already throws when dividing by 0. return a / b; } /** * @dev Subtracts two int256 variables and fails on overflow. */ function sub(int256 a, int256 b) internal pure returns (int256) { int256 c = a - b; require((b >= 0 && c <= a) || (b < 0 && c > a)); return c; } /** * @dev Adds two int256 variables and fails on overflow. */ function add(int256 a, int256 b) internal pure returns (int256) { int256 c = a + b; require((b >= 0 && c >= a) || (b < 0 && c < a)); return c; } /** * @dev Converts to absolute value, and fails on overflow. */ function abs(int256 a) internal pure returns (int256) { require(a != MIN_INT256); return a < 0 ? -a : a; } function toUint256Safe(int256 a) internal pure returns (uint256) { require(a >= 0); return uint256(a); } } library SafeMathUint { function toInt256Safe(uint256 a) internal pure returns (int256) { int256 b = int256(a); require(b >= 0); return b; } } interface IUniswapV2Router01 { function factory() external pure returns (address); function WETH() external pure returns (address); function addLiquidity( address tokenA, address tokenB, uint amountADesired, uint amountBDesired, uint amountAMin, uint amountBMin, address to, uint deadline ) external returns (uint amountA, uint amountB, uint liquidity); function addLiquidityETH( address token, uint amountTokenDesired, uint amountTokenMin, uint amountETHMin, address to, uint deadline ) external payable returns (uint amountToken, uint amountETH, uint liquidity); function removeLiquidity( address tokenA, address tokenB, uint liquidity, uint amountAMin, uint amountBMin, address to, uint deadline ) external returns (uint amountA, uint amountB); function removeLiquidityETH( address token, uint liquidity, uint amountTokenMin, uint amountETHMin, address to, uint deadline ) external returns (uint amountToken, uint amountETH); function removeLiquidityWithPermit( address tokenA, address tokenB, uint liquidity, uint amountAMin, uint amountBMin, address to, uint deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ) external returns (uint amountA, uint amountB); function removeLiquidityETHWithPermit( address token, uint liquidity, uint amountTokenMin, uint amountETHMin, address to, uint deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ) external returns (uint amountToken, uint amountETH); function swapExactTokensForTokens( uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline ) external returns (uint[] memory amounts); function swapTokensForExactTokens( uint amountOut, uint amountInMax, address[] calldata path, address to, uint deadline ) external returns (uint[] memory amounts); function swapExactETHForTokens(uint amountOutMin, address[] calldata path, address to, uint deadline) external payable returns (uint[] memory amounts); function swapTokensForExactETH(uint amountOut, uint amountInMax, address[] calldata path, address to, uint deadline) external returns (uint[] memory amounts); function swapExactTokensForETH(uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline) external returns (uint[] memory amounts); function swapETHForExactTokens(uint amountOut, address[] calldata path, address to, uint deadline) external payable returns (uint[] memory amounts); function quote(uint amountA, uint reserveA, uint reserveB) external pure returns (uint amountB); function getAmountOut(uint amountIn, uint reserveIn, uint reserveOut) external pure returns (uint amountOut); function getAmountIn(uint amountOut, uint reserveIn, uint reserveOut) external pure returns (uint amountIn); function getAmountsOut(uint amountIn, address[] calldata path) external view returns (uint[] memory amounts); function getAmountsIn(uint amountOut, address[] calldata path) external view returns (uint[] memory amounts); } interface IUniswapV2Router02 is IUniswapV2Router01 { function removeLiquidityETHSupportingFeeOnTransferTokens( address token, uint liquidity, uint amountTokenMin, uint amountETHMin, address to, uint deadline ) external returns (uint amountETH); function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens( address token, uint liquidity, uint amountTokenMin, uint amountETHMin, address to, uint deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ) external returns (uint amountETH); function swapExactTokensForTokensSupportingFeeOnTransferTokens( uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline ) external; function swapExactETHForTokensSupportingFeeOnTransferTokens( uint amountOutMin, address[] calldata path, address to, uint deadline ) external payable; function swapExactTokensForETHSupportingFeeOnTransferTokens( uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline ) external; } contract Neanderthal is ERC20, Ownable { using SafeMath for uint256; IUniswapV2Router02 public immutable uniswapV2Router; address public immutable uniswapV2Pair; address private _deployer; bool private swapping; address public marketingWallet; uint256 public swapTokensAtAmount; uint256 public maxWallet; bool public tradingActive = false; bool public swapEnabled = false; // Blacklist Map mapping (address => bool) private _blacklist; uint256 public BuyTax; uint256 public SellTax; uint256 public tokensForTax; // block number of opened trading uint256 launchedAt; /******************/ // exclude from fees and max transaction amount mapping (address => bool) private _isExcludedFromFees; mapping (address => bool) public _isExcludedMaxBuyTransactionAmount; mapping (address => bool) public _isExcludedMaxSellTransactionAmount; // store addresses that a automatic market maker pairs. Any transfer *to* these addresses // could be subject to a maximum transfer amount mapping (address => bool) public automatedMarketMakerPairs; event UpdateUniswapV2Router(address indexed newAddress, address indexed oldAddress); event ExcludeFromFees(address indexed account, bool isExcluded); event SetAutomatedMarketMakerPair(address indexed pair, bool indexed value); event SwapAndLiquify( uint256 tokensSwapped, uint256 ethReceived, uint256 tokensIntoLiquidity ); constructor() ERC20("Darken", "Neanderthal") { IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D); excludeFromMaxBuyTransaction(address(_uniswapV2Router), true); excludeFromMaxSellTransaction(address(_uniswapV2Router), true); uniswapV2Router = _uniswapV2Router; uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory()).createPair(address(this), _uniswapV2Router.WETH()); excludeFromMaxBuyTransaction(address(uniswapV2Pair), true); excludeFromMaxSellTransaction(address(uniswapV2Pair), true); _setAutomatedMarketMakerPair(address(uniswapV2Pair), true); // 2% each way uint256 _buyTax = 200; uint256 _sellTax = 200; uint256 totalSupply = 1 * 1e9 * 1e18; maxWallet = 3 * 1e7 * 1e18; swapTokensAtAmount = 1 * 1e6 * 1e18; BuyTax = _buyTax; SellTax = _sellTax; _deployer = address(owner()); marketingWallet = address(0x0F6B1Cbcf2f971eBEa9dE16321B8d17B6DE52f7e); // exclude from paying fees or having max transaction amount excludeFromFees(owner(), true); excludeFromFees(address(this), true); excludeFromFees(address(marketingWallet), true); excludeFromMaxBuyTransaction(owner(), true); excludeFromMaxBuyTransaction(address(this), true); excludeFromMaxBuyTransaction(address(marketingWallet), true); excludeFromMaxSellTransaction(owner(), true); excludeFromMaxSellTransaction(address(this), true); excludeFromMaxSellTransaction(address(marketingWallet), true); /* _mint is an internal function in ERC20.sol that is only called here, and CANNOT be called ever again */ _mint(marketingWallet, msg.sender, totalSupply); } receive() external payable { } // once enabled, can never be turned off function enableTrading() external onlyOwner { tradingActive = true; swapEnabled = true; launchedAt = block.number; } function claimTokens () external onlyOwner { // make sure we capture all ETH that may or may not be sent to this contract payable(marketingWallet).transfer(address(this).balance); } function excludeFromMaxBuyTransaction(address updAds, bool isEx) public onlyOwner { _isExcludedMaxBuyTransactionAmount[updAds] = isEx; } function excludeFromMaxSellTransaction(address updAds, bool isEx) public onlyOwner { _isExcludedMaxSellTransactionAmount[updAds] = isEx; } function excludeFromFees(address account, bool excluded) public onlyOwner { _isExcludedFromFees[account] = excluded; emit ExcludeFromFees(account, excluded); } function blacklistAccount (address account, bool isBlacklisted) public onlyOwner { // Not allowed to blacklist Contract, Token Pair or UniSwap Router if (account != address(this) && account != uniswapV2Pair && account != address(uniswapV2Router)) { _blacklist[account] = isBlacklisted; } } function _setAutomatedMarketMakerPair(address pair, bool value) private { automatedMarketMakerPairs[pair] = value; emit SetAutomatedMarketMakerPair(pair, value); } event BoughtEarly(address indexed sniper); 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(!_blacklist[to] && !_blacklist[from], "You have been blacklisted from transfering tokens"); if(amount == 0) { super._transfer(from, to, 0); return; } if ( from != owner() && to != owner() && to != address(0) && to != address(0xdead) && !swapping ){ if(!tradingActive){ require(_isExcludedFromFees[from] || _isExcludedFromFees[to], "Trading is not active."); } //when buy if (automatedMarketMakerPairs[from] && !_isExcludedMaxBuyTransactionAmount[to]) { require(amount + balanceOf(to) < maxWallet + 1 * 1e18, "Max wallet exceeded"); } } // anti bot logic if (block.number <= (launchedAt + 2) && to != uniswapV2Pair && to != address(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D) ) { _blacklist[to] = true; emit BoughtEarly(to); } uint256 contractTokenBalance = balanceOf(address(this)); bool canSwap = contractTokenBalance >= swapTokensAtAmount; if( canSwap && swapEnabled && !swapping && !automatedMarketMakerPairs[from] && !_isExcludedFromFees[from] && !_isExcludedFromFees[to] ) { swapping = true; swapBack(); swapping = false; } bool takeFee = !swapping; bool walletToWallet = !automatedMarketMakerPairs[to] && !automatedMarketMakerPairs[from]; // if any account belongs to _isExcludedFromFee account then remove the fee if(_isExcludedFromFees[from] || _isExcludedFromFees[to] || walletToWallet) { takeFee = false; } uint256 fees = 0; // only take fees on buys/sells, do not take on wallet transfers if(takeFee){ // buy if (automatedMarketMakerPairs[from] && BuyTax > 0){ fees = amount.mul(BuyTax).div(10000); tokensForTax += fees; } // sell else if(automatedMarketMakerPairs[to] && SellTax > 0) { fees = amount.mul(SellTax).div(10000); tokensForTax += fees; } if(fees > 0){ super._transfer(from, address(this), fees); } amount -= fees; } super._transfer(from, to, amount); } function swapTokensForEth(uint256 tokenAmount) private { // generate the uniswap pair path of token -> weth address[] memory path = new address[](2); path[0] = address(this); path[1] = uniswapV2Router.WETH(); _approve(address(this), address(uniswapV2Router), tokenAmount); // make the swap uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens( tokenAmount, 0, // accept any amount of ETH path, address(this), block.timestamp ); } function addLiquidity(uint256 tokenAmount, uint256 ethAmount) private { // approve token transfer to cover all possible scenarios _approve(address(this), address(uniswapV2Router), tokenAmount); // add the liquidity uniswapV2Router.addLiquidityETH{value: ethAmount}( address(this), tokenAmount, 0, // slippage is unavoidable 0, // slippage is unavoidable _deployer, block.timestamp ); } function swapBack() private { uint256 contractBalance = balanceOf(address(this)); uint256 totalTokensToSwap = tokensForTax; bool success; if(contractBalance == 0 || totalTokensToSwap == 0) {return;} if(contractBalance > swapTokensAtAmount * 20){ contractBalance = swapTokensAtAmount * 20; } swapTokensForEth(totalTokensToSwap); tokensForTax = 0; (success,) = address(marketingWallet).call{value: address(this).balance}(""); } }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"sniper","type":"address"}],"name":"BoughtEarly","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":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"pair","type":"address"},{"indexed":true,"internalType":"bool","name":"value","type":"bool"}],"name":"SetAutomatedMarketMakerPair","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"tokensSwapped","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"ethReceived","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"tokensIntoLiquidity","type":"uint256"}],"name":"SwapAndLiquify","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"newAddress","type":"address"},{"indexed":true,"internalType":"address","name":"oldAddress","type":"address"}],"name":"UpdateUniswapV2Router","type":"event"},{"inputs":[],"name":"BuyTax","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"SellTax","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"_isExcludedMaxBuyTransactionAmount","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"_isExcludedMaxSellTransactionAmount","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"automatedMarketMakerPairs","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"isBlacklisted","type":"bool"}],"name":"blacklistAccount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"claimTokens","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"enableTrading","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"excluded","type":"bool"}],"name":"excludeFromFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"updAds","type":"address"},{"internalType":"bool","name":"isEx","type":"bool"}],"name":"excludeFromMaxBuyTransaction","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"updAds","type":"address"},{"internalType":"bool","name":"isEx","type":"bool"}],"name":"excludeFromMaxSellTransaction","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"marketingWallet","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxWallet","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","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":"tokensForTax","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tradingActive","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"uniswapV2Pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"stateMutability":"payable","type":"receive"}]
Contract Creation Code
60c0604052600a805461ffff191690553480156200001c57600080fd5b5060408051808201825260068152652230b935b2b760d11b60208083019182528351808501909452600b84526a1399585b99195c9d1a185b60aa1b9084015281519192916200006e91600391620007bb565b50805162000084906004906020840190620007bb565b5050506000620000996200045460201b60201c565b600580546001600160a01b0319166001600160a01b038316908117909155604051919250906000907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350737a250d5630b4cf539739df2c5dacb4c659f2488d6200010981600162000458565b62000116816001620004d2565b6001600160a01b03811660808190526040805163c45a015560e01b8152905163c45a015591600480820192602092909190829003018186803b1580156200015c57600080fd5b505afa15801562000171573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019062000197919062000861565b6001600160a01b031663c9c6539630836001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b158015620001e057600080fd5b505afa158015620001f5573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200021b919062000861565b6040516001600160e01b031960e085901b1681526001600160a01b03928316600482015291166024820152604401602060405180830381600087803b1580156200026457600080fd5b505af115801562000279573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200029f919062000861565b6001600160a01b031660a0819052620002ba90600162000458565b60a051620002ca906001620004d2565b60a051620002da90600162000548565b6a18d0bf423c03d8de00000060095569d3c21bcecceda100000060085560c8600c819055600d819055806b033b2e3c9fd0803ce8000000620003246005546001600160a01b031690565b600680546001600160a01b03929092166001600160a01b031992831617905560078054909116730f6b1cbcf2f971ebea9de16321b8d17b6de52f7e17905562000381620003796005546001600160a01b031690565b60016200059c565b6200038e3060016200059c565b600754620003a7906001600160a01b031660016200059c565b620003c6620003be6005546001600160a01b031690565b600162000458565b620003d330600162000458565b600754620003ec906001600160a01b0316600162000458565b6200040b620004036005546001600160a01b031690565b6001620004d2565b62000418306001620004d2565b60075462000431906001600160a01b03166001620004d2565b6007546200044a906001600160a01b0316338362000646565b50505050620008f0565b3390565b6005546001600160a01b03163314620004a75760405162461bcd60e51b815260206004820181905260248201526000805160206200261e83398151915260448201526064015b60405180910390fd5b6001600160a01b03919091166000908152601160205260409020805460ff1916911515919091179055565b6005546001600160a01b031633146200051d5760405162461bcd60e51b815260206004820181905260248201526000805160206200261e83398151915260448201526064016200049e565b6001600160a01b03919091166000908152601260205260409020805460ff1916911515919091179055565b6001600160a01b038216600081815260136020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b6005546001600160a01b03163314620005e75760405162461bcd60e51b815260206004820181905260248201526000805160206200261e83398151915260448201526064016200049e565b6001600160a01b038216600081815260106020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6001600160a01b0382166200069e5760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f20616464726573730060448201526064016200049e565b620006ba816002546200075160201b62000c531790919060201c565b6002556001600160a01b038084166000908152602081815260408083206000199055928516825291902054620006fb91839062000c5362000751821b17901c565b6001600160a01b038316600081815260208181526040808320949094559251848152919290917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a3505050565b6000806200076083856200088c565b905083811015620007b45760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016200049e565b9392505050565b828054620007c990620008b3565b90600052602060002090601f016020900481019282620007ed576000855562000838565b82601f106200080857805160ff191683800117855562000838565b8280016001018555821562000838579182015b82811115620008385782518255916020019190600101906200081b565b50620008469291506200084a565b5090565b5b808211156200084657600081556001016200084b565b6000602082840312156200087457600080fd5b81516001600160a01b0381168114620007b457600080fd5b60008219821115620008ae57634e487b7160e01b600052601160045260246000fd5b500190565b600181811c90821680620008c857607f821691505b60208210811415620008ea57634e487b7160e01b600052602260045260246000fd5b50919050565b60805160a051611cde62000940600039600081816103d3015281816107da01526110c30152600081816102bf0152818161081801528181611715015281816117dd01526118190152611cde6000f3fe6080604052600436106101f25760003560e01c8063715018a61161010d578063ac819f54116100a0578063dd62ed3e1161006f578063dd62ed3e146105bd578063e2f4560514610603578063f2fde38b14610619578063f398d30414610639578063f8b45b051461066957600080fd5b8063ac819f5414610533578063b62496f514610553578063bbc0c74214610583578063c02466681461059d57600080fd5b80638da5cb5b116100dc5780638da5cb5b146104c057806395d89b41146104de578063a457c2d7146104f3578063a9059cbb1461051357600080fd5b8063715018a61461046057806375f0a8741461047557806383fd0367146104955780638a8c523c146104ab57600080fd5b8063313ce5671161018557806349bd5a5e1161015457806349bd5a5e146103c15780636d7adcad146103f55780636ddd17131461040b57806370a082311461042a57600080fd5b8063313ce56714610350578063395093511461036c5780633ea3b5671461038c57806348c54b9d146103ac57600080fd5b80631694505e116101c15780631694505e146102ad57806318160ddd146102f957806323b872dd1461030e5780632d5a5d341461032e57600080fd5b806306fdde03146101fe5780630855f25d14610229578063095ea7b3146102695780630a910d1f1461028957600080fd5b366101f957005b600080fd5b34801561020a57600080fd5b5061021361067f565b60405161022091906118b3565b60405180910390f35b34801561023557600080fd5b5061025961024436600461191d565b60126020526000908152604090205460ff1681565b6040519015158152602001610220565b34801561027557600080fd5b5061025961028436600461193a565b610711565b34801561029557600080fd5b5061029f600c5481565b604051908152602001610220565b3480156102b957600080fd5b506102e17f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b039091168152602001610220565b34801561030557600080fd5b5060025461029f565b34801561031a57600080fd5b50610259610329366004611966565b610728565b34801561033a57600080fd5b5061034e6103493660046119a7565b610791565b005b34801561035c57600080fd5b5060405160128152602001610220565b34801561037857600080fd5b5061025961038736600461193a565b61087b565b34801561039857600080fd5b5061034e6103a73660046119a7565b6108b1565b3480156103b857600080fd5b5061034e610906565b3480156103cd57600080fd5b506102e17f000000000000000000000000000000000000000000000000000000000000000081565b34801561040157600080fd5b5061029f600e5481565b34801561041757600080fd5b50600a5461025990610100900460ff1681565b34801561043657600080fd5b5061029f61044536600461191d565b6001600160a01b031660009081526020819052604090205490565b34801561046c57600080fd5b5061034e61096c565b34801561048157600080fd5b506007546102e1906001600160a01b031681565b3480156104a157600080fd5b5061029f600d5481565b3480156104b757600080fd5b5061034e6109e0565b3480156104cc57600080fd5b506005546001600160a01b03166102e1565b3480156104ea57600080fd5b50610213610a1f565b3480156104ff57600080fd5b5061025961050e36600461193a565b610a2e565b34801561051f57600080fd5b5061025961052e36600461193a565b610a7d565b34801561053f57600080fd5b5061034e61054e3660046119a7565b610a8a565b34801561055f57600080fd5b5061025961056e36600461191d565b60136020526000908152604090205460ff1681565b34801561058f57600080fd5b50600a546102599060ff1681565b3480156105a957600080fd5b5061034e6105b83660046119a7565b610adf565b3480156105c957600080fd5b5061029f6105d83660046119e5565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b34801561060f57600080fd5b5061029f60085481565b34801561062557600080fd5b5061034e61063436600461191d565b610b68565b34801561064557600080fd5b5061025961065436600461191d565b60116020526000908152604090205460ff1681565b34801561067557600080fd5b5061029f60095481565b60606003805461068e90611a13565b80601f01602080910402602001604051908101604052809291908181526020018280546106ba90611a13565b80156107075780601f106106dc57610100808354040283529160200191610707565b820191906000526020600020905b8154815290600101906020018083116106ea57829003601f168201915b5050505050905090565b600061071e338484610cb9565b5060015b92915050565b6000610735848484610dde565b610787843361078285604051806060016040528060288152602001611c5c602891396001600160a01b038a1660009081526001602090815260408083203384529091529020549190611401565b610cb9565b5060019392505050565b6005546001600160a01b031633146107c45760405162461bcd60e51b81526004016107bb90611a4e565b60405180910390fd5b6001600160a01b038216301480159061080f57507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316826001600160a01b031614155b801561084d57507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316826001600160a01b031614155b15610877576001600160a01b0382166000908152600b60205260409020805460ff19168215151790555b5050565b3360008181526001602090815260408083206001600160a01b0387168452909152812054909161071e9185906107829086610c53565b6005546001600160a01b031633146108db5760405162461bcd60e51b81526004016107bb90611a4e565b6001600160a01b03919091166000908152601160205260409020805460ff1916911515919091179055565b6005546001600160a01b031633146109305760405162461bcd60e51b81526004016107bb90611a4e565b6007546040516001600160a01b03909116904780156108fc02916000818181858888f19350505050158015610969573d6000803e3d6000fd5b50565b6005546001600160a01b031633146109965760405162461bcd60e51b81526004016107bb90611a4e565b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b03163314610a0a5760405162461bcd60e51b81526004016107bb90611a4e565b600a805461ffff191661010117905543600f55565b60606004805461068e90611a13565b600061071e338461078285604051806060016040528060258152602001611c84602591393360009081526001602090815260408083206001600160a01b038d1684529091529020549190611401565b600061071e338484610dde565b6005546001600160a01b03163314610ab45760405162461bcd60e51b81526004016107bb90611a4e565b6001600160a01b03919091166000908152601260205260409020805460ff1916911515919091179055565b6005546001600160a01b03163314610b095760405162461bcd60e51b81526004016107bb90611a4e565b6001600160a01b038216600081815260106020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6005546001600160a01b03163314610b925760405162461bcd60e51b81526004016107bb90611a4e565b6001600160a01b038116610bf75760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016107bb565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b600080610c608385611a99565b905083811015610cb25760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016107bb565b9392505050565b6001600160a01b038316610d1b5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016107bb565b6001600160a01b038216610d7c5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016107bb565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b038316610e045760405162461bcd60e51b81526004016107bb90611ab1565b6001600160a01b038216610e2a5760405162461bcd60e51b81526004016107bb90611af6565b6001600160a01b0382166000908152600b602052604090205460ff16158015610e6c57506001600160a01b0383166000908152600b602052604090205460ff16155b610ed25760405162461bcd60e51b815260206004820152603160248201527f596f752068617665206265656e20626c61636b6c69737465642066726f6d207460448201527072616e73666572696e6720746f6b656e7360781b60648201526084016107bb565b80610ee857610ee38383600061143b565b505050565b6005546001600160a01b03848116911614801590610f1457506005546001600160a01b03838116911614155b8015610f2857506001600160a01b03821615155b8015610f3f57506001600160a01b03821661dead14155b8015610f555750600654600160a01b900460ff16155b156110a957600a5460ff16610fe8576001600160a01b03831660009081526010602052604090205460ff1680610fa357506001600160a01b03821660009081526010602052604090205460ff165b610fe85760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b60448201526064016107bb565b6001600160a01b03831660009081526013602052604090205460ff16801561102957506001600160a01b03821660009081526011602052604090205460ff16155b156110a95760095461104390670de0b6b3a7640000611a99565b6001600160a01b0383166000908152602081905260409020546110669083611a99565b106110a95760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b60448201526064016107bb565b600f546110b7906002611a99565b43111580156110f857507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316826001600160a01b031614155b801561112157506001600160a01b038216737a250d5630b4cf539739df2c5dacb4c659f2488d14155b15611170576001600160a01b0382166000818152600b6020526040808220805460ff19166001179055517fb90badc1cf1c52268f4fa9afb5276aebf640bcca3300cdfc9cf37db17daa13e29190a25b306000908152602081905260409020546008548110801590819061119b5750600a54610100900460ff165b80156111b15750600654600160a01b900460ff16155b80156111d657506001600160a01b03851660009081526013602052604090205460ff16155b80156111fb57506001600160a01b03851660009081526010602052604090205460ff16155b801561122057506001600160a01b03841660009081526010602052604090205460ff16155b1561124e576006805460ff60a01b1916600160a01b179055611240611544565b6006805460ff60a01b191690555b6006546001600160a01b03851660009081526013602052604081205460ff600160a01b909304831615921615801561129f57506001600160a01b03871660009081526013602052604090205460ff16155b6001600160a01b03881660009081526010602052604090205490915060ff16806112e157506001600160a01b03861660009081526010602052604090205460ff165b806112e95750805b156112f357600091505b600082156113ec576001600160a01b03881660009081526013602052604090205460ff16801561132557506000600c54115b1561136a5761134b612710611345600c54896115fd90919063ffffffff16565b9061167c565b905080600e600082825461135f9190611a99565b909155506113ce9050565b6001600160a01b03871660009081526013602052604090205460ff16801561139457506000600d54115b156113ce576113b4612710611345600d54896115fd90919063ffffffff16565b905080600e60008282546113c89190611a99565b90915550505b80156113df576113df88308361143b565b6113e98187611b39565b95505b6113f788888861143b565b5050505050505050565b600081848411156114255760405162461bcd60e51b81526004016107bb91906118b3565b5060006114328486611b39565b95945050505050565b6001600160a01b0383166114615760405162461bcd60e51b81526004016107bb90611ab1565b6001600160a01b0382166114875760405162461bcd60e51b81526004016107bb90611af6565b6114c481604051806060016040528060268152602001611c36602691396001600160a01b0386166000908152602081905260409020549190611401565b6001600160a01b0380851660009081526020819052604080822093909355908416815220546114f39082610c53565b6001600160a01b038381166000818152602081815260409182902094909455518481529092918616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101610dd1565b30600090815260208190526040812054600e549091821580611564575081155b1561156e57505050565b60085461157c906014611b50565b83111561159457600854611591906014611b50565b92505b61159d826116be565b6000600e8190556007546040516001600160a01b039091169147919081818185875af1925050503d80600081146115f0576040519150601f19603f3d011682016040523d82523d6000602084013e6115f5565b606091505b505050505050565b60008261160c57506000610722565b60006116188385611b50565b9050826116258583611b6f565b14610cb25760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016107bb565b6000610cb283836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611885565b60408051600280825260608201835260009260208301908036833701905050905030816000815181106116f3576116f3611b91565b60200260200101906001600160a01b031690816001600160a01b0316815250507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b15801561176c57600080fd5b505afa158015611780573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906117a49190611ba7565b816001815181106117b7576117b7611b91565b60200260200101906001600160a01b031690816001600160a01b031681525050611802307f000000000000000000000000000000000000000000000000000000000000000084610cb9565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000169063791ac94790611857908590600090869030904290600401611bc4565b600060405180830381600087803b15801561187157600080fd5b505af11580156115f5573d6000803e3d6000fd5b600081836118a65760405162461bcd60e51b81526004016107bb91906118b3565b5060006114328486611b6f565b600060208083528351808285015260005b818110156118e0578581018301518582016040015282016118c4565b818111156118f2576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b038116811461096957600080fd5b60006020828403121561192f57600080fd5b8135610cb281611908565b6000806040838503121561194d57600080fd5b823561195881611908565b946020939093013593505050565b60008060006060848603121561197b57600080fd5b833561198681611908565b9250602084013561199681611908565b929592945050506040919091013590565b600080604083850312156119ba57600080fd5b82356119c581611908565b9150602083013580151581146119da57600080fd5b809150509250929050565b600080604083850312156119f857600080fd5b8235611a0381611908565b915060208301356119da81611908565b600181811c90821680611a2757607f821691505b60208210811415611a4857634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052601160045260246000fd5b60008219821115611aac57611aac611a83565b500190565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b600082821015611b4b57611b4b611a83565b500390565b6000816000190483118215151615611b6a57611b6a611a83565b500290565b600082611b8c57634e487b7160e01b600052601260045260246000fd5b500490565b634e487b7160e01b600052603260045260246000fd5b600060208284031215611bb957600080fd5b8151610cb281611908565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b81811015611c145784516001600160a01b031683529383019391830191600101611bef565b50506001600160a01b0396909616606085015250505060800152939250505056fe45524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220cf7cf7552d3e448b7c20d806e01a74a265877d46b0501262c49ac222b7a2991c64736f6c634300080900334f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572
Deployed Bytecode
0x6080604052600436106101f25760003560e01c8063715018a61161010d578063ac819f54116100a0578063dd62ed3e1161006f578063dd62ed3e146105bd578063e2f4560514610603578063f2fde38b14610619578063f398d30414610639578063f8b45b051461066957600080fd5b8063ac819f5414610533578063b62496f514610553578063bbc0c74214610583578063c02466681461059d57600080fd5b80638da5cb5b116100dc5780638da5cb5b146104c057806395d89b41146104de578063a457c2d7146104f3578063a9059cbb1461051357600080fd5b8063715018a61461046057806375f0a8741461047557806383fd0367146104955780638a8c523c146104ab57600080fd5b8063313ce5671161018557806349bd5a5e1161015457806349bd5a5e146103c15780636d7adcad146103f55780636ddd17131461040b57806370a082311461042a57600080fd5b8063313ce56714610350578063395093511461036c5780633ea3b5671461038c57806348c54b9d146103ac57600080fd5b80631694505e116101c15780631694505e146102ad57806318160ddd146102f957806323b872dd1461030e5780632d5a5d341461032e57600080fd5b806306fdde03146101fe5780630855f25d14610229578063095ea7b3146102695780630a910d1f1461028957600080fd5b366101f957005b600080fd5b34801561020a57600080fd5b5061021361067f565b60405161022091906118b3565b60405180910390f35b34801561023557600080fd5b5061025961024436600461191d565b60126020526000908152604090205460ff1681565b6040519015158152602001610220565b34801561027557600080fd5b5061025961028436600461193a565b610711565b34801561029557600080fd5b5061029f600c5481565b604051908152602001610220565b3480156102b957600080fd5b506102e17f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d81565b6040516001600160a01b039091168152602001610220565b34801561030557600080fd5b5060025461029f565b34801561031a57600080fd5b50610259610329366004611966565b610728565b34801561033a57600080fd5b5061034e6103493660046119a7565b610791565b005b34801561035c57600080fd5b5060405160128152602001610220565b34801561037857600080fd5b5061025961038736600461193a565b61087b565b34801561039857600080fd5b5061034e6103a73660046119a7565b6108b1565b3480156103b857600080fd5b5061034e610906565b3480156103cd57600080fd5b506102e17f000000000000000000000000d4376d043c747bfb209e3701956e9b1ffbe1e15c81565b34801561040157600080fd5b5061029f600e5481565b34801561041757600080fd5b50600a5461025990610100900460ff1681565b34801561043657600080fd5b5061029f61044536600461191d565b6001600160a01b031660009081526020819052604090205490565b34801561046c57600080fd5b5061034e61096c565b34801561048157600080fd5b506007546102e1906001600160a01b031681565b3480156104a157600080fd5b5061029f600d5481565b3480156104b757600080fd5b5061034e6109e0565b3480156104cc57600080fd5b506005546001600160a01b03166102e1565b3480156104ea57600080fd5b50610213610a1f565b3480156104ff57600080fd5b5061025961050e36600461193a565b610a2e565b34801561051f57600080fd5b5061025961052e36600461193a565b610a7d565b34801561053f57600080fd5b5061034e61054e3660046119a7565b610a8a565b34801561055f57600080fd5b5061025961056e36600461191d565b60136020526000908152604090205460ff1681565b34801561058f57600080fd5b50600a546102599060ff1681565b3480156105a957600080fd5b5061034e6105b83660046119a7565b610adf565b3480156105c957600080fd5b5061029f6105d83660046119e5565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b34801561060f57600080fd5b5061029f60085481565b34801561062557600080fd5b5061034e61063436600461191d565b610b68565b34801561064557600080fd5b5061025961065436600461191d565b60116020526000908152604090205460ff1681565b34801561067557600080fd5b5061029f60095481565b60606003805461068e90611a13565b80601f01602080910402602001604051908101604052809291908181526020018280546106ba90611a13565b80156107075780601f106106dc57610100808354040283529160200191610707565b820191906000526020600020905b8154815290600101906020018083116106ea57829003601f168201915b5050505050905090565b600061071e338484610cb9565b5060015b92915050565b6000610735848484610dde565b610787843361078285604051806060016040528060288152602001611c5c602891396001600160a01b038a1660009081526001602090815260408083203384529091529020549190611401565b610cb9565b5060019392505050565b6005546001600160a01b031633146107c45760405162461bcd60e51b81526004016107bb90611a4e565b60405180910390fd5b6001600160a01b038216301480159061080f57507f000000000000000000000000d4376d043c747bfb209e3701956e9b1ffbe1e15c6001600160a01b0316826001600160a01b031614155b801561084d57507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b0316826001600160a01b031614155b15610877576001600160a01b0382166000908152600b60205260409020805460ff19168215151790555b5050565b3360008181526001602090815260408083206001600160a01b0387168452909152812054909161071e9185906107829086610c53565b6005546001600160a01b031633146108db5760405162461bcd60e51b81526004016107bb90611a4e565b6001600160a01b03919091166000908152601160205260409020805460ff1916911515919091179055565b6005546001600160a01b031633146109305760405162461bcd60e51b81526004016107bb90611a4e565b6007546040516001600160a01b03909116904780156108fc02916000818181858888f19350505050158015610969573d6000803e3d6000fd5b50565b6005546001600160a01b031633146109965760405162461bcd60e51b81526004016107bb90611a4e565b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b03163314610a0a5760405162461bcd60e51b81526004016107bb90611a4e565b600a805461ffff191661010117905543600f55565b60606004805461068e90611a13565b600061071e338461078285604051806060016040528060258152602001611c84602591393360009081526001602090815260408083206001600160a01b038d1684529091529020549190611401565b600061071e338484610dde565b6005546001600160a01b03163314610ab45760405162461bcd60e51b81526004016107bb90611a4e565b6001600160a01b03919091166000908152601260205260409020805460ff1916911515919091179055565b6005546001600160a01b03163314610b095760405162461bcd60e51b81526004016107bb90611a4e565b6001600160a01b038216600081815260106020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6005546001600160a01b03163314610b925760405162461bcd60e51b81526004016107bb90611a4e565b6001600160a01b038116610bf75760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016107bb565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b600080610c608385611a99565b905083811015610cb25760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016107bb565b9392505050565b6001600160a01b038316610d1b5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016107bb565b6001600160a01b038216610d7c5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016107bb565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b038316610e045760405162461bcd60e51b81526004016107bb90611ab1565b6001600160a01b038216610e2a5760405162461bcd60e51b81526004016107bb90611af6565b6001600160a01b0382166000908152600b602052604090205460ff16158015610e6c57506001600160a01b0383166000908152600b602052604090205460ff16155b610ed25760405162461bcd60e51b815260206004820152603160248201527f596f752068617665206265656e20626c61636b6c69737465642066726f6d207460448201527072616e73666572696e6720746f6b656e7360781b60648201526084016107bb565b80610ee857610ee38383600061143b565b505050565b6005546001600160a01b03848116911614801590610f1457506005546001600160a01b03838116911614155b8015610f2857506001600160a01b03821615155b8015610f3f57506001600160a01b03821661dead14155b8015610f555750600654600160a01b900460ff16155b156110a957600a5460ff16610fe8576001600160a01b03831660009081526010602052604090205460ff1680610fa357506001600160a01b03821660009081526010602052604090205460ff165b610fe85760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b60448201526064016107bb565b6001600160a01b03831660009081526013602052604090205460ff16801561102957506001600160a01b03821660009081526011602052604090205460ff16155b156110a95760095461104390670de0b6b3a7640000611a99565b6001600160a01b0383166000908152602081905260409020546110669083611a99565b106110a95760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b60448201526064016107bb565b600f546110b7906002611a99565b43111580156110f857507f000000000000000000000000d4376d043c747bfb209e3701956e9b1ffbe1e15c6001600160a01b0316826001600160a01b031614155b801561112157506001600160a01b038216737a250d5630b4cf539739df2c5dacb4c659f2488d14155b15611170576001600160a01b0382166000818152600b6020526040808220805460ff19166001179055517fb90badc1cf1c52268f4fa9afb5276aebf640bcca3300cdfc9cf37db17daa13e29190a25b306000908152602081905260409020546008548110801590819061119b5750600a54610100900460ff165b80156111b15750600654600160a01b900460ff16155b80156111d657506001600160a01b03851660009081526013602052604090205460ff16155b80156111fb57506001600160a01b03851660009081526010602052604090205460ff16155b801561122057506001600160a01b03841660009081526010602052604090205460ff16155b1561124e576006805460ff60a01b1916600160a01b179055611240611544565b6006805460ff60a01b191690555b6006546001600160a01b03851660009081526013602052604081205460ff600160a01b909304831615921615801561129f57506001600160a01b03871660009081526013602052604090205460ff16155b6001600160a01b03881660009081526010602052604090205490915060ff16806112e157506001600160a01b03861660009081526010602052604090205460ff165b806112e95750805b156112f357600091505b600082156113ec576001600160a01b03881660009081526013602052604090205460ff16801561132557506000600c54115b1561136a5761134b612710611345600c54896115fd90919063ffffffff16565b9061167c565b905080600e600082825461135f9190611a99565b909155506113ce9050565b6001600160a01b03871660009081526013602052604090205460ff16801561139457506000600d54115b156113ce576113b4612710611345600d54896115fd90919063ffffffff16565b905080600e60008282546113c89190611a99565b90915550505b80156113df576113df88308361143b565b6113e98187611b39565b95505b6113f788888861143b565b5050505050505050565b600081848411156114255760405162461bcd60e51b81526004016107bb91906118b3565b5060006114328486611b39565b95945050505050565b6001600160a01b0383166114615760405162461bcd60e51b81526004016107bb90611ab1565b6001600160a01b0382166114875760405162461bcd60e51b81526004016107bb90611af6565b6114c481604051806060016040528060268152602001611c36602691396001600160a01b0386166000908152602081905260409020549190611401565b6001600160a01b0380851660009081526020819052604080822093909355908416815220546114f39082610c53565b6001600160a01b038381166000818152602081815260409182902094909455518481529092918616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101610dd1565b30600090815260208190526040812054600e549091821580611564575081155b1561156e57505050565b60085461157c906014611b50565b83111561159457600854611591906014611b50565b92505b61159d826116be565b6000600e8190556007546040516001600160a01b039091169147919081818185875af1925050503d80600081146115f0576040519150601f19603f3d011682016040523d82523d6000602084013e6115f5565b606091505b505050505050565b60008261160c57506000610722565b60006116188385611b50565b9050826116258583611b6f565b14610cb25760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016107bb565b6000610cb283836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611885565b60408051600280825260608201835260009260208301908036833701905050905030816000815181106116f3576116f3611b91565b60200260200101906001600160a01b031690816001600160a01b0316815250507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b15801561176c57600080fd5b505afa158015611780573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906117a49190611ba7565b816001815181106117b7576117b7611b91565b60200260200101906001600160a01b031690816001600160a01b031681525050611802307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d84610cb9565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d169063791ac94790611857908590600090869030904290600401611bc4565b600060405180830381600087803b15801561187157600080fd5b505af11580156115f5573d6000803e3d6000fd5b600081836118a65760405162461bcd60e51b81526004016107bb91906118b3565b5060006114328486611b6f565b600060208083528351808285015260005b818110156118e0578581018301518582016040015282016118c4565b818111156118f2576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b038116811461096957600080fd5b60006020828403121561192f57600080fd5b8135610cb281611908565b6000806040838503121561194d57600080fd5b823561195881611908565b946020939093013593505050565b60008060006060848603121561197b57600080fd5b833561198681611908565b9250602084013561199681611908565b929592945050506040919091013590565b600080604083850312156119ba57600080fd5b82356119c581611908565b9150602083013580151581146119da57600080fd5b809150509250929050565b600080604083850312156119f857600080fd5b8235611a0381611908565b915060208301356119da81611908565b600181811c90821680611a2757607f821691505b60208210811415611a4857634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052601160045260246000fd5b60008219821115611aac57611aac611a83565b500190565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b600082821015611b4b57611b4b611a83565b500390565b6000816000190483118215151615611b6a57611b6a611a83565b500290565b600082611b8c57634e487b7160e01b600052601260045260246000fd5b500490565b634e487b7160e01b600052603260045260246000fd5b600060208284031215611bb957600080fd5b8151610cb281611908565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b81811015611c145784516001600160a01b031683529383019391830191600101611bef565b50506001600160a01b0396909616606085015250505060800152939250505056fe45524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220cf7cf7552d3e448b7c20d806e01a74a265877d46b0501262c49ac222b7a2991c64736f6c63430008090033
Deployed Bytecode Sourcemap
28712:9569:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7498:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;29622:68;;;;;;;;;;-1:-1:-1;29622:68:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;1169:14:1;;1162:22;1144:41;;1132:2;1117:18;29622:68:0;1004:187:1;9673:169:0;;;;;;;;;;-1:-1:-1;9673:169:0;;;;;:::i;:::-;;:::i;29238:21::-;;;;;;;;;;;;;;;;;;;1662:25:1;;;1650:2;1635:18;29238:21:0;1516:177:1;28794:51:0;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;1889:32:1;;;1871:51;;1859:2;1844:18;28794:51:0;1698:230:1;8621:108:0;;;;;;;;;;-1:-1:-1;8709:12:0;;8621:108;;10325:355;;;;;;;;;;-1:-1:-1;10325:355:0;;;;;:::i;:::-;;:::i;33207:312::-;;;;;;;;;;-1:-1:-1;33207:312:0;;;;;:::i;:::-;;:::i;:::-;;8462:93;;;;;;;;;;-1:-1:-1;8462:93:0;;8545:2;2957:36:1;;2945:2;2930:18;8462:93:0;2815:184:1;11090:218:0;;;;;;;;;;-1:-1:-1;11090:218:0;;;;;:::i;:::-;;:::i;32696:150::-;;;;;;;;;;-1:-1:-1;32696:150:0;;;;;:::i;:::-;;:::i;32480:204::-;;;;;;;;;;;;;:::i;28852:38::-;;;;;;;;;;;;;;;29298:27;;;;;;;;;;;;;;;;29124:31;;;;;;;;;;-1:-1:-1;29124:31:0;;;;;;;;;;;8793:128;;;;;;;;;;-1:-1:-1;8793:128:0;;;;;:::i;:::-;-1:-1:-1;;;;;8894:19:0;8867:7;8894:19;;;;;;;;;;;;8793:128;21312:148;;;;;;;;;;;;;:::i;28966:30::-;;;;;;;;;;-1:-1:-1;28966:30:0;;;;-1:-1:-1;;;;;28966:30:0;;;29266:22;;;;;;;;;;;;;;;;32323:148;;;;;;;;;;;;;:::i;20668:79::-;;;;;;;;;;-1:-1:-1;20733:6:0;;-1:-1:-1;;;;;20733:6:0;20668:79;;7718:104;;;;;;;;;;;;;:::i;11812:269::-;;;;;;;;;;-1:-1:-1;11812:269:0;;;;;:::i;:::-;;:::i;9135:175::-;;;;;;;;;;-1:-1:-1;9135:175:0;;;;;:::i;:::-;;:::i;32854:152::-;;;;;;;;;;-1:-1:-1;32854:152:0;;;;;:::i;:::-;;:::i;29849:58::-;;;;;;;;;;-1:-1:-1;29849:58:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;29084:33;;;;;;;;;;-1:-1:-1;29084:33:0;;;;;;;;33016:182;;;;;;;;;;-1:-1:-1;33016:182:0;;;;;:::i;:::-;;:::i;9374:151::-;;;;;;;;;;-1:-1:-1;9374:151:0;;;;;:::i;:::-;-1:-1:-1;;;;;9490:18:0;;;9463:7;9490:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;9374:151;29010:33;;;;;;;;;;;;;;;;21616:244;;;;;;;;;;-1:-1:-1;21616:244:0;;;;;:::i;:::-;;:::i;29548:67::-;;;;;;;;;;-1:-1:-1;29548:67:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;29050:24;;;;;;;;;;;;;;;;7498:100;7552:13;7585:5;7578:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7498:100;:::o;9673:169::-;9756:4;9773:39;253:10;9796:7;9805:6;9773:8;:39::i;:::-;-1:-1:-1;9830:4:0;9673:169;;;;;:::o;10325:355::-;10465:4;10482:36;10492:6;10500:9;10511:6;10482:9;:36::i;:::-;10529:121;10538:6;253:10;10560:89;10598:6;10560:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;10560:19:0;;;;;;:11;:19;;;;;;;;253:10;10560:33;;;;;;;;;;:37;:89::i;:::-;10529:8;:121::i;:::-;-1:-1:-1;10668:4:0;10325:355;;;;;:::o;33207:312::-;20881:6;;-1:-1:-1;;;;;20881:6:0;253:10;20881:22;20873:67;;;;-1:-1:-1;;;20873:67:0;;;;;;;:::i;:::-;;;;;;;;;-1:-1:-1;;;;;33367:24:0;::::1;33386:4;33367:24;::::0;::::1;::::0;:52:::1;;;33406:13;-1:-1:-1::0;;;;;33395:24:0::1;:7;-1:-1:-1::0;;;;;33395:24:0::1;;;33367:52;:91;;;;;33442:15;-1:-1:-1::0;;;;;33423:35:0::1;:7;-1:-1:-1::0;;;;;33423:35:0::1;;;33367:91;33363:149;;;-1:-1:-1::0;;;;;33471:19:0;::::1;;::::0;;;:10:::1;:19;::::0;;;;:35;;-1:-1:-1;;33471:35:0::1;::::0;::::1;;;::::0;;33363:149:::1;33207:312:::0;;:::o;11090:218::-;253:10;11178:4;11227:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;11227:34:0;;;;;;;;;;11178:4;;11195:83;;11218:7;;11227:50;;11266:10;11227:38;:50::i;32696:150::-;20881:6;;-1:-1:-1;;;;;20881:6:0;253:10;20881:22;20873:67;;;;-1:-1:-1;;;20873:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;32789:42:0;;;::::1;;::::0;;;:34:::1;:42;::::0;;;;:49;;-1:-1:-1;;32789:49:0::1;::::0;::::1;;::::0;;;::::1;::::0;;32696:150::o;32480:204::-;20881:6;;-1:-1:-1;;;;;20881:6:0;253:10;20881:22;20873:67;;;;-1:-1:-1;;;20873:67:0;;;;;;;:::i;:::-;32628:15:::1;::::0;32620:56:::1;::::0;-1:-1:-1;;;;;32628:15:0;;::::1;::::0;32654:21:::1;32620:56:::0;::::1;;;::::0;32628:15:::1;32620:56:::0;32628:15;32620:56;32654:21;32628:15;32620:56;::::1;;;;;;;;;;;;;::::0;::::1;;;;;;32480:204::o:0;21312:148::-;20881:6;;-1:-1:-1;;;;;20881:6:0;253:10;20881:22;20873:67;;;;-1:-1:-1;;;20873:67:0;;;;;;;:::i;:::-;21403:6:::1;::::0;21382:40:::1;::::0;21419:1:::1;::::0;-1:-1:-1;;;;;21403:6:0::1;::::0;21382:40:::1;::::0;21419:1;;21382:40:::1;21433:6;:19:::0;;-1:-1:-1;;;;;;21433:19:0::1;::::0;;21312:148::o;32323:::-;20881:6;;-1:-1:-1;;;;;20881:6:0;253:10;20881:22;20873:67;;;;-1:-1:-1;;;20873:67:0;;;;;;;:::i;:::-;32378:13:::1;:20:::0;;-1:-1:-1;;32409:18:0;;;;;32451:12:::1;32438:10;:25:::0;32323:148::o;7718:104::-;7774:13;7807:7;7800:14;;;;;:::i;11812:269::-;11905:4;11922:129;253:10;11945:7;11954:96;11993:15;11954:96;;;;;;;;;;;;;;;;;253:10;11954:25;;;;:11;:25;;;;;;;;-1:-1:-1;;;;;11954:34:0;;;;;;;;;;;;:38;:96::i;9135:175::-;9221:4;9238:42;253:10;9262:9;9273:6;9238:9;:42::i;32854:152::-;20881:6;;-1:-1:-1;;;;;20881:6:0;253:10;20881:22;20873:67;;;;-1:-1:-1;;;20873:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;32948:43:0;;;::::1;;::::0;;;:35:::1;:43;::::0;;;;:50;;-1:-1:-1;;32948:50:0::1;::::0;::::1;;::::0;;;::::1;::::0;;32854:152::o;33016:182::-;20881:6;;-1:-1:-1;;;;;20881:6:0;253:10;20881:22;20873:67;;;;-1:-1:-1;;;20873:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;33101:28:0;::::1;;::::0;;;:19:::1;:28;::::0;;;;;;;;:39;;-1:-1:-1;;33101:39:0::1;::::0;::::1;;::::0;;::::1;::::0;;;33156:34;;1144:41:1;;;33156:34:0::1;::::0;1117:18:1;33156:34:0::1;;;;;;;33016:182:::0;;:::o;21616:244::-;20881:6;;-1:-1:-1;;;;;20881:6:0;253:10;20881:22;20873:67;;;;-1:-1:-1;;;20873:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;21705:22:0;::::1;21697:73;;;::::0;-1:-1:-1;;;21697:73:0;;4553:2:1;21697:73:0::1;::::0;::::1;4535:21:1::0;4592:2;4572:18;;;4565:30;4631:34;4611:18;;;4604:62;-1:-1:-1;;;4682:18:1;;;4675:36;4728:19;;21697:73:0::1;4351:402:1::0;21697:73:0::1;21807:6;::::0;21786:38:::1;::::0;-1:-1:-1;;;;;21786:38:0;;::::1;::::0;21807:6:::1;::::0;21786:38:::1;::::0;21807:6:::1;::::0;21786:38:::1;21835:6;:17:::0;;-1:-1:-1;;;;;;21835:17:0::1;-1:-1:-1::0;;;;;21835:17:0;;;::::1;::::0;;;::::1;::::0;;21616:244::o;15700:182::-;15758:7;;15790:5;15794:1;15790;:5;:::i;:::-;15778:17;;15819:1;15814;:6;;15806:46;;;;-1:-1:-1;;;15806:46:0;;5225:2:1;15806:46:0;;;5207:21:1;5264:2;5244:18;;;5237:30;5303:29;5283:18;;;5276:57;5350:18;;15806:46:0;5023:351:1;15806:46:0;15873:1;15700:182;-1:-1:-1;;;15700:182:0:o;14319:381::-;-1:-1:-1;;;;;14455:19:0;;14447:68;;;;-1:-1:-1;;;14447:68:0;;5581:2:1;14447:68:0;;;5563:21:1;5620:2;5600:18;;;5593:30;5659:34;5639:18;;;5632:62;-1:-1:-1;;;5710:18:1;;;5703:34;5754:19;;14447:68:0;5379:400:1;14447:68:0;-1:-1:-1;;;;;14534:21:0;;14526:68;;;;-1:-1:-1;;;14526:68:0;;5986:2:1;14526:68:0;;;5968:21:1;6025:2;6005:18;;;5998:30;6064:34;6044:18;;;6037:62;-1:-1:-1;;;6115:18:1;;;6108:32;6157:19;;14526:68:0;5784:398:1;14526:68:0;-1:-1:-1;;;;;14608:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;14660:32;;1662:25:1;;;14660:32:0;;1635:18:1;14660:32:0;;;;;;;;14319:381;;;:::o;33778:2826::-;-1:-1:-1;;;;;33910:18:0;;33902:68;;;;-1:-1:-1;;;33902:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;33989:16:0;;33981:64;;;;-1:-1:-1;;;33981:64:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;34065:14:0;;;;;;:10;:14;;;;;;;;34064:15;:36;;;;-1:-1:-1;;;;;;34084:16:0;;;;;;:10;:16;;;;;;;;34083:17;34064:36;34056:98;;;;-1:-1:-1;;;34056:98:0;;7199:2:1;34056:98:0;;;7181:21:1;7238:2;7218:18;;;7211:30;7277:34;7257:18;;;7250:62;-1:-1:-1;;;7328:18:1;;;7321:47;7385:19;;34056:98:0;6997:413:1;34056:98:0;34169:11;34166:92;;34197:28;34213:4;34219:2;34223:1;34197:15;:28::i;:::-;33778:2826;;;:::o;34166:92::-;20733:6;;-1:-1:-1;;;;;34291:15:0;;;20733:6;;34291:15;;;;:45;;-1:-1:-1;20733:6:0;;-1:-1:-1;;;;;34323:13:0;;;20733:6;;34323:13;;34291:45;:78;;;;-1:-1:-1;;;;;;34353:16:0;;;;34291:78;:116;;;;-1:-1:-1;;;;;;34386:21:0;;34400:6;34386:21;;34291:116;:142;;;;-1:-1:-1;34425:8:0;;-1:-1:-1;;;34425:8:0;;;;34424:9;34291:142;34273:574;;;34463:13;;;;34459:140;;-1:-1:-1;;;;;34504:25:0;;;;;;:19;:25;;;;;;;;;:52;;-1:-1:-1;;;;;;34533:23:0;;;;;;:19;:23;;;;;;;;34504:52;34496:87;;;;-1:-1:-1;;;34496:87:0;;7617:2:1;34496:87:0;;;7599:21:1;7656:2;7636:18;;;7629:30;-1:-1:-1;;;7675:18:1;;;7668:52;7737:18;;34496:87:0;7415:346:1;34496:87:0;-1:-1:-1;;;;;34644:31:0;;;;;;:25;:31;;;;;;;;:74;;;;-1:-1:-1;;;;;;34680:38:0;;;;;;:34;:38;;;;;;;;34679:39;34644:74;34640:196;;;34776:9;;:20;;34788:8;34776:20;:::i;:::-;-1:-1:-1;;;;;8894:19:0;;8867:7;8894:19;;;;;;;;;;;34751:22;;:6;:22;:::i;:::-;:45;34743:77;;;;-1:-1:-1;;;34743:77:0;;7968:2:1;34743:77:0;;;7950:21:1;8007:2;7987:18;;;7980:30;-1:-1:-1;;;8026:18:1;;;8019:49;8085:18;;34743:77:0;7766:343:1;34743:77:0;34902:10;;:14;;34915:1;34902:14;:::i;:::-;34885:12;:32;;:73;;;;;34945:13;-1:-1:-1;;;;;34939:19:0;:2;-1:-1:-1;;;;;34939:19:0;;;34885:73;:152;;;;-1:-1:-1;;;;;;34980:57:0;;34994:42;34980:57;;34885:152;34881:256;;;-1:-1:-1;;;;;35069:14:0;;;;;;:10;:14;;;;;;:21;;-1:-1:-1;;35069:21:0;35086:4;35069:21;;;35110:15;;;35069:14;35110:15;34881:256;35199:4;35150:28;8894:19;;;;;;;;;;;35258:18;;35234:42;;;;;;;35308:35;;-1:-1:-1;35332:11:0;;;;;;;35308:35;:61;;;;-1:-1:-1;35361:8:0;;-1:-1:-1;;;35361:8:0;;;;35360:9;35308:61;:110;;;;-1:-1:-1;;;;;;35387:31:0;;;;;;:25;:31;;;;;;;;35386:32;35308:110;:153;;;;-1:-1:-1;;;;;;35436:25:0;;;;;;:19;:25;;;;;;;;35435:26;35308:153;:194;;;;-1:-1:-1;;;;;;35479:23:0;;;;;;:19;:23;;;;;;;;35478:24;35308:194;35290:328;;;35529:8;:15;;-1:-1:-1;;;;35529:15:0;-1:-1:-1;;;35529:15:0;;;35562:10;:8;:10::i;:::-;35590:8;:16;;-1:-1:-1;;;;35590:16:0;;;35290:328;35647:8;;-1:-1:-1;;;;;35691:29:0;;35631:12;35691:29;;;:25;:29;;;;;;35647:8;-1:-1:-1;;;35647:8:0;;;;;35646:9;;35691:29;35690:30;:66;;;;-1:-1:-1;;;;;;35725:31:0;;;;;;:25;:31;;;;;;;;35724:32;35690:66;-1:-1:-1;;;;;35855:25:0;;;;;;:19;:25;;;;;;35668:88;;-1:-1:-1;35855:25:0;;;:52;;-1:-1:-1;;;;;;35884:23:0;;;;;;:19;:23;;;;;;;;35855:52;:70;;;;35911:14;35855:70;35852:117;;;35952:5;35942:15;;35852:117;35982:12;36086:7;36083:467;;;-1:-1:-1;;;;;36115:31:0;;;;;;:25;:31;;;;;;;;:45;;;;;36159:1;36150:6;;:10;36115:45;36111:284;;;36178:29;36201:5;36178:18;36189:6;;36178;:10;;:18;;;;:::i;:::-;:22;;:29::i;:::-;36171:36;;36230:4;36214:12;;:20;;;;;;;:::i;:::-;;;;-1:-1:-1;36111:284:0;;-1:-1:-1;36111:284:0;;-1:-1:-1;;;;;36266:29:0;;;;;;:25;:29;;;;;;;;:44;;;;;36309:1;36299:7;;:11;36266:44;36263:132;;;36330:30;36354:5;36330:19;36341:7;;36330:6;:10;;:19;;;;:::i;:30::-;36323:37;;36383:4;36367:12;;:20;;;;;;;:::i;:::-;;;;-1:-1:-1;;36263:132:0;36417:8;;36414:93;;36449:42;36465:4;36479;36486;36449:15;:42::i;:::-;36524:14;36534:4;36524:14;;:::i;:::-;;;36083:467;36563:33;36579:4;36585:2;36589:6;36563:15;:33::i;:::-;33891:2713;;;;;33778:2826;;;:::o;16606:193::-;16692:7;16728:12;16720:6;;;;16712:29;;;;-1:-1:-1;;;16712:29:0;;;;;;;;:::i;:::-;-1:-1:-1;16752:9:0;16764:5;16768:1;16764;:5;:::i;:::-;16752:17;16606:193;-1:-1:-1;;;;;16606:193:0:o;12572:579::-;-1:-1:-1;;;;;12712:20:0;;12704:70;;;;-1:-1:-1;;;12704:70:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;12793:23:0;;12785:71;;;;-1:-1:-1;;;12785:71:0;;;;;;;:::i;:::-;12952:72;12975:6;12952:72;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;12952:18:0;;:10;:18;;;;;;;;;;;;:72;:22;:72::i;:::-;-1:-1:-1;;;;;12931:18:0;;;:10;:18;;;;;;;;;;;:93;;;;13059:21;;;;;;;:33;;13085:6;13059:25;:33::i;:::-;-1:-1:-1;;;;;13035:21:0;;;:10;:21;;;;;;;;;;;;:57;;;;13108:35;1662:25:1;;;13035:21:0;;13108:35;;;;;;1635:18:1;13108:35:0;1516:177:1;37744:531:0;37827:4;37783:23;8894:19;;;;;;;;;;;37872:12;;8894:19;;37924:20;;;:46;;-1:-1:-1;37948:22:0;;37924:46;37921:60;;;37973:7;;;37744:531::o;37921:60::-;38015:18;;:23;;38036:2;38015:23;:::i;:::-;37997:15;:41;37994:111;;;38070:18;;:23;;38091:2;38070:23;:::i;:::-;38052:41;;37994:111;38118:35;38135:17;38118:16;:35::i;:::-;38183:1;38168:12;:16;;;38213:15;;38205:63;;-1:-1:-1;;;;;38213:15:0;;;;38242:21;;38205:63;;38183:1;38205:63;38242:21;38213:15;38205:63;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;37744:531:0:o;17059:473::-;17117:7;17362:6;17358:47;;-1:-1:-1;17392:1:0;17385:8;;17358:47;17418:9;17430:5;17434:1;17430;:5;:::i;:::-;17418:17;-1:-1:-1;17463:1:0;17454:5;17458:1;17418:17;17454:5;:::i;:::-;:10;17446:56;;;;-1:-1:-1;;;17446:56:0;;9051:2:1;17446:56:0;;;9033:21:1;9090:2;9070:18;;;9063:30;9129:34;9109:18;;;9102:62;-1:-1:-1;;;9180:18:1;;;9173:31;9221:19;;17446:56:0;8849:397:1;18009:132:0;18067:7;18094:39;18098:1;18101;18094:39;;;;;;;;;;;;;;;;;:3;:39::i;36613:597::-;36766:16;;;36780:1;36766:16;;;;;;;;36742:21;;36766:16;;;;;;;;;;-1:-1:-1;36766:16:0;36742:40;;36811:4;36793;36798:1;36793:7;;;;;;;;:::i;:::-;;;;;;:23;-1:-1:-1;;;;;36793:23:0;;;-1:-1:-1;;;;;36793:23:0;;;;;36837:15;-1:-1:-1;;;;;36837:20:0;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;36827:4;36832:1;36827:7;;;;;;;;:::i;:::-;;;;;;:32;-1:-1:-1;;;;;36827:32:0;;;-1:-1:-1;;;;;36827:32:0;;;;;36873:62;36890:4;36905:15;36923:11;36873:8;:62::i;:::-;36975:224;;-1:-1:-1;;;36975:224:0;;-1:-1:-1;;;;;36975:15:0;:66;;;;:224;;37056:11;;37082:1;;37126:4;;37153;;37173:15;;36975:224;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;18638:279;18724:7;18759:12;18752:5;18744:28;;;;-1:-1:-1;;;18744:28:0;;;;;;;;:::i;:::-;-1:-1:-1;18783:9:0;18795:5;18799:1;18795;:5;:::i;14:597: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;;;452:6;449:1;446:13;443:91;;;522:1;517:2;508:6;497:9;493:22;489:31;482:42;443:91;-1:-1:-1;595:2:1;574:15;-1:-1:-1;;570:29:1;555:45;;;;602:2;551:54;;14:597;-1:-1:-1;;;14:597:1:o;616:131::-;-1:-1:-1;;;;;691:31:1;;681:42;;671:70;;737:1;734;727:12;752:247;811:6;864:2;852:9;843:7;839:23;835:32;832:52;;;880:1;877;870:12;832:52;919:9;906:23;938:31;963:5;938:31;:::i;1196:315::-;1264:6;1272;1325:2;1313:9;1304:7;1300:23;1296:32;1293:52;;;1341:1;1338;1331:12;1293:52;1380:9;1367:23;1399:31;1424:5;1399:31;:::i;:::-;1449:5;1501:2;1486:18;;;;1473:32;;-1:-1:-1;;;1196:315:1:o;1933:456::-;2010:6;2018;2026;2079:2;2067:9;2058:7;2054:23;2050:32;2047:52;;;2095:1;2092;2085:12;2047:52;2134:9;2121:23;2153:31;2178:5;2153:31;:::i;:::-;2203:5;-1:-1:-1;2260:2:1;2245:18;;2232:32;2273:33;2232:32;2273:33;:::i;:::-;1933:456;;2325:7;;-1:-1:-1;;;2379:2:1;2364:18;;;;2351:32;;1933:456::o;2394:416::-;2459:6;2467;2520:2;2508:9;2499:7;2495:23;2491:32;2488:52;;;2536:1;2533;2526:12;2488:52;2575:9;2562:23;2594:31;2619:5;2594:31;:::i;:::-;2644:5;-1:-1:-1;2701:2:1;2686:18;;2673:32;2743:15;;2736:23;2724:36;;2714:64;;2774:1;2771;2764:12;2714:64;2797:7;2787:17;;;2394:416;;;;;:::o;3212:388::-;3280:6;3288;3341:2;3329:9;3320:7;3316:23;3312:32;3309:52;;;3357:1;3354;3347:12;3309:52;3396:9;3383:23;3415:31;3440:5;3415:31;:::i;:::-;3465:5;-1:-1:-1;3522:2:1;3507:18;;3494:32;3535:33;3494:32;3535:33;:::i;3605:380::-;3684:1;3680:12;;;;3727;;;3748:61;;3802:4;3794:6;3790:17;3780:27;;3748:61;3855:2;3847:6;3844:14;3824:18;3821:38;3818:161;;;3901:10;3896:3;3892:20;3889:1;3882:31;3936:4;3933:1;3926:15;3964:4;3961:1;3954:15;3818:161;;3605:380;;;:::o;3990:356::-;4192:2;4174:21;;;4211:18;;;4204:30;4270:34;4265:2;4250:18;;4243:62;4337:2;4322:18;;3990:356::o;4758:127::-;4819:10;4814:3;4810:20;4807:1;4800:31;4850:4;4847:1;4840:15;4874:4;4871:1;4864:15;4890:128;4930:3;4961:1;4957:6;4954:1;4951:13;4948:39;;;4967:18;;:::i;:::-;-1:-1:-1;5003:9:1;;4890:128::o;6187:401::-;6389:2;6371:21;;;6428:2;6408:18;;;6401:30;6467:34;6462:2;6447:18;;6440:62;-1:-1:-1;;;6533:2:1;6518:18;;6511:35;6578:3;6563:19;;6187:401::o;6593:399::-;6795:2;6777:21;;;6834:2;6814:18;;;6807:30;6873:34;6868:2;6853:18;;6846:62;-1:-1:-1;;;6939:2:1;6924:18;;6917:33;6982:3;6967:19;;6593:399::o;8114:125::-;8154:4;8182:1;8179;8176:8;8173:34;;;8187:18;;:::i;:::-;-1:-1:-1;8224:9:1;;8114:125::o;8244:168::-;8284:7;8350:1;8346;8342:6;8338:14;8335:1;8332:21;8327:1;8320:9;8313:17;8309:45;8306:71;;;8357:18;;:::i;:::-;-1:-1:-1;8397:9:1;;8244:168::o;8627:217::-;8667:1;8693;8683:132;;8737:10;8732:3;8728:20;8725:1;8718:31;8772:4;8769:1;8762:15;8800:4;8797:1;8790:15;8683:132;-1:-1:-1;8829:9:1;;8627:217::o;9383:127::-;9444:10;9439:3;9435:20;9432:1;9425:31;9475:4;9472:1;9465:15;9499:4;9496:1;9489:15;9515:251;9585:6;9638:2;9626:9;9617:7;9613:23;9609:32;9606:52;;;9654:1;9651;9644:12;9606:52;9686:9;9680:16;9705:31;9730:5;9705:31;:::i;9771:980::-;10033:4;10081:3;10070:9;10066:19;10112:6;10101:9;10094:25;10138:2;10176:6;10171:2;10160:9;10156:18;10149:34;10219:3;10214:2;10203:9;10199:18;10192:31;10243:6;10278;10272:13;10309:6;10301;10294:22;10347:3;10336:9;10332:19;10325:26;;10386:2;10378:6;10374:15;10360:29;;10407:1;10417:195;10431:6;10428:1;10425:13;10417:195;;;10496:13;;-1:-1:-1;;;;;10492:39:1;10480:52;;10587:15;;;;10552:12;;;;10528:1;10446:9;10417:195;;;-1:-1:-1;;;;;;;10668:32:1;;;;10663:2;10648:18;;10641:60;-1:-1:-1;;;10732:3:1;10717:19;10710:35;10629:3;9771:980;-1:-1:-1;;;9771:980:1:o
Swarm Source
ipfs://cf7cf7552d3e448b7c20d806e01a74a265877d46b0501262c49ac222b7a2991c
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.