ERC-20
Overview
Max Total Supply
973,282,232.396188129786693685 Milady Index
Holders
197
Market
Onchain Market Cap
$0.00
Circulating Supply Market Cap
-
Other Info
Token Contract (WITH 18 Decimals)
Balance
1.288280830335392765 Milady IndexValue
$0.00Loading...
Loading
Loading...
Loading
Loading...
Loading
# | Exchange | Pair | Price | 24H Volume | % Volume |
---|
Contract Name:
Milady
Compiler Version
v0.8.13+commit.abaa5c0e
Optimization Enabled:
Yes with 200 runs
Other Settings:
london EvmVersion
Contract Source Code (Solidity Standard Json-Input format)
/** $Milady (Milady Index) is a token that acts as an index of the following tokens: All swaps and transfers incur a 5% tax - this value goes to adding liquidity for $Milady and to purchase tokens. $Milady can be redeemed in equal proportion for the underlyiing assets that the burned amount respresents. Website: https://www.miladyindex.com/ Telegram: https://t.me/MiladyIndexPortal */ // SPDX-License-Identifier: MIT pragma solidity ^0.8.13; import {ERC20} from "solmate/tokens/ERC20.sol"; import {WETH} from "solmate/tokens/WETH.sol"; import {Owned} from "solmate/auth/Owned.sol"; import {SafeTransferLib} from "solmate/utils/SafeTransferLib.sol"; import {IUniswapV2Factory} from "./interfaces/IUniswapV2Factory.sol"; import {IUniswapV2Router} from "./interfaces/IUniswapV2Router.sol"; /** */ contract Milady is ERC20, Owned { using SafeTransferLib for ERC20; struct User { bool isBlacklisted; bool isAutomatedMarketMaker; bool isExcludedFromFees; bool isExcludedFromMaxTransactionAmount; } struct Fees { uint8 buy; uint8 sell; uint8 liquidity; uint8 index; uint8 development; } struct Settings { bool limitsInEffect; bool swapEnabled; bool blacklistRenounced; bool feeChangeRenounced; bool tradingActive; /// @dev Upon enabling trading, record the end block for bot protection fee /// @dev This fee is a 90% fee that is reduced by 5% every block for 18 blocks. uint216 endBlock; } uint256 public constant MAX_SUPPLY = 1_000_000_000 * 1e18; uint256 public constant MIN_SWAP_AMOUNT = MAX_SUPPLY / 100_000; // 0.001% uint256 public constant MAX_SWAP_AMOUNT = (MAX_SUPPLY * 5) / 1_000; // 0.5% IUniswapV2Router public immutable uniswapV2Router; address public immutable uniswapV2Pair; address public immutable index; address public immutable developmentWallet; uint256 public maxTransactionAmount; uint256 public swapTokensAtAmount; uint256 public maxWallet; uint256 public tokensForBotProtection; Fees public feeAmounts; bool private _swapping; Settings private settings = Settings({ limitsInEffect: true, swapEnabled: true, blacklistRenounced: false, feeChangeRenounced: false, tradingActive: false, endBlock: uint216(0) }); mapping(address => User) private _users; address private wethAddress; event ExcludeFromFees(address indexed account, bool isExcluded); event ExcludeFromMaxTransaction(address indexed account, bool isExcluded); event FailedSwapBackTransfer(address indexed destination, uint256 amount); event MaxTransactionAmountUpdated(uint256 newAmount, uint256 oldAmount); event SetAutomatedMarketMakerPair(address indexed pair, bool value); event SwapAndLiquify(uint256 tokensSwapped, uint256 ethReceived); event SwapTokensAtAmountUpdated(uint256 newAmount, uint256 oldAmount); error Milady__BlacklistModificationDisabled(); error Milady__BuyAmountGreaterThanMax(); error Milady__CannotBlacklistLPPair(); error Milady__CannotBlacklistRouter(); error Milady__CannotRemovePairFromAMMs(); error Milady__CannotTransferFromAddressZero(); error Milady__CannotTransferToAddressZero(); error Milady__ErrorWithdrawingEth(); error Milady__FeeChangeRenounced(); error Milady__MaxFeeFivePercent(); error Milady__MaxTransactionTooLow(); error Milady__MaxWalletAmountExceeded(); error Milady__MaxWalletAmountTooLow(); error Milady__OnlyOwner(); error Milady__ReceiverBlacklisted(); error Milady__ReceiverCannotBeAddressZero(); error Milady__SellAmountGreaterThanMax(); error Milady__SenderBlacklisted(); error Milady__StuckEthWithdrawError(); error Milady__SwapAmountGreaterThanMaximum(); error Milady__SwapAmountLowerThanMinimum(); error Milady__TokenAddressCannotBeAddressZero(); error Milady__TradingNotActive(); constructor( address routerAddress, address indexAddress, address devWallet ) ERC20("Milady", "Milady Index", 18) Owned(msg.sender) { index = indexAddress; developmentWallet = devWallet; IUniswapV2Router _uniswapV2Router = IUniswapV2Router(routerAddress); uniswapV2Router = _uniswapV2Router; wethAddress = uniswapV2Router.WETH(); uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory()) .createPair(address(this), _uniswapV2Router.WETH()); maxTransactionAmount = MAX_SUPPLY / 200; // 0.5% maxWallet = MAX_SUPPLY / 100; // 1% swapTokensAtAmount = (MAX_SUPPLY * 5) / 10_000; // 0.05% feeAmounts = Fees({ buy: 5, sell: 5, liquidity: 10, index: 70, development: 20 }); _users[msg.sender] = User({ isExcludedFromFees: true, isExcludedFromMaxTransactionAmount: true, isAutomatedMarketMaker: false, isBlacklisted: false }); _users[address(this)] = User({ isExcludedFromFees: true, isExcludedFromMaxTransactionAmount: true, isAutomatedMarketMaker: false, isBlacklisted: false }); _users[address(uniswapV2Router)] = User({ isExcludedFromMaxTransactionAmount: true, isAutomatedMarketMaker: false, isExcludedFromFees: false, isBlacklisted: false }); _users[address(uniswapV2Pair)] = User({ isExcludedFromMaxTransactionAmount: true, isAutomatedMarketMaker: true, isExcludedFromFees: false, isBlacklisted: false }); _mint(msg.sender, MAX_SUPPLY); _approve(address(uniswapV2Router), type(uint256).max); } receive() external payable {} function _requireIsOwner() internal view { require(msg.sender == owner, "!owner"); } function burn(address from, uint256 amount) external { require(msg.sender == index, "!index"); _burn(from, amount); } function updateFees(Fees memory newFees) external { _requireIsOwner(); require(newFees.development <= 20, "!valid"); require(newFees.index >= 60, "!valid"); require(newFees.liquidity >= 10, "!valid"); require( newFees.development + newFees.index + newFees.liquidity == 100, "!valid" ); feeAmounts = newFees; } function enableTrading() external { _requireIsOwner(); settings.endBlock = uint216(block.number) + 20; settings.tradingActive = true; } function removeLimits() external { _requireIsOwner(); settings.limitsInEffect = false; } // change the minimum amount of tokens to sell from fees function updateSwapTokensAtAmount(uint256 newAmount) external { _requireIsOwner(); if (newAmount < MIN_SWAP_AMOUNT) { revert Milady__SwapAmountLowerThanMinimum(); } if (newAmount > MAX_SWAP_AMOUNT) { revert Milady__SwapAmountGreaterThanMaximum(); } uint256 oldSwapAmount = swapTokensAtAmount; swapTokensAtAmount = newAmount; emit SwapTokensAtAmountUpdated(newAmount, oldSwapAmount); } function updateMaxTransactionAmount(uint256 newAmount) external { _requireIsOwner(); if (newAmount < (MAX_SUPPLY * 5) / 1000) { revert Milady__MaxTransactionTooLow(); } uint256 oldMaxTransactionAmount = maxTransactionAmount; maxTransactionAmount = newAmount; emit MaxTransactionAmountUpdated(newAmount, oldMaxTransactionAmount); } function excludeFromFees(address account, bool excluded) external { _requireIsOwner(); _users[account].isExcludedFromFees = excluded; emit ExcludeFromFees(account, excluded); } function excludeFromMaxTransaction( address account, bool isExcluded ) external { _requireIsOwner(); _users[account].isExcludedFromMaxTransactionAmount = isExcluded; emit ExcludeFromMaxTransaction(account, isExcluded); } function setAutomatedMarketMakerPair(address pair, bool value) external { _requireIsOwner(); if (pair == uniswapV2Pair) { revert Milady__CannotRemovePairFromAMMs(); } _users[pair].isAutomatedMarketMaker = value; emit SetAutomatedMarketMakerPair(pair, value); } function renounceBlacklist() external { _requireIsOwner(); settings.blacklistRenounced = true; } function blacklist(address account) external { _requireIsOwner(); if (settings.blacklistRenounced) { revert Milady__BlacklistModificationDisabled(); } if (account == uniswapV2Pair) { revert Milady__CannotBlacklistLPPair(); } if (account == address(uniswapV2Router)) { revert Milady__CannotBlacklistRouter(); } _users[account].isBlacklisted = true; } // @dev unblacklist address; not affected by blacklistRenounced incase team wants to unblacklist v3 pools down the function unblacklist(address account) external { _requireIsOwner(); _users[account].isBlacklisted = false; } function isExcludedFromFees(address account) external view returns (bool) { return _users[account].isExcludedFromFees; } function isExcludedFromMaxTransactionAmount( address account ) external view returns (bool) { return _users[account].isExcludedFromMaxTransactionAmount; } function isAutomatedMarketMakerPair( address pair ) external view returns (bool) { return _users[pair].isAutomatedMarketMaker; } function isBlacklisted(address account) external view returns (bool) { return _users[account].isBlacklisted; } function isSwapEnabled() external view returns (bool) { return settings.swapEnabled; } function isBlacklistRenounced() external view returns (bool) { return settings.blacklistRenounced; } function isFeeChangeRenounced() external view returns (bool) { return settings.feeChangeRenounced; } function isTradingActive() external view returns (bool) { return settings.tradingActive; } function isLimitInEffect() external view returns (bool) { return settings.limitsInEffect; } function transfer( address to, uint256 amount ) public override returns (bool) { _transfer(msg.sender, to, amount); return true; } function transferFrom( address from, address to, uint256 amount ) public override returns (bool) { uint256 allowed = allowance[from][msg.sender]; // Saves gas for limited approvals. if (allowed != type(uint256).max) { allowance[from][msg.sender] = allowed - amount; } _transfer(from, to, amount); return true; } function _transfer( address from, address to, uint256 amount ) internal returns (bool) { User memory fromData = _users[from]; User memory toData = _users[to]; Settings memory settingCache = settings; if (!settingCache.tradingActive) { if (!fromData.isExcludedFromFees) { if (!toData.isExcludedFromFees) { revert Milady__TradingNotActive(); } } } // Apply blacklist protection if (fromData.isBlacklisted) { revert Milady__SenderBlacklisted(); } if (toData.isBlacklisted) { revert Milady__ReceiverBlacklisted(); } // If zero amount, continue if (amount == 0) { return true; } bool excludedFromFees = fromData.isExcludedFromFees || toData.isExcludedFromFees; // Cache transaction type for reference. // 1 = Buy // 2 = Sell // 3 = Transfer uint8 txType = 3; if (fromData.isAutomatedMarketMaker) { // Buys originate from the AMM pair txType = 1; } else if (toData.isAutomatedMarketMaker) { // Sells send funds to AMM pair txType = 2; } if (!_swapping) { if (settingCache.limitsInEffect) { //when buy if (txType == 1 && !toData.isExcludedFromMaxTransactionAmount) { if (amount > maxTransactionAmount) { revert Milady__BuyAmountGreaterThanMax(); } if (amount + this.balanceOf(to) > maxWallet) { revert Milady__MaxWalletAmountExceeded(); } } //when sell else if ( txType == 2 && !fromData.isExcludedFromMaxTransactionAmount ) { if (amount > maxTransactionAmount) { revert Milady__SellAmountGreaterThanMax(); } } else if (!toData.isExcludedFromMaxTransactionAmount) { if (amount + this.balanceOf(to) > maxWallet) { revert Milady__MaxWalletAmountExceeded(); } } } if (settingCache.swapEnabled) { // Only sells will trigger the fee swap if (txType == 2) { if (this.balanceOf(address(this)) >= swapTokensAtAmount) { _swapping = true; _swapBack(); _swapping = false; } } } } if (txType < 3) { bool takeFee = !_swapping; // if any account belongs to _isExcludedFromFee account then remove the fee if (excludedFromFees) { takeFee = false; } uint256 fees = 0; // only take fees on buys/sells, do not take on wallet transfers if (takeFee) { Fees memory feeCache = feeAmounts; // on sell if (txType == 2) { if (feeCache.sell > 0) { fees = (amount * feeCache.sell) / 100; } } // on buy else if (txType == 1) { if (feeCache.buy > 0) { fees = (amount * feeCache.buy) / 100; } } if (block.number < settingCache.endBlock) { uint256 blocksLeft = settingCache.endBlock - block.number; uint256 botFeeMultiplier = 95; // Apply sniper protection - first 18 blocks have a fee reduced 5% each block. if (blocksLeft < 19) { botFeeMultiplier -= (5 * (19 - blocksLeft)); } uint256 botFee = (amount * botFeeMultiplier) / 100; _doTransfer(from, owner, fees); amount -= botFee; tokensForBotProtection += botFee; } amount -= fees; if (fees > 0) { _doTransfer(from, address(this), fees); } } } _doTransfer(from, to, amount); return true; } function _swapTokensForEth(uint256 tokenAmount) internal { address[] memory path = new address[](2); path[0] = address(this); path[1] = uniswapV2Router.WETH(); uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens( tokenAmount, 0, path, address(this), block.timestamp ); } function _addLiquidity(uint256 tokenAmount, uint256 ethAmount) internal { uniswapV2Router.addLiquidityETH{value: ethAmount}( address(this), tokenAmount, 0, // slippage is unavoidable 0, // slippage is unavoidable index, block.timestamp ); } function _doTransfer( address from, address to, uint256 amount ) internal returns (bool) { balanceOf[from] -= amount; // Cannot overflow because the sum of all user // balances can't exceed the max uint256 value. unchecked { balanceOf[to] += amount; } emit Transfer(from, to, amount); return true; } function _swapBack() internal { // Cache values uint256 contractBalance = this.balanceOf(address(this)); Fees memory feeCache = feeAmounts; if (contractBalance == 0) { return; } // Prevent too many tokens from being swapped uint256 maxAmount = swapTokensAtAmount * 20; if (contractBalance > maxAmount) { contractBalance = maxAmount; } uint256 liquidityAmount = (contractBalance * feeCache.liquidity) / 100; // Halve the amount of liquidity tokens uint256 liquidityTokens = liquidityAmount - (liquidityAmount / 2); uint256 initialETHBalance = address(this).balance; _swapTokensForEth(liquidityTokens); uint256 ethForLiquidity = address(this).balance - initialETHBalance; if (liquidityTokens > 0 && ethForLiquidity > 0) { _addLiquidity(liquidityTokens, ethForLiquidity); emit SwapAndLiquify(liquidityTokens, ethForLiquidity); } uint256 amountToSwapForETH = contractBalance - liquidityAmount; _swapTokensForEth(amountToSwapForETH); uint256 contractEthAmount = address(this).balance; uint256 initialTotalEth = contractEthAmount + (ethForLiquidity * 2); uint256 developmentEthAmount = (initialTotalEth * feeCache.development) / 100; (bool success, ) = address(developmentWallet).call{ value: developmentEthAmount }(""); require(success); uint256 indexEthAmount = contractEthAmount - developmentEthAmount; WETH(payable(wethAddress)).deposit{value: indexEthAmount}(); ERC20(wethAddress).safeTransfer(index, indexEthAmount); } function _approve(address spender, uint256 amount) internal onlyOwner { allowance[address(this)][spender] = amount; emit Approval(address(this), spender, amount); } }
// SPDX-License-Identifier: AGPL-3.0-only pragma solidity >=0.8.0; /// @notice Modern and gas efficient ERC20 + EIP-2612 implementation. /// @author Solmate (https://github.com/transmissions11/solmate/blob/main/src/tokens/ERC20.sol) /// @author Modified from Uniswap (https://github.com/Uniswap/uniswap-v2-core/blob/master/contracts/UniswapV2ERC20.sol) /// @dev Do not manually set balances without updating totalSupply, as the sum of all user balances must not exceed it. abstract contract ERC20 { /*////////////////////////////////////////////////////////////// EVENTS //////////////////////////////////////////////////////////////*/ event Transfer(address indexed from, address indexed to, uint256 amount); event Approval(address indexed owner, address indexed spender, uint256 amount); /*////////////////////////////////////////////////////////////// METADATA STORAGE //////////////////////////////////////////////////////////////*/ string public name; string public symbol; uint8 public immutable decimals; /*////////////////////////////////////////////////////////////// ERC20 STORAGE //////////////////////////////////////////////////////////////*/ uint256 public totalSupply; mapping(address => uint256) public balanceOf; mapping(address => mapping(address => uint256)) public allowance; /*////////////////////////////////////////////////////////////// EIP-2612 STORAGE //////////////////////////////////////////////////////////////*/ uint256 internal immutable INITIAL_CHAIN_ID; bytes32 internal immutable INITIAL_DOMAIN_SEPARATOR; mapping(address => uint256) public nonces; /*////////////////////////////////////////////////////////////// CONSTRUCTOR //////////////////////////////////////////////////////////////*/ constructor( string memory _name, string memory _symbol, uint8 _decimals ) { name = _name; symbol = _symbol; decimals = _decimals; INITIAL_CHAIN_ID = block.chainid; INITIAL_DOMAIN_SEPARATOR = computeDomainSeparator(); } /*////////////////////////////////////////////////////////////// ERC20 LOGIC //////////////////////////////////////////////////////////////*/ function approve(address spender, uint256 amount) public virtual returns (bool) { allowance[msg.sender][spender] = amount; emit Approval(msg.sender, spender, amount); return true; } function transfer(address to, uint256 amount) public virtual returns (bool) { balanceOf[msg.sender] -= amount; // Cannot overflow because the sum of all user // balances can't exceed the max uint256 value. unchecked { balanceOf[to] += amount; } emit Transfer(msg.sender, to, amount); return true; } function transferFrom( address from, address to, uint256 amount ) public virtual returns (bool) { uint256 allowed = allowance[from][msg.sender]; // Saves gas for limited approvals. if (allowed != type(uint256).max) allowance[from][msg.sender] = allowed - amount; balanceOf[from] -= amount; // Cannot overflow because the sum of all user // balances can't exceed the max uint256 value. unchecked { balanceOf[to] += amount; } emit Transfer(from, to, amount); return true; } /*////////////////////////////////////////////////////////////// EIP-2612 LOGIC //////////////////////////////////////////////////////////////*/ function permit( address owner, address spender, uint256 value, uint256 deadline, uint8 v, bytes32 r, bytes32 s ) public virtual { require(deadline >= block.timestamp, "PERMIT_DEADLINE_EXPIRED"); // Unchecked because the only math done is incrementing // the owner's nonce which cannot realistically overflow. unchecked { address recoveredAddress = ecrecover( keccak256( abi.encodePacked( "\x19\x01", DOMAIN_SEPARATOR(), keccak256( abi.encode( keccak256( "Permit(address owner,address spender,uint256 value,uint256 nonce,uint256 deadline)" ), owner, spender, value, nonces[owner]++, deadline ) ) ) ), v, r, s ); require(recoveredAddress != address(0) && recoveredAddress == owner, "INVALID_SIGNER"); allowance[recoveredAddress][spender] = value; } emit Approval(owner, spender, value); } function DOMAIN_SEPARATOR() public view virtual returns (bytes32) { return block.chainid == INITIAL_CHAIN_ID ? INITIAL_DOMAIN_SEPARATOR : computeDomainSeparator(); } function computeDomainSeparator() internal view virtual returns (bytes32) { return keccak256( abi.encode( keccak256("EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)"), keccak256(bytes(name)), keccak256("1"), block.chainid, address(this) ) ); } /*////////////////////////////////////////////////////////////// INTERNAL MINT/BURN LOGIC //////////////////////////////////////////////////////////////*/ function _mint(address to, uint256 amount) internal virtual { totalSupply += amount; // Cannot overflow because the sum of all user // balances can't exceed the max uint256 value. unchecked { balanceOf[to] += amount; } emit Transfer(address(0), to, amount); } function _burn(address from, uint256 amount) internal virtual { balanceOf[from] -= amount; // Cannot underflow because a user's balance // will never be larger than the total supply. unchecked { totalSupply -= amount; } emit Transfer(from, address(0), amount); } }
// SPDX-License-Identifier: AGPL-3.0-only pragma solidity >=0.8.0; import {ERC20} from "./ERC20.sol"; import {SafeTransferLib} from "../utils/SafeTransferLib.sol"; /// @notice Minimalist and modern Wrapped Ether implementation. /// @author Solmate (https://github.com/transmissions11/solmate/blob/main/src/tokens/WETH.sol) /// @author Inspired by WETH9 (https://github.com/dapphub/ds-weth/blob/master/src/weth9.sol) contract WETH is ERC20("Wrapped Ether", "WETH", 18) { using SafeTransferLib for address; event Deposit(address indexed from, uint256 amount); event Withdrawal(address indexed to, uint256 amount); function deposit() public payable virtual { _mint(msg.sender, msg.value); emit Deposit(msg.sender, msg.value); } function withdraw(uint256 amount) public virtual { _burn(msg.sender, amount); emit Withdrawal(msg.sender, amount); msg.sender.safeTransferETH(amount); } receive() external payable virtual { deposit(); } }
// SPDX-License-Identifier: AGPL-3.0-only pragma solidity >=0.8.0; /// @notice Simple single owner authorization mixin. /// @author Solmate (https://github.com/transmissions11/solmate/blob/main/src/auth/Owned.sol) abstract contract Owned { /*////////////////////////////////////////////////////////////// EVENTS //////////////////////////////////////////////////////////////*/ event OwnershipTransferred(address indexed user, address indexed newOwner); /*////////////////////////////////////////////////////////////// OWNERSHIP STORAGE //////////////////////////////////////////////////////////////*/ address public owner; modifier onlyOwner() virtual { require(msg.sender == owner, "UNAUTHORIZED"); _; } /*////////////////////////////////////////////////////////////// CONSTRUCTOR //////////////////////////////////////////////////////////////*/ constructor(address _owner) { owner = _owner; emit OwnershipTransferred(address(0), _owner); } /*////////////////////////////////////////////////////////////// OWNERSHIP LOGIC //////////////////////////////////////////////////////////////*/ function transferOwnership(address newOwner) public virtual onlyOwner { owner = newOwner; emit OwnershipTransferred(msg.sender, newOwner); } }
// SPDX-License-Identifier: AGPL-3.0-only pragma solidity >=0.8.0; import {ERC20} from "../tokens/ERC20.sol"; /// @notice Safe ETH and ERC20 transfer library that gracefully handles missing return values. /// @author Solmate (https://github.com/transmissions11/solmate/blob/main/src/utils/SafeTransferLib.sol) /// @dev Use with caution! Some functions in this library knowingly create dirty bits at the destination of the free memory pointer. /// @dev Note that none of the functions in this library check that a token has code at all! That responsibility is delegated to the caller. library SafeTransferLib { /*////////////////////////////////////////////////////////////// ETH OPERATIONS //////////////////////////////////////////////////////////////*/ function safeTransferETH(address to, uint256 amount) internal { bool success; /// @solidity memory-safe-assembly assembly { // Transfer the ETH and store if it succeeded or not. success := call(gas(), to, amount, 0, 0, 0, 0) } require(success, "ETH_TRANSFER_FAILED"); } /*////////////////////////////////////////////////////////////// ERC20 OPERATIONS //////////////////////////////////////////////////////////////*/ function safeTransferFrom( ERC20 token, address from, address to, uint256 amount ) internal { bool success; /// @solidity memory-safe-assembly assembly { // Get a pointer to some free memory. let freeMemoryPointer := mload(0x40) // Write the abi-encoded calldata into memory, beginning with the function selector. mstore(freeMemoryPointer, 0x23b872dd00000000000000000000000000000000000000000000000000000000) mstore(add(freeMemoryPointer, 4), and(from, 0xffffffffffffffffffffffffffffffffffffffff)) // Append and mask the "from" argument. mstore(add(freeMemoryPointer, 36), and(to, 0xffffffffffffffffffffffffffffffffffffffff)) // Append and mask the "to" argument. mstore(add(freeMemoryPointer, 68), amount) // Append the "amount" argument. Masking not required as it's a full 32 byte type. success := and( // Set success to whether the call reverted, if not we check it either // returned exactly 1 (can't just be non-zero data), or had no return data. or(and(eq(mload(0), 1), gt(returndatasize(), 31)), iszero(returndatasize())), // We use 100 because the length of our calldata totals up like so: 4 + 32 * 3. // We use 0 and 32 to copy up to 32 bytes of return data into the scratch space. // Counterintuitively, this call must be positioned second to the or() call in the // surrounding and() call or else returndatasize() will be zero during the computation. call(gas(), token, 0, freeMemoryPointer, 100, 0, 32) ) } require(success, "TRANSFER_FROM_FAILED"); } function safeTransfer( ERC20 token, address to, uint256 amount ) internal { bool success; /// @solidity memory-safe-assembly assembly { // Get a pointer to some free memory. let freeMemoryPointer := mload(0x40) // Write the abi-encoded calldata into memory, beginning with the function selector. mstore(freeMemoryPointer, 0xa9059cbb00000000000000000000000000000000000000000000000000000000) mstore(add(freeMemoryPointer, 4), and(to, 0xffffffffffffffffffffffffffffffffffffffff)) // Append and mask the "to" argument. mstore(add(freeMemoryPointer, 36), amount) // Append the "amount" argument. Masking not required as it's a full 32 byte type. success := and( // Set success to whether the call reverted, if not we check it either // returned exactly 1 (can't just be non-zero data), or had no return data. or(and(eq(mload(0), 1), gt(returndatasize(), 31)), iszero(returndatasize())), // We use 68 because the length of our calldata totals up like so: 4 + 32 * 2. // We use 0 and 32 to copy up to 32 bytes of return data into the scratch space. // Counterintuitively, this call must be positioned second to the or() call in the // surrounding and() call or else returndatasize() will be zero during the computation. call(gas(), token, 0, freeMemoryPointer, 68, 0, 32) ) } require(success, "TRANSFER_FAILED"); } function safeApprove( ERC20 token, address to, uint256 amount ) internal { bool success; /// @solidity memory-safe-assembly assembly { // Get a pointer to some free memory. let freeMemoryPointer := mload(0x40) // Write the abi-encoded calldata into memory, beginning with the function selector. mstore(freeMemoryPointer, 0x095ea7b300000000000000000000000000000000000000000000000000000000) mstore(add(freeMemoryPointer, 4), and(to, 0xffffffffffffffffffffffffffffffffffffffff)) // Append and mask the "to" argument. mstore(add(freeMemoryPointer, 36), amount) // Append the "amount" argument. Masking not required as it's a full 32 byte type. success := and( // Set success to whether the call reverted, if not we check it either // returned exactly 1 (can't just be non-zero data), or had no return data. or(and(eq(mload(0), 1), gt(returndatasize(), 31)), iszero(returndatasize())), // We use 68 because the length of our calldata totals up like so: 4 + 32 * 2. // We use 0 and 32 to copy up to 32 bytes of return data into the scratch space. // Counterintuitively, this call must be positioned second to the or() call in the // surrounding and() call or else returndatasize() will be zero during the computation. call(gas(), token, 0, freeMemoryPointer, 68, 0, 32) ) } require(success, "APPROVE_FAILED"); } }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.13; interface IUniswapV2Factory { function createPair( address tokenA, address tokenB ) external returns (address pair); }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.13; interface IUniswapV2Router { function factory() external pure returns (address); function WETH() external pure returns (address); function addLiquidity( address tokenA, address tokenB, uint256 amountADesired, uint256 amountBDesired, uint256 amountAMin, uint256 amountBMin, address to, uint256 deadline ) external returns (uint256 amountA, uint256 amountB, uint256 liquidity); function removeLiquidity( address tokenA, address tokenB, uint liquidity, uint amountAMin, uint amountBMin, address to, uint deadline ) external returns (uint amountA, uint amountB); function addLiquidityETH( address token, uint256 amountTokenDesired, uint256 amountTokenMin, uint256 amountETHMin, address to, uint256 deadline ) external payable returns (uint256 amountToken, uint256 amountETH, uint256 liquidity); function swapExactTokensForTokensSupportingFeeOnTransferTokens( uint256 amountIn, uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external; function swapExactETHForTokensSupportingFeeOnTransferTokens( uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external payable; function swapExactTokensForETHSupportingFeeOnTransferTokens( uint256 amountIn, uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external; }
{ "remappings": [ "ds-test/=lib/forge-std/lib/ds-test/src/", "forge-std/=lib/forge-std/src/", "solmate/=lib/solmate/src/" ], "optimizer": { "enabled": true, "runs": 200 }, "metadata": { "useLiteralContent": false, "bytecodeHash": "ipfs" }, "outputSelection": { "*": { "*": [ "evm.bytecode", "evm.deployedBytecode", "devdoc", "userdoc", "metadata", "abi" ] } }, "evmVersion": "london", "libraries": {} }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"inputs":[{"internalType":"address","name":"routerAddress","type":"address"},{"internalType":"address","name":"indexAddress","type":"address"},{"internalType":"address","name":"devWallet","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[],"name":"Milady__BlacklistModificationDisabled","type":"error"},{"inputs":[],"name":"Milady__BuyAmountGreaterThanMax","type":"error"},{"inputs":[],"name":"Milady__CannotBlacklistLPPair","type":"error"},{"inputs":[],"name":"Milady__CannotBlacklistRouter","type":"error"},{"inputs":[],"name":"Milady__CannotRemovePairFromAMMs","type":"error"},{"inputs":[],"name":"Milady__CannotTransferFromAddressZero","type":"error"},{"inputs":[],"name":"Milady__CannotTransferToAddressZero","type":"error"},{"inputs":[],"name":"Milady__ErrorWithdrawingEth","type":"error"},{"inputs":[],"name":"Milady__FeeChangeRenounced","type":"error"},{"inputs":[],"name":"Milady__MaxFeeFivePercent","type":"error"},{"inputs":[],"name":"Milady__MaxTransactionTooLow","type":"error"},{"inputs":[],"name":"Milady__MaxWalletAmountExceeded","type":"error"},{"inputs":[],"name":"Milady__MaxWalletAmountTooLow","type":"error"},{"inputs":[],"name":"Milady__OnlyOwner","type":"error"},{"inputs":[],"name":"Milady__ReceiverBlacklisted","type":"error"},{"inputs":[],"name":"Milady__ReceiverCannotBeAddressZero","type":"error"},{"inputs":[],"name":"Milady__SellAmountGreaterThanMax","type":"error"},{"inputs":[],"name":"Milady__SenderBlacklisted","type":"error"},{"inputs":[],"name":"Milady__StuckEthWithdrawError","type":"error"},{"inputs":[],"name":"Milady__SwapAmountGreaterThanMaximum","type":"error"},{"inputs":[],"name":"Milady__SwapAmountLowerThanMinimum","type":"error"},{"inputs":[],"name":"Milady__TokenAddressCannotBeAddressZero","type":"error"},{"inputs":[],"name":"Milady__TradingNotActive","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":"amount","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":"ExcludeFromMaxTransaction","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"destination","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"FailedSwapBackTransfer","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"newAmount","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"oldAmount","type":"uint256"}],"name":"MaxTransactionAmountUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","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":false,"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"}],"name":"SwapAndLiquify","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"newAmount","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"oldAmount","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":"amount","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[],"name":"DOMAIN_SEPARATOR","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MAX_SUPPLY","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MAX_SWAP_AMOUNT","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MIN_SWAP_AMOUNT","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"address","name":"","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":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"blacklist","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"burn","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"developmentWallet","outputs":[{"internalType":"address","name":"","type":"address"}],"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":"isExcluded","type":"bool"}],"name":"excludeFromMaxTransaction","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"feeAmounts","outputs":[{"internalType":"uint8","name":"buy","type":"uint8"},{"internalType":"uint8","name":"sell","type":"uint8"},{"internalType":"uint8","name":"liquidity","type":"uint8"},{"internalType":"uint8","name":"index","type":"uint8"},{"internalType":"uint8","name":"development","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"index","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"pair","type":"address"}],"name":"isAutomatedMarketMakerPair","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"isBlacklistRenounced","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"isBlacklisted","outputs":[{"internalType":"bool","name":"","type":"bool"}],"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":"isExcludedFromMaxTransactionAmount","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"isFeeChangeRenounced","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"isLimitInEffect","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"isSwapEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"isTradingActive","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxTransactionAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxWallet","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"nonces","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"},{"internalType":"uint256","name":"deadline","type":"uint256"},{"internalType":"uint8","name":"v","type":"uint8"},{"internalType":"bytes32","name":"r","type":"bytes32"},{"internalType":"bytes32","name":"s","type":"bytes32"}],"name":"permit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"removeLimits","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceBlacklist","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"pair","type":"address"},{"internalType":"bool","name":"value","type":"bool"}],"name":"setAutomatedMarketMakerPair","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"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":"tokensForBotProtection","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","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":[{"internalType":"address","name":"account","type":"address"}],"name":"unblacklist","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"uniswapV2Pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"components":[{"internalType":"uint8","name":"buy","type":"uint8"},{"internalType":"uint8","name":"sell","type":"uint8"},{"internalType":"uint8","name":"liquidity","type":"uint8"},{"internalType":"uint8","name":"index","type":"uint8"},{"internalType":"uint8","name":"development","type":"uint8"}],"internalType":"struct Milady.Fees","name":"newFees","type":"tuple"}],"name":"updateFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newAmount","type":"uint256"}],"name":"updateMaxTransactionAmount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newAmount","type":"uint256"}],"name":"updateSwapTokensAtAmount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]
Contract Creation Code
61022060405260016101608190526101805260006101a08190526101c08190526101e081905261020052610101600d553480156200003c57600080fd5b5060405162003551380380620035518339810160408190526200005f9162000a84565b60408051808201825260068152654d696c61647960d01b60208083019182528351808501909452600c84526b09ad2d8c2c8f24092dcc8caf60a31b908401528151339391601291620000b491600091620009c1565b508151620000ca906001906020850190620009c1565b5060ff81166080524660a052620000e062000810565b60c0525050600680546001600160a01b0319166001600160a01b0384169081179091556040519091506000907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a3506001600160a01b038083166101205281811661014052831660e0819052604080516315ab88c960e31b8152905185929163ad5c46489160048083019260209291908290030181865afa1580156200018d573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620001b3919062000ace565b600f60006101000a8154816001600160a01b0302191690836001600160a01b03160217905550806001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa15801562000218573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200023e919062000ace565b6001600160a01b031663c9c6539630836001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa1580156200028c573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620002b2919062000ace565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af115801562000300573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019062000326919062000ace565b6001600160a01b0316610100526200034c60c86b033b2e3c9fd0803ce800000062000b09565b6007556200036860646b033b2e3c9fd0803ce800000062000b09565b600955612710620003876b033b2e3c9fd0803ce8000000600562000b2c565b62000393919062000b09565b6008819055506040518060a00160405280600560ff168152602001600560ff168152602001600a60ff168152602001604660ff168152602001601460ff16815250600b60008201518160000160006101000a81548160ff021916908360ff16021790555060208201518160000160016101000a81548160ff021916908360ff16021790555060408201518160000160026101000a81548160ff021916908360ff16021790555060608201518160000160036101000a81548160ff021916908360ff16021790555060808201518160000160046101000a81548160ff021916908360ff160217905550905050604051806080016040528060001515815260200160001515815260200160011515815260200160011515815250600e6000336001600160a01b03166001600160a01b0316815260200190815260200160002060008201518160000160006101000a81548160ff02191690831515021790555060208201518160000160016101000a81548160ff02191690831515021790555060408201518160000160026101000a81548160ff02191690831515021790555060608201518160000160036101000a81548160ff021916908315150217905550905050604051806080016040528060001515815260200160001515815260200160011515815260200160011515815250600e6000306001600160a01b03166001600160a01b0316815260200190815260200160002060008201518160000160006101000a81548160ff02191690831515021790555060208201518160000160016101000a81548160ff02191690831515021790555060408201518160000160026101000a81548160ff02191690831515021790555060608201518160000160036101000a81548160ff021916908315150217905550905050604051806080016040528060001515815260200160001515815260200160001515815260200160011515815250600e600060e0516001600160a01b03166001600160a01b0316815260200190815260200160002060008201518160000160006101000a81548160ff02191690831515021790555060208201518160000160016101000a81548160ff02191690831515021790555060408201518160000160026101000a81548160ff02191690831515021790555060608201518160000160036101000a81548160ff021916908315150217905550905050604051806080016040528060001515815260200160011515815260200160001515815260200160011515815250600e6000610100516001600160a01b03166001600160a01b0316815260200190815260200160002060008201518160000160006101000a81548160ff02191690831515021790555060208201518160000160016101000a81548160ff02191690831515021790555060408201518160000160026101000a81548160ff02191690831515021790555060608201518160000160036101000a81548160ff021916908315150217905550905050620007f5336b033b2e3c9fd0803ce8000000620008ac60201b60201c565b60e05162000806906000196200091a565b5050505062000c48565b60007f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f600060405162000844919062000b8a565b6040805191829003822060208301939093528101919091527fc89efdaa54c0f20c7adf612882df0950f5a951637e0307cdcb4c672f298b8bc660608201524660808201523060a082015260c00160405160208183030381529060405280519060200120905090565b8060026000828254620008c0919062000c2d565b90915550506001600160a01b0382166000818152600360209081526040808320805486019055518481527fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef91015b60405180910390a35050565b6006546001600160a01b03163314620009685760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b604482015260640160405180910390fd5b3060008181526004602090815260408083206001600160a01b03871680855290835292819020859055518481529192917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591016200090e565b828054620009cf9062000b4e565b90600052602060002090601f016020900481019282620009f3576000855562000a3e565b82601f1062000a0e57805160ff191683800117855562000a3e565b8280016001018555821562000a3e579182015b8281111562000a3e57825182559160200191906001019062000a21565b5062000a4c92915062000a50565b5090565b5b8082111562000a4c576000815560010162000a51565b80516001600160a01b038116811462000a7f57600080fd5b919050565b60008060006060848603121562000a9a57600080fd5b62000aa58462000a67565b925062000ab56020850162000a67565b915062000ac56040850162000a67565b90509250925092565b60006020828403121562000ae157600080fd5b62000aec8262000a67565b9392505050565b634e487b7160e01b600052601160045260246000fd5b60008262000b2757634e487b7160e01b600052601260045260246000fd5b500490565b600081600019048311821515161562000b495762000b4962000af3565b500290565b600181811c9082168062000b6357607f821691505b60208210810362000b8457634e487b7160e01b600052602260045260246000fd5b50919050565b600080835481600182811c91508083168062000ba757607f831692505b6020808410820362000bc757634e487b7160e01b86526022600452602486fd5b81801562000bde576001811462000bf05762000c1f565b60ff1986168952848901965062000c1f565b60008a81526020902060005b8681101562000c175781548b82015290850190830162000bfc565b505084890196505b509498975050505050505050565b6000821982111562000c435762000c4362000af3565b500190565b60805160a05160c05160e05161010051610120516101405161286862000ce9600039600081816107cd0152611e2c0152600081816103cd01528181610ee101528181611f3101526121b501526000818161050e01528181610e27015261142601526000818161030501528181611478015281816120550152818161210d01526121e301526000610c9301526000610c5e0152600061040101526128686000f3fe60806040526004361061028c5760003560e01c80638da5cb5b1161015a578063c53d4d53116100c1578063e2f456051161007a578063e2f45605146108bb578063e9481eee146108d1578063f2fde38b14610911578063f8b45b0514610931578063f9f92be414610947578063fe575a871461096757600080fd5b8063c53d4d53146107ef578063c8c8ebe41461080e578063cc10a17914610824578063d257b34f14610843578063d505accf14610863578063dd62ed3e1461088357600080fd5b8063a9059cbb11610113578063a9059cbb14610725578063aa49802314610745578063ba1618d514610765578063be1ded871461077d578063c02466681461079b578063c04a5414146107bb57600080fd5b80638da5cb5b1461068657806395d89b41146106a65780639759f76e146106bb57806399f34c12146106d05780639a7a23d6146106e55780639dc29fac1461070557600080fd5b80633644e515116101fe578063751039fc116101b7578063751039fc146105b15780637571336a146105c657806375e3661e146105e65780637949a403146106065780637ecebe00146106445780638a8c523c1461067157600080fd5b80633644e515146104725780633f17b1611461048757806349bd5a5e146104fc5780634fbee193146105305780635f1893611461056f57806370a082311461058457600080fd5b80631b624ecb116102505780631b624ecb1461038557806323b872dd1461039b5780632986c0e5146103bb578063313ce567146103ef57806332cb6b0c14610435578063351a964d1461045557600080fd5b806306fdde0314610298578063095ea7b3146102c35780631694505e146102f357806317ee89511461033f57806318160ddd1461036157600080fd5b3661029357005b600080fd5b3480156102a457600080fd5b506102ad6109a0565b6040516102ba91906122e0565b60405180910390f35b3480156102cf57600080fd5b506102e36102de36600461234d565b610a2e565b60405190151581526020016102ba565b3480156102ff57600080fd5b506103277f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b0390911681526020016102ba565b34801561034b57600080fd5b5061035f61035a36600461238f565b610a9a565b005b34801561036d57600080fd5b5061037760025481565b6040519081526020016102ba565b34801561039157600080fd5b50610377600a5481565b3480156103a757600080fd5b506102e36103b636600461242b565b610be5565b3480156103c757600080fd5b506103277f000000000000000000000000000000000000000000000000000000000000000081565b3480156103fb57600080fd5b506104237f000000000000000000000000000000000000000000000000000000000000000081565b60405160ff90911681526020016102ba565b34801561044157600080fd5b506103776b033b2e3c9fd0803ce800000081565b34801561046157600080fd5b50600d54610100900460ff166102e3565b34801561047e57600080fd5b50610377610c5a565b34801561049357600080fd5b50600b546104c89060ff80821691610100810482169162010000820481169163010000008104821691600160201b9091041685565b6040805160ff968716815294861660208601529285169284019290925283166060830152909116608082015260a0016102ba565b34801561050857600080fd5b506103277f000000000000000000000000000000000000000000000000000000000000000081565b34801561053c57600080fd5b506102e361054b36600461246c565b6001600160a01b03166000908152600e602052604090205462010000900460ff1690565b34801561057b57600080fd5b5061035f610cb5565b34801561059057600080fd5b5061037761059f36600461246c565b60036020526000908152604090205481565b3480156105bd57600080fd5b5061035f610cd0565b3480156105d257600080fd5b5061035f6105e1366004612489565b610ce4565b3480156105f257600080fd5b5061035f61060136600461246c565b610d5b565b34801561061257600080fd5b506102e361062136600461246c565b6001600160a01b03166000908152600e6020526040902054610100900460ff1690565b34801561065057600080fd5b5061037761065f36600461246c565b60056020526000908152604090205481565b34801561067d57600080fd5b5061035f610d84565b34801561069257600080fd5b50600654610327906001600160a01b031681565b3480156106b257600080fd5b506102ad610dd0565b3480156106c757600080fd5b50610377610ddd565b3480156106dc57600080fd5b50610377610e04565b3480156106f157600080fd5b5061035f610700366004612489565b610e1d565b34801561071157600080fd5b5061035f61072036600461234d565b610ed6565b34801561073157600080fd5b506102e361074036600461234d565b610f45565b34801561075157600080fd5b5061035f6107603660046124c7565b610f5c565b34801561077157600080fd5b50600d5460ff166102e3565b34801561078957600080fd5b50600d5462010000900460ff166102e3565b3480156107a757600080fd5b5061035f6107b6366004612489565b610fee565b3480156107c757600080fd5b506103277f000000000000000000000000000000000000000000000000000000000000000081565b3480156107fb57600080fd5b50600d54600160201b900460ff166102e3565b34801561081a57600080fd5b5061037760075481565b34801561083057600080fd5b50600d546301000000900460ff166102e3565b34801561084f57600080fd5b5061035f61085e3660046124c7565b611057565b34801561086f57600080fd5b5061035f61087e3660046124e0565b61111a565b34801561088f57600080fd5b5061037761089e36600461254e565b600460209081526000928352604080842090915290825290205481565b3480156108c757600080fd5b5061037760085481565b3480156108dd57600080fd5b506102e36108ec36600461246c565b6001600160a01b03166000908152600e60205260409020546301000000900460ff1690565b34801561091d57600080fd5b5061035f61092c36600461246c565b61135e565b34801561093d57600080fd5b5061037760095481565b34801561095357600080fd5b5061035f61096236600461246c565b6113f3565b34801561097357600080fd5b506102e361098236600461246c565b6001600160a01b03166000908152600e602052604090205460ff1690565b600080546109ad9061257c565b80601f01602080910402602001604051908101604052809291908181526020018280546109d99061257c565b8015610a265780601f106109fb57610100808354040283529160200191610a26565b820191906000526020600020905b815481529060010190602001808311610a0957829003601f168201915b505050505081565b3360008181526004602090815260408083206001600160a01b038716808552925280832085905551919290917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92590610a899086815260200190565b60405180910390a350600192915050565b610aa26114ec565b6014816080015160ff161115610ad35760405162461bcd60e51b8152600401610aca906125b6565b60405180910390fd5b603c816060015160ff161015610afb5760405162461bcd60e51b8152600401610aca906125b6565b600a816040015160ff161015610b235760405162461bcd60e51b8152600401610aca906125b6565b806040015181606001518260800151610b3c91906125ec565b610b4691906125ec565b60ff16606414610b685760405162461bcd60e51b8152600401610aca906125b6565b8051600b805460208401516040850151606086015160809096015160ff908116600160201b0264ff000000001997821663010000000263ff0000001993831662010000029390931663ffff0000199483166101000261ffff1990961692909716919091179390931791909116939093179290921792909216179055565b6001600160a01b03831660009081526004602090815260408083203384529091528120546000198114610c4157610c1c8382612611565b6001600160a01b03861660009081526004602090815260408083203384529091529020555b610c4c858585611531565b5060019150505b9392505050565b60007f00000000000000000000000000000000000000000000000000000000000000004614610c9057610c8b611b35565b905090565b507f000000000000000000000000000000000000000000000000000000000000000090565b610cbd6114ec565b600d805462ff0000191662010000179055565b610cd86114ec565b600d805460ff19169055565b610cec6114ec565b6001600160a01b0382166000818152600e602052604090819020805484151563010000000263ff00000019909116179055517fe0a7c1f8826ab3d62a6e242681ccca3828462e5c87816004b9f8d655b22d5f0890610d4f90841515815260200190565b60405180910390a25050565b610d636114ec565b6001600160a01b03166000908152600e60205260409020805460ff19169055565b610d8c6114ec565b610d97436014612628565b600d805464ff00000000196001600160d81b039390931665010000000000029290921663ffffffff90921691909117600160201b179055565b600180546109ad9061257c565b6103e8610df76b033b2e3c9fd0803ce80000006005612653565b610e019190612672565b81565b610e01620186a06b033b2e3c9fd0803ce8000000612672565b610e256114ec565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316826001600160a01b031603610e7757604051630d07f64160e21b815260040160405180910390fd5b6001600160a01b0382166000818152600e60205260409081902080548415156101000261ff0019909116179055517fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab90610d4f90841515815260200190565b336001600160a01b037f00000000000000000000000000000000000000000000000000000000000000001614610f375760405162461bcd60e51b8152602060048201526006602482015265042d2dcc8caf60d31b6044820152606401610aca565b610f418282611bcf565b5050565b6000610f52338484611531565b5060019392505050565b610f646114ec565b6103e8610f7e6b033b2e3c9fd0803ce80000006005612653565b610f889190612672565b811015610fa857604051630663914d60e51b815260040160405180910390fd5b600780549082905560408051838152602081018390527fd40d861b6c61fb22040b4eb8de22cc4c267673593fef5c5880e2f55e75ef454891015b60405180910390a15050565b610ff66114ec565b6001600160a01b0382166000818152600e6020526040908190208054841515620100000262ff000019909116179055517f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df790610d4f90841515815260200190565b61105f6114ec565b611078620186a06b033b2e3c9fd0803ce8000000612672565b8110156110985760405163083352ff60e01b815260040160405180910390fd5b6103e86110b26b033b2e3c9fd0803ce80000006005612653565b6110bc9190612672565b8111156110dc57604051631a24c5b760e01b815260040160405180910390fd5b600880549082905560408051838152602081018390527febb96427ceba6a46f9f71146db5c30bc7e2fe31285e9bf34b38bbdede7cd5ea19101610fe2565b4284101561116a5760405162461bcd60e51b815260206004820152601760248201527f5045524d49545f444541444c494e455f455850495245440000000000000000006044820152606401610aca565b60006001611176610c5a565b6001600160a01b038a811660008181526005602090815260409182902080546001810190915582517f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c98184015280840194909452938d166060840152608083018c905260a083019390935260c08083018b90528151808403909101815260e08301909152805192019190912061190160f01b6101008301526101028201929092526101228101919091526101420160408051601f198184030181528282528051602091820120600084529083018083525260ff871690820152606081018590526080810184905260a0016020604051602081039080840390855afa158015611282573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b038116158015906112b85750876001600160a01b0316816001600160a01b0316145b6112f55760405162461bcd60e51b815260206004820152600e60248201526d24a72b20a624a22fa9a4a3a722a960911b6044820152606401610aca565b6001600160a01b0390811660009081526004602090815260408083208a8516808552908352928190208990555188815291928a16917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a350505050505050565b6006546001600160a01b031633146113a75760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b6044820152606401610aca565b600680546001600160a01b0319166001600160a01b03831690811790915560405133907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a350565b6113fb6114ec565b600d5462010000900460ff1615611424576040516293e92d60e81b815260040160405180910390fd5b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316816001600160a01b03160361147657604051631e5c182560e21b815260040160405180910390fd5b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316816001600160a01b0316036114c8576040516307869ffb60e21b815260040160405180910390fd5b6001600160a01b03166000908152600e60205260409020805460ff19166001179055565b6006546001600160a01b0316331461152f5760405162461bcd60e51b815260206004820152600660248201526510b7bbb732b960d11b6044820152606401610aca565b565b6001600160a01b038381166000908152600e60208181526040808420815160808082018452915460ff808216151583526101008083048216151584880152620100008084048316151585880152630100000093849004831615156060808701919091529a8d168a529787528589208651808701885290548084161515825282810484161515828a0152898104841615158289015284900483161515818c0152865160c081018852600d5480851615158252928304841615159881019890985297810482161515958701959095529084048116151597850197909752600160201b83049096161515908301819052650100000000009091046001600160d81b031660a083015292939261166857826040015161166857816040015161166857604051630c82b55d60e41b815260040160405180910390fd5b82511561168857604051633679262560e01b815260040160405180910390fd5b8151156116a857604051639103c6cb60e01b815260040160405180910390fd5b846000036116bc5760019350505050610c53565b60008360400151806116cf575082604001515b6020850151909150600390156116e7575060016116f5565b8360200151156116f5575060025b600c5460ff16611952578251156118b5578060ff16600114801561171b57508360600151155b156117dc57600754871115611743576040516336d2617f60e21b815260040160405180910390fd5b6009546040516370a0823160e01b81526001600160a01b038a16600482015230906370a0823190602401602060405180830381865afa15801561178a573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906117ae9190612694565b6117b890896126ad565b11156117d757604051636db85bd560e01b815260040160405180910390fd5b6118b5565b8060ff1660021480156117f157508460600151155b15611818576007548711156117d75760405162b7965d60e81b815260040160405180910390fd5b83606001516118b5576009546040516370a0823160e01b81526001600160a01b038a16600482015230906370a0823190602401602060405180830381865afa158015611868573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061188c9190612694565b61189690896126ad565b11156118b557604051636db85bd560e01b815260040160405180910390fd5b826020015115611952578060ff16600203611952576008546040516370a0823160e01b81523060048201819052906370a0823190602401602060405180830381865afa158015611909573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061192d9190612694565b1061195257600c805460ff19166001179055611947611c4a565b600c805460ff191690555b60038160ff161015611b1a57600c5460ff1615821561196f575060005b60008115611b17576040805160a081018252600b5460ff80821683526101008204811660208401526201000082048116938301939093526301000000810483166060830152600160201b900482166080820152908416600203611a0057602081015160ff16156119fb576064816020015160ff168b6119ee9190612653565b6119f89190612672565b91505b611a34565b8360ff16600103611a3457805160ff1615611a34578051606490611a279060ff168c612653565b611a319190612672565b91505b8560a001516001600160d81b0316431015611af6576000438760a001516001600160d81b0316611a649190612611565b9050605f6013821015611a9457611a7c826013612611565b611a87906005612653565b611a919082612611565b90505b60006064611aa2838f612653565b611aac9190612672565b9050611ace8f600660009054906101000a90046001600160a01b031687611f67565b50611ad9818e612611565b9c5080600a6000828254611aed91906126ad565b90915550505050505b611b00828b612611565b99508115611b1557611b138c3084611f67565b505b505b50505b611b25898989611f67565b5060019998505050505050505050565b60007f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f6000604051611b6791906126c5565b6040805191829003822060208301939093528101919091527fc89efdaa54c0f20c7adf612882df0950f5a951637e0307cdcb4c672f298b8bc660608201524660808201523060a082015260c00160405160208183030381529060405280519060200120905090565b6001600160a01b03821660009081526003602052604081208054839290611bf7908490612611565b90915550506002805482900390556040518181526000906001600160a01b038416907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35050565b6040516370a0823160e01b815230600482018190526000916370a0823190602401602060405180830381865afa158015611c88573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611cac9190612694565b6040805160a081018252600b5460ff80821683526101008204811660208401526201000082048116938301939093526301000000810483166060830152600160201b900490911660808201529091506000829003611d08575050565b60006008546014611d199190612653565b905080831115611d27578092505b60006064836040015160ff1685611d3e9190612653565b611d489190612672565b90506000611d57600283612672565b611d619083612611565b905047611d6d82611ffe565b6000611d798247612611565b9050600083118015611d8b5750600081115b15611dd457611d9a8382612183565b60408051848152602081018390527f28fc98272ce761178794ad6768050fea1648e07f1e2ffe15afd3a290f8381486910160405180910390a15b6000611de08589612611565b9050611deb81611ffe565b476000611df9846002612653565b611e0390836126ad565b9050600060648a6080015160ff1683611e1c9190612653565b611e269190612672565b905060007f00000000000000000000000000000000000000000000000000000000000000006001600160a01b03168260405160006040518083038185875af1925050503d8060008114611e95576040519150601f19603f3d011682016040523d82523d6000602084013e611e9a565b606091505b5050905080611ea857600080fd5b6000611eb48386612611565b9050600f60009054906101000a90046001600160a01b03166001600160a01b031663d0e30db0826040518263ffffffff1660e01b81526004016000604051808303818588803b158015611f0657600080fd5b505af1158015611f1a573d6000803e3d6000fd5b5050600f54611f5893506001600160a01b031691507f0000000000000000000000000000000000000000000000000000000000000000905083612259565b50505050505050505050505050565b6001600160a01b038316600090815260036020526040812080548391908390611f91908490612611565b90915550506001600160a01b03808416600081815260036020526040908190208054860190555190918616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90611fec9086815260200190565b60405180910390a35060019392505050565b604080516002808252606082018352600092602083019080368337019050509050308160008151811061203357612033612760565b60200260200101906001600160a01b031690816001600160a01b0316815250507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa1580156120b1573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906120d59190612776565b816001815181106120e8576120e8612760565b6001600160a01b03928316602091820292909201015260405163791ac94760e01b81527f00000000000000000000000000000000000000000000000000000000000000009091169063791ac9479061214d908590600090869030904290600401612793565b600060405180830381600087803b15801561216757600080fd5b505af115801561217b573d6000803e3d6000fd5b505050505050565b60405163f305d71960e01b81523060048201526024810183905260006044820181905260648201526001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000811660848301524260a48301527f0000000000000000000000000000000000000000000000000000000000000000169063f305d71990839060c40160606040518083038185885af115801561222d573d6000803e3d6000fd5b50505050506040513d601f19601f820116820180604052508101906122529190612804565b5050505050565b600060405163a9059cbb60e01b81526001600160a01b0384166004820152826024820152602060006044836000895af13d15601f3d11600160005114161716915050806122da5760405162461bcd60e51b815260206004820152600f60248201526e1514905394d1915497d19052531151608a1b6044820152606401610aca565b50505050565b600060208083528351808285015260005b8181101561230d578581018301518582016040015282016122f1565b8181111561231f576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b038116811461234a57600080fd5b50565b6000806040838503121561236057600080fd5b823561236b81612335565b946020939093013593505050565b803560ff8116811461238a57600080fd5b919050565b600060a082840312156123a157600080fd5b60405160a0810181811067ffffffffffffffff821117156123d257634e487b7160e01b600052604160045260246000fd5b6040526123de83612379565b81526123ec60208401612379565b60208201526123fd60408401612379565b604082015261240e60608401612379565b606082015261241f60808401612379565b60808201529392505050565b60008060006060848603121561244057600080fd5b833561244b81612335565b9250602084013561245b81612335565b929592945050506040919091013590565b60006020828403121561247e57600080fd5b8135610c5381612335565b6000806040838503121561249c57600080fd5b82356124a781612335565b9150602083013580151581146124bc57600080fd5b809150509250929050565b6000602082840312156124d957600080fd5b5035919050565b600080600080600080600060e0888a0312156124fb57600080fd5b873561250681612335565b9650602088013561251681612335565b9550604088013594506060880135935061253260808901612379565b925060a0880135915060c0880135905092959891949750929550565b6000806040838503121561256157600080fd5b823561256c81612335565b915060208301356124bc81612335565b600181811c9082168061259057607f821691505b6020821081036125b057634e487b7160e01b600052602260045260246000fd5b50919050565b602080825260069082015265085d985b1a5960d21b604082015260600190565b634e487b7160e01b600052601160045260246000fd5b600060ff821660ff84168060ff03821115612609576126096125d6565b019392505050565b600082821015612623576126236125d6565b500390565b60006001600160d81b0382811684821680830382111561264a5761264a6125d6565b01949350505050565b600081600019048311821515161561266d5761266d6125d6565b500290565b60008261268f57634e487b7160e01b600052601260045260246000fd5b500490565b6000602082840312156126a657600080fd5b5051919050565b600082198211156126c0576126c06125d6565b500190565b600080835481600182811c9150808316806126e157607f831692505b6020808410820361270057634e487b7160e01b86526022600452602486fd5b818015612714576001811461272557612752565b60ff19861689528489019650612752565b60008a81526020902060005b8681101561274a5781548b820152908501908301612731565b505084890196505b509498975050505050505050565b634e487b7160e01b600052603260045260246000fd5b60006020828403121561278857600080fd5b8151610c5381612335565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156127e35784516001600160a01b0316835293830193918301916001016127be565b50506001600160a01b03969096166060850152505050608001529392505050565b60008060006060848603121561281957600080fd5b835192506020840151915060408401519050925092509256fea26469706673582212204d66cf2162f8bbdd7724109a38ab198a83ce09765700e1d3c4a167265a1d662564736f6c634300080d00330000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d0000000000000000000000007b8db699c8bb60e683d24f8d74bb9970a2831197000000000000000000000000951b0d0a221a5d31ba14e29d9a32d2c9cbfc3fc1
Deployed Bytecode
0x60806040526004361061028c5760003560e01c80638da5cb5b1161015a578063c53d4d53116100c1578063e2f456051161007a578063e2f45605146108bb578063e9481eee146108d1578063f2fde38b14610911578063f8b45b0514610931578063f9f92be414610947578063fe575a871461096757600080fd5b8063c53d4d53146107ef578063c8c8ebe41461080e578063cc10a17914610824578063d257b34f14610843578063d505accf14610863578063dd62ed3e1461088357600080fd5b8063a9059cbb11610113578063a9059cbb14610725578063aa49802314610745578063ba1618d514610765578063be1ded871461077d578063c02466681461079b578063c04a5414146107bb57600080fd5b80638da5cb5b1461068657806395d89b41146106a65780639759f76e146106bb57806399f34c12146106d05780639a7a23d6146106e55780639dc29fac1461070557600080fd5b80633644e515116101fe578063751039fc116101b7578063751039fc146105b15780637571336a146105c657806375e3661e146105e65780637949a403146106065780637ecebe00146106445780638a8c523c1461067157600080fd5b80633644e515146104725780633f17b1611461048757806349bd5a5e146104fc5780634fbee193146105305780635f1893611461056f57806370a082311461058457600080fd5b80631b624ecb116102505780631b624ecb1461038557806323b872dd1461039b5780632986c0e5146103bb578063313ce567146103ef57806332cb6b0c14610435578063351a964d1461045557600080fd5b806306fdde0314610298578063095ea7b3146102c35780631694505e146102f357806317ee89511461033f57806318160ddd1461036157600080fd5b3661029357005b600080fd5b3480156102a457600080fd5b506102ad6109a0565b6040516102ba91906122e0565b60405180910390f35b3480156102cf57600080fd5b506102e36102de36600461234d565b610a2e565b60405190151581526020016102ba565b3480156102ff57600080fd5b506103277f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d81565b6040516001600160a01b0390911681526020016102ba565b34801561034b57600080fd5b5061035f61035a36600461238f565b610a9a565b005b34801561036d57600080fd5b5061037760025481565b6040519081526020016102ba565b34801561039157600080fd5b50610377600a5481565b3480156103a757600080fd5b506102e36103b636600461242b565b610be5565b3480156103c757600080fd5b506103277f0000000000000000000000007b8db699c8bb60e683d24f8d74bb9970a283119781565b3480156103fb57600080fd5b506104237f000000000000000000000000000000000000000000000000000000000000001281565b60405160ff90911681526020016102ba565b34801561044157600080fd5b506103776b033b2e3c9fd0803ce800000081565b34801561046157600080fd5b50600d54610100900460ff166102e3565b34801561047e57600080fd5b50610377610c5a565b34801561049357600080fd5b50600b546104c89060ff80821691610100810482169162010000820481169163010000008104821691600160201b9091041685565b6040805160ff968716815294861660208601529285169284019290925283166060830152909116608082015260a0016102ba565b34801561050857600080fd5b506103277f00000000000000000000000050507364f0843a9e53d89e869a30cc1a7519a93b81565b34801561053c57600080fd5b506102e361054b36600461246c565b6001600160a01b03166000908152600e602052604090205462010000900460ff1690565b34801561057b57600080fd5b5061035f610cb5565b34801561059057600080fd5b5061037761059f36600461246c565b60036020526000908152604090205481565b3480156105bd57600080fd5b5061035f610cd0565b3480156105d257600080fd5b5061035f6105e1366004612489565b610ce4565b3480156105f257600080fd5b5061035f61060136600461246c565b610d5b565b34801561061257600080fd5b506102e361062136600461246c565b6001600160a01b03166000908152600e6020526040902054610100900460ff1690565b34801561065057600080fd5b5061037761065f36600461246c565b60056020526000908152604090205481565b34801561067d57600080fd5b5061035f610d84565b34801561069257600080fd5b50600654610327906001600160a01b031681565b3480156106b257600080fd5b506102ad610dd0565b3480156106c757600080fd5b50610377610ddd565b3480156106dc57600080fd5b50610377610e04565b3480156106f157600080fd5b5061035f610700366004612489565b610e1d565b34801561071157600080fd5b5061035f61072036600461234d565b610ed6565b34801561073157600080fd5b506102e361074036600461234d565b610f45565b34801561075157600080fd5b5061035f6107603660046124c7565b610f5c565b34801561077157600080fd5b50600d5460ff166102e3565b34801561078957600080fd5b50600d5462010000900460ff166102e3565b3480156107a757600080fd5b5061035f6107b6366004612489565b610fee565b3480156107c757600080fd5b506103277f000000000000000000000000951b0d0a221a5d31ba14e29d9a32d2c9cbfc3fc181565b3480156107fb57600080fd5b50600d54600160201b900460ff166102e3565b34801561081a57600080fd5b5061037760075481565b34801561083057600080fd5b50600d546301000000900460ff166102e3565b34801561084f57600080fd5b5061035f61085e3660046124c7565b611057565b34801561086f57600080fd5b5061035f61087e3660046124e0565b61111a565b34801561088f57600080fd5b5061037761089e36600461254e565b600460209081526000928352604080842090915290825290205481565b3480156108c757600080fd5b5061037760085481565b3480156108dd57600080fd5b506102e36108ec36600461246c565b6001600160a01b03166000908152600e60205260409020546301000000900460ff1690565b34801561091d57600080fd5b5061035f61092c36600461246c565b61135e565b34801561093d57600080fd5b5061037760095481565b34801561095357600080fd5b5061035f61096236600461246c565b6113f3565b34801561097357600080fd5b506102e361098236600461246c565b6001600160a01b03166000908152600e602052604090205460ff1690565b600080546109ad9061257c565b80601f01602080910402602001604051908101604052809291908181526020018280546109d99061257c565b8015610a265780601f106109fb57610100808354040283529160200191610a26565b820191906000526020600020905b815481529060010190602001808311610a0957829003601f168201915b505050505081565b3360008181526004602090815260408083206001600160a01b038716808552925280832085905551919290917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92590610a899086815260200190565b60405180910390a350600192915050565b610aa26114ec565b6014816080015160ff161115610ad35760405162461bcd60e51b8152600401610aca906125b6565b60405180910390fd5b603c816060015160ff161015610afb5760405162461bcd60e51b8152600401610aca906125b6565b600a816040015160ff161015610b235760405162461bcd60e51b8152600401610aca906125b6565b806040015181606001518260800151610b3c91906125ec565b610b4691906125ec565b60ff16606414610b685760405162461bcd60e51b8152600401610aca906125b6565b8051600b805460208401516040850151606086015160809096015160ff908116600160201b0264ff000000001997821663010000000263ff0000001993831662010000029390931663ffff0000199483166101000261ffff1990961692909716919091179390931791909116939093179290921792909216179055565b6001600160a01b03831660009081526004602090815260408083203384529091528120546000198114610c4157610c1c8382612611565b6001600160a01b03861660009081526004602090815260408083203384529091529020555b610c4c858585611531565b5060019150505b9392505050565b60007f00000000000000000000000000000000000000000000000000000000000000014614610c9057610c8b611b35565b905090565b507f03a5d3d85e83fbb37adc1d86b298a0d722569a0195af174a37b960bb186415a890565b610cbd6114ec565b600d805462ff0000191662010000179055565b610cd86114ec565b600d805460ff19169055565b610cec6114ec565b6001600160a01b0382166000818152600e602052604090819020805484151563010000000263ff00000019909116179055517fe0a7c1f8826ab3d62a6e242681ccca3828462e5c87816004b9f8d655b22d5f0890610d4f90841515815260200190565b60405180910390a25050565b610d636114ec565b6001600160a01b03166000908152600e60205260409020805460ff19169055565b610d8c6114ec565b610d97436014612628565b600d805464ff00000000196001600160d81b039390931665010000000000029290921663ffffffff90921691909117600160201b179055565b600180546109ad9061257c565b6103e8610df76b033b2e3c9fd0803ce80000006005612653565b610e019190612672565b81565b610e01620186a06b033b2e3c9fd0803ce8000000612672565b610e256114ec565b7f00000000000000000000000050507364f0843a9e53d89e869a30cc1a7519a93b6001600160a01b0316826001600160a01b031603610e7757604051630d07f64160e21b815260040160405180910390fd5b6001600160a01b0382166000818152600e60205260409081902080548415156101000261ff0019909116179055517fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab90610d4f90841515815260200190565b336001600160a01b037f0000000000000000000000007b8db699c8bb60e683d24f8d74bb9970a28311971614610f375760405162461bcd60e51b8152602060048201526006602482015265042d2dcc8caf60d31b6044820152606401610aca565b610f418282611bcf565b5050565b6000610f52338484611531565b5060019392505050565b610f646114ec565b6103e8610f7e6b033b2e3c9fd0803ce80000006005612653565b610f889190612672565b811015610fa857604051630663914d60e51b815260040160405180910390fd5b600780549082905560408051838152602081018390527fd40d861b6c61fb22040b4eb8de22cc4c267673593fef5c5880e2f55e75ef454891015b60405180910390a15050565b610ff66114ec565b6001600160a01b0382166000818152600e6020526040908190208054841515620100000262ff000019909116179055517f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df790610d4f90841515815260200190565b61105f6114ec565b611078620186a06b033b2e3c9fd0803ce8000000612672565b8110156110985760405163083352ff60e01b815260040160405180910390fd5b6103e86110b26b033b2e3c9fd0803ce80000006005612653565b6110bc9190612672565b8111156110dc57604051631a24c5b760e01b815260040160405180910390fd5b600880549082905560408051838152602081018390527febb96427ceba6a46f9f71146db5c30bc7e2fe31285e9bf34b38bbdede7cd5ea19101610fe2565b4284101561116a5760405162461bcd60e51b815260206004820152601760248201527f5045524d49545f444541444c494e455f455850495245440000000000000000006044820152606401610aca565b60006001611176610c5a565b6001600160a01b038a811660008181526005602090815260409182902080546001810190915582517f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c98184015280840194909452938d166060840152608083018c905260a083019390935260c08083018b90528151808403909101815260e08301909152805192019190912061190160f01b6101008301526101028201929092526101228101919091526101420160408051601f198184030181528282528051602091820120600084529083018083525260ff871690820152606081018590526080810184905260a0016020604051602081039080840390855afa158015611282573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b038116158015906112b85750876001600160a01b0316816001600160a01b0316145b6112f55760405162461bcd60e51b815260206004820152600e60248201526d24a72b20a624a22fa9a4a3a722a960911b6044820152606401610aca565b6001600160a01b0390811660009081526004602090815260408083208a8516808552908352928190208990555188815291928a16917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a350505050505050565b6006546001600160a01b031633146113a75760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b6044820152606401610aca565b600680546001600160a01b0319166001600160a01b03831690811790915560405133907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a350565b6113fb6114ec565b600d5462010000900460ff1615611424576040516293e92d60e81b815260040160405180910390fd5b7f00000000000000000000000050507364f0843a9e53d89e869a30cc1a7519a93b6001600160a01b0316816001600160a01b03160361147657604051631e5c182560e21b815260040160405180910390fd5b7f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b0316816001600160a01b0316036114c8576040516307869ffb60e21b815260040160405180910390fd5b6001600160a01b03166000908152600e60205260409020805460ff19166001179055565b6006546001600160a01b0316331461152f5760405162461bcd60e51b815260206004820152600660248201526510b7bbb732b960d11b6044820152606401610aca565b565b6001600160a01b038381166000908152600e60208181526040808420815160808082018452915460ff808216151583526101008083048216151584880152620100008084048316151585880152630100000093849004831615156060808701919091529a8d168a529787528589208651808701885290548084161515825282810484161515828a0152898104841615158289015284900483161515818c0152865160c081018852600d5480851615158252928304841615159881019890985297810482161515958701959095529084048116151597850197909752600160201b83049096161515908301819052650100000000009091046001600160d81b031660a083015292939261166857826040015161166857816040015161166857604051630c82b55d60e41b815260040160405180910390fd5b82511561168857604051633679262560e01b815260040160405180910390fd5b8151156116a857604051639103c6cb60e01b815260040160405180910390fd5b846000036116bc5760019350505050610c53565b60008360400151806116cf575082604001515b6020850151909150600390156116e7575060016116f5565b8360200151156116f5575060025b600c5460ff16611952578251156118b5578060ff16600114801561171b57508360600151155b156117dc57600754871115611743576040516336d2617f60e21b815260040160405180910390fd5b6009546040516370a0823160e01b81526001600160a01b038a16600482015230906370a0823190602401602060405180830381865afa15801561178a573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906117ae9190612694565b6117b890896126ad565b11156117d757604051636db85bd560e01b815260040160405180910390fd5b6118b5565b8060ff1660021480156117f157508460600151155b15611818576007548711156117d75760405162b7965d60e81b815260040160405180910390fd5b83606001516118b5576009546040516370a0823160e01b81526001600160a01b038a16600482015230906370a0823190602401602060405180830381865afa158015611868573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061188c9190612694565b61189690896126ad565b11156118b557604051636db85bd560e01b815260040160405180910390fd5b826020015115611952578060ff16600203611952576008546040516370a0823160e01b81523060048201819052906370a0823190602401602060405180830381865afa158015611909573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061192d9190612694565b1061195257600c805460ff19166001179055611947611c4a565b600c805460ff191690555b60038160ff161015611b1a57600c5460ff1615821561196f575060005b60008115611b17576040805160a081018252600b5460ff80821683526101008204811660208401526201000082048116938301939093526301000000810483166060830152600160201b900482166080820152908416600203611a0057602081015160ff16156119fb576064816020015160ff168b6119ee9190612653565b6119f89190612672565b91505b611a34565b8360ff16600103611a3457805160ff1615611a34578051606490611a279060ff168c612653565b611a319190612672565b91505b8560a001516001600160d81b0316431015611af6576000438760a001516001600160d81b0316611a649190612611565b9050605f6013821015611a9457611a7c826013612611565b611a87906005612653565b611a919082612611565b90505b60006064611aa2838f612653565b611aac9190612672565b9050611ace8f600660009054906101000a90046001600160a01b031687611f67565b50611ad9818e612611565b9c5080600a6000828254611aed91906126ad565b90915550505050505b611b00828b612611565b99508115611b1557611b138c3084611f67565b505b505b50505b611b25898989611f67565b5060019998505050505050505050565b60007f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f6000604051611b6791906126c5565b6040805191829003822060208301939093528101919091527fc89efdaa54c0f20c7adf612882df0950f5a951637e0307cdcb4c672f298b8bc660608201524660808201523060a082015260c00160405160208183030381529060405280519060200120905090565b6001600160a01b03821660009081526003602052604081208054839290611bf7908490612611565b90915550506002805482900390556040518181526000906001600160a01b038416907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35050565b6040516370a0823160e01b815230600482018190526000916370a0823190602401602060405180830381865afa158015611c88573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611cac9190612694565b6040805160a081018252600b5460ff80821683526101008204811660208401526201000082048116938301939093526301000000810483166060830152600160201b900490911660808201529091506000829003611d08575050565b60006008546014611d199190612653565b905080831115611d27578092505b60006064836040015160ff1685611d3e9190612653565b611d489190612672565b90506000611d57600283612672565b611d619083612611565b905047611d6d82611ffe565b6000611d798247612611565b9050600083118015611d8b5750600081115b15611dd457611d9a8382612183565b60408051848152602081018390527f28fc98272ce761178794ad6768050fea1648e07f1e2ffe15afd3a290f8381486910160405180910390a15b6000611de08589612611565b9050611deb81611ffe565b476000611df9846002612653565b611e0390836126ad565b9050600060648a6080015160ff1683611e1c9190612653565b611e269190612672565b905060007f000000000000000000000000951b0d0a221a5d31ba14e29d9a32d2c9cbfc3fc16001600160a01b03168260405160006040518083038185875af1925050503d8060008114611e95576040519150601f19603f3d011682016040523d82523d6000602084013e611e9a565b606091505b5050905080611ea857600080fd5b6000611eb48386612611565b9050600f60009054906101000a90046001600160a01b03166001600160a01b031663d0e30db0826040518263ffffffff1660e01b81526004016000604051808303818588803b158015611f0657600080fd5b505af1158015611f1a573d6000803e3d6000fd5b5050600f54611f5893506001600160a01b031691507f0000000000000000000000007b8db699c8bb60e683d24f8d74bb9970a2831197905083612259565b50505050505050505050505050565b6001600160a01b038316600090815260036020526040812080548391908390611f91908490612611565b90915550506001600160a01b03808416600081815260036020526040908190208054860190555190918616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90611fec9086815260200190565b60405180910390a35060019392505050565b604080516002808252606082018352600092602083019080368337019050509050308160008151811061203357612033612760565b60200260200101906001600160a01b031690816001600160a01b0316815250507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa1580156120b1573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906120d59190612776565b816001815181106120e8576120e8612760565b6001600160a01b03928316602091820292909201015260405163791ac94760e01b81527f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d9091169063791ac9479061214d908590600090869030904290600401612793565b600060405180830381600087803b15801561216757600080fd5b505af115801561217b573d6000803e3d6000fd5b505050505050565b60405163f305d71960e01b81523060048201526024810183905260006044820181905260648201526001600160a01b037f0000000000000000000000007b8db699c8bb60e683d24f8d74bb9970a2831197811660848301524260a48301527f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d169063f305d71990839060c40160606040518083038185885af115801561222d573d6000803e3d6000fd5b50505050506040513d601f19601f820116820180604052508101906122529190612804565b5050505050565b600060405163a9059cbb60e01b81526001600160a01b0384166004820152826024820152602060006044836000895af13d15601f3d11600160005114161716915050806122da5760405162461bcd60e51b815260206004820152600f60248201526e1514905394d1915497d19052531151608a1b6044820152606401610aca565b50505050565b600060208083528351808285015260005b8181101561230d578581018301518582016040015282016122f1565b8181111561231f576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b038116811461234a57600080fd5b50565b6000806040838503121561236057600080fd5b823561236b81612335565b946020939093013593505050565b803560ff8116811461238a57600080fd5b919050565b600060a082840312156123a157600080fd5b60405160a0810181811067ffffffffffffffff821117156123d257634e487b7160e01b600052604160045260246000fd5b6040526123de83612379565b81526123ec60208401612379565b60208201526123fd60408401612379565b604082015261240e60608401612379565b606082015261241f60808401612379565b60808201529392505050565b60008060006060848603121561244057600080fd5b833561244b81612335565b9250602084013561245b81612335565b929592945050506040919091013590565b60006020828403121561247e57600080fd5b8135610c5381612335565b6000806040838503121561249c57600080fd5b82356124a781612335565b9150602083013580151581146124bc57600080fd5b809150509250929050565b6000602082840312156124d957600080fd5b5035919050565b600080600080600080600060e0888a0312156124fb57600080fd5b873561250681612335565b9650602088013561251681612335565b9550604088013594506060880135935061253260808901612379565b925060a0880135915060c0880135905092959891949750929550565b6000806040838503121561256157600080fd5b823561256c81612335565b915060208301356124bc81612335565b600181811c9082168061259057607f821691505b6020821081036125b057634e487b7160e01b600052602260045260246000fd5b50919050565b602080825260069082015265085d985b1a5960d21b604082015260600190565b634e487b7160e01b600052601160045260246000fd5b600060ff821660ff84168060ff03821115612609576126096125d6565b019392505050565b600082821015612623576126236125d6565b500390565b60006001600160d81b0382811684821680830382111561264a5761264a6125d6565b01949350505050565b600081600019048311821515161561266d5761266d6125d6565b500290565b60008261268f57634e487b7160e01b600052601260045260246000fd5b500490565b6000602082840312156126a657600080fd5b5051919050565b600082198211156126c0576126c06125d6565b500190565b600080835481600182811c9150808316806126e157607f831692505b6020808410820361270057634e487b7160e01b86526022600452602486fd5b818015612714576001811461272557612752565b60ff19861689528489019650612752565b60008a81526020902060005b8681101561274a5781548b820152908501908301612731565b505084890196505b509498975050505050505050565b634e487b7160e01b600052603260045260246000fd5b60006020828403121561278857600080fd5b8151610c5381612335565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156127e35784516001600160a01b0316835293830193918301916001016127be565b50506001600160a01b03969096166060850152505050608001529392505050565b60008060006060848603121561281957600080fd5b835192506020840151915060408401519050925092509256fea26469706673582212204d66cf2162f8bbdd7724109a38ab198a83ce09765700e1d3c4a167265a1d662564736f6c634300080d0033
Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)
0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d0000000000000000000000007b8db699c8bb60e683d24f8d74bb9970a2831197000000000000000000000000951b0d0a221a5d31ba14e29d9a32d2c9cbfc3fc1
-----Decoded View---------------
Arg [0] : routerAddress (address): 0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D
Arg [1] : indexAddress (address): 0x7B8Db699c8bb60E683d24F8d74bB9970A2831197
Arg [2] : devWallet (address): 0x951B0d0a221a5D31Ba14E29D9A32d2c9Cbfc3Fc1
-----Encoded View---------------
3 Constructor Arguments found :
Arg [0] : 0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d
Arg [1] : 0000000000000000000000007b8db699c8bb60e683d24f8d74bb9970a2831197
Arg [2] : 000000000000000000000000951b0d0a221a5d31ba14e29d9a32d2c9cbfc3fc1
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.