ERC-20
Overview
Max Total Supply
1,150,000,000,000,000 eArena
Holders
1,729
Market
Onchain Market Cap
$0.00
Circulating Supply Market Cap
-
Other Info
Token Contract (WITH 18 Decimals)
Balance
40,000,000,000 eArenaValue
$0.00Loading...
Loading
Loading...
Loading
Loading...
Loading
# | Exchange | Pair | Price | 24H Volume | % Volume |
---|
Contract Name:
ElectricArena
Compiler Version
v0.6.12+commit.27d51765
Contract Source Code (Solidity)
/** *Submitted for verification at Etherscan.io on 2021-09-26 */ pragma solidity ^0.6.12; library SafeMath { function add(uint256 a, uint256 b) internal pure returns (uint256) { uint256 c = a + b; require(c >= a, "SafeMath: addition overflow"); return c; } function sub(uint256 a, uint256 b) internal pure returns (uint256) { return sub(a, b, "SafeMath: subtraction overflow"); } function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b <= a, errorMessage); uint256 c = a - b; return c; } function mul(uint256 a, uint256 b) internal pure returns (uint256) { if (a == 0) { return 0; } uint256 c = a * b; require(c / a == b, "SafeMath: multiplication overflow"); return c; } function div(uint256 a, uint256 b) internal pure returns (uint256) { return div(a, b, "SafeMath: division by zero"); } function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b > 0, errorMessage); uint256 c = a / b; return c; } function mod(uint256 a, uint256 b) internal pure returns (uint256) { return mod(a, b, "SafeMath: modulo by zero"); } function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b != 0, errorMessage); return a % b; } } abstract contract Context { function _msgSender() internal view virtual returns (address) { return msg.sender; } } contract Ownable is Context { address private _owner; event OwnershipTransferred(address indexed previousOwner, address indexed newOwner); constructor () public { address msgSender = _msgSender(); _owner = msgSender; emit OwnershipTransferred(address(0), msgSender); } function owner() public view returns (address) { return _owner; } modifier onlyOwner() { require(_owner == _msgSender(), "Ownable: caller is not the owner"); _; } function renounceOwnership() public virtual onlyOwner { emit OwnershipTransferred(_owner, address(0)); _owner = address(0); } function transferOwnership(address newOwner) public virtual onlyOwner { require(newOwner != address(0), "Ownable: new owner is the zero address"); emit OwnershipTransferred(_owner, newOwner); _owner = newOwner; } } 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 balanceOf(address owner) 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 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; } 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 view 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 _balances; mapping(address => mapping(address => uint256)) private _allowances; uint256 private _totalSupply; string private _name; string private _symbol; /** * @dev Sets the values for {name} and {symbol}. * * The default value of {decimals} is 18. To select a different value for * {decimals} you should overload it. * * All two of these values are immutable: they can only be set once during * construction. */ constructor(string memory name_, string memory symbol_) public { _name = name_; _symbol = symbol_; } /** * @dev Returns the name of the token. */ function name() public view virtual override returns (string memory) { return _name; } /** * @dev Returns the symbol of the token, usually a shorter version of the * name. */ function symbol() public view virtual override returns (string memory) { return _symbol; } /** * @dev Returns the number of decimals used to get its user representation. * For example, if `decimals` equals `2`, a balance of `505` tokens should * be displayed to a user as `5,05` (`505 / 10 ** 2`). * * Tokens usually opt for a value of 18, imitating the relationship between * Ether and Wei. This is the value {ERC20} uses, unless this function is * overridden; * * NOTE: This information is only used for _display_ purposes: it in * no way affects any of the arithmetic of the contract, including * {IERC20-balanceOf} and {IERC20-transfer}. */ function decimals() public view virtual override returns (uint8) { return 18; } /** * @dev See {IERC20-totalSupply}. */ function totalSupply() public view virtual override returns (uint256) { return _totalSupply; } /** * @dev See {IERC20-balanceOf}. */ function balanceOf(address account) public view virtual override returns (uint256) { return _balances[account]; } /** * @dev See {IERC20-transfer}. * * Requirements: * * - `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); _balances[sender] = _balances[sender].sub(amount, "ERC20: transfer amount exceeds balance"); _balances[recipient] = _balances[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 account, uint256 amount) internal virtual { require(account != address(0), "ERC20: mint to the zero address"); _beforeTokenTransfer(address(0), account, amount); _totalSupply = _totalSupply.add(amount); _balances[account] = _balances[account].add(amount); emit Transfer(address(0), account, amount); } /** * @dev Destroys `amount` tokens from `account`, reducing the * total supply. * * Emits a {Transfer} event with `to` set to the zero address. * * Requirements: * * - `account` cannot be the zero address. * - `account` must have at least `amount` tokens. */ function _burn(address account, uint256 amount) internal virtual { require(account != address(0), "ERC20: burn from the zero address"); _beforeTokenTransfer(account, address(0), amount); _balances[account] = _balances[account].sub(amount, "ERC20: burn amount exceeds balance"); _totalSupply = _totalSupply.sub(amount); emit Transfer(account, address(0), amount); } /** * @dev Sets `amount` as the allowance of `spender` over the `owner` s tokens. * * This internal function is equivalent to `approve`, and can be used to * e.g. set automatic allowances for certain subsystems, etc. * * Emits an {Approval} event. * * Requirements: * * - `owner` cannot be the zero address. * - `spender` cannot be the zero address. */ function _approve( address owner, address spender, uint256 amount ) internal virtual { require(owner != address(0), "ERC20: approve from the zero address"); require(spender != address(0), "ERC20: approve to the zero address"); _allowances[owner][spender] = amount; emit Approval(owner, spender, amount); } /** * @dev 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 {} } contract ElectricArena is ERC20, Ownable { using SafeMath for uint256; IUniswapV2Router02 public uniswapV2Router; address public immutable uniswapV2Pair; bool private swapping; uint256 public swapTokensAtAmount = 10**10 * (10**18); mapping (address => bool) private _isExcluded; constructor() public ERC20("ElectricArena", "eArena") { IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D); address _uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory()) .createPair(address(this), _uniswapV2Router.WETH()); uniswapV2Router = _uniswapV2Router; uniswapV2Pair = _uniswapV2Pair; _isExcluded[owner()] = true; _isExcluded[address(this)] = true; _mint(owner(), 115 * 10**13 * (10**18)); } receive() external payable { } function _transfer( address from, address to, uint256 amount ) internal override { require(from != address(0)); require(to != address(0)); if(amount == 0) { super._transfer(from, to, 0); return; } uint256 contractTokenBalance = balanceOf(address(this)); bool canSwap = contractTokenBalance >= swapTokensAtAmount; if( canSwap && !swapping && from != uniswapV2Pair && from != owner() && to != owner() ) { swapping = true; uint256 sellTokens = balanceOf(address(this)); swapAndSendDividends(sellTokens); swapping = false; } bool takeFee = !swapping; if(_isExcluded[from] || _isExcluded[to]) { takeFee = false; } if(takeFee && (to == uniswapV2Pair || from == uniswapV2Pair)) { uint256 fees = amount.mul(5).div(100); amount = amount.sub(fees); super._transfer(from, address(this), fees); } super._transfer(from, to, amount); } function swapTokensForEth(uint256 tokenAmount) private { address[] memory path = new address[](2); path[0] = address(this); path[1] = uniswapV2Router.WETH(); _approve(address(this), address(uniswapV2Router), tokenAmount); uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens( tokenAmount, 0, path, address(this), block.timestamp ); } function swapAndSendDividends(uint256 tokens) private { swapTokensForEth(tokens); payable(owner()).transfer(address(this).balance); } function airdrop(address[] memory _user, uint256[] memory _amount) external onlyOwner { uint256 len = _user.length; require(len == _amount.length); for (uint256 i = 0; i < len; i++) { super._transfer(_msgSender(), _user[i], _amount[i]); } } function setSwapAtAmount(uint256 amount) external onlyOwner { swapTokensAtAmount = amount; } }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[{"internalType":"address[]","name":"_user","type":"address[]"},{"internalType":"uint256[]","name":"_amount","type":"uint256[]"}],"name":"airdrop","outputs":[],"stateMutability":"nonpayable","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":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"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":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"setSwapAtAmount","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":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"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
60a06040526b204fce5e3e250261100000006007553480156200002157600080fd5b50604080518082018252600d81526c456c6563747269634172656e6160981b602080830191825283518085019094526006845265654172656e6160d01b9084015281519192916200007591600391620004a0565b5080516200008b906004906020840190620004a0565b5050506000620000a06200031760201b60201c565b600580546001600160a01b0319166001600160a01b038316908117909155604051919250906000907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a3506000737a250d5630b4cf539739df2c5dacb4c659f2488d90506000816001600160a01b031663c45a01556040518163ffffffff1660e01b815260040160206040518083038186803b1580156200014357600080fd5b505afa15801562000158573d6000803e3d6000fd5b505050506040513d60208110156200016f57600080fd5b5051604080516315ab88c960e31b815290516001600160a01b039283169263c9c653969230929187169163ad5c464891600480820192602092909190829003018186803b158015620001c057600080fd5b505afa158015620001d5573d6000803e3d6000fd5b505050506040513d6020811015620001ec57600080fd5b5051604080516001600160e01b031960e086901b1681526001600160a01b0393841660048201529290911660248301525160448083019260209291908290030181600087803b1580156200023f57600080fd5b505af115801562000254573d6000803e3d6000fd5b505050506040513d60208110156200026b57600080fd5b5051600680546001600160a01b0319166001600160a01b038516179055606081901b6001600160601b0319166080529050600160086000620002ac6200031b565b6001600160a01b0316815260208082019290925260409081016000908120805494151560ff1995861617905530815260089092529020805490911660011790556200030f620002fa6200031b565b6d38b30a686f9c8144c24b800000006200032a565b50506200053c565b3390565b6005546001600160a01b031690565b6001600160a01b03821662000386576040805162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f206164647265737300604482015290519081900360640190fd5b620003946000838362000439565b620003b0816002546200043e60201b62000c171790919060201c565b6002556001600160a01b03821660009081526020818152604090912054620003e391839062000c176200043e821b17901c565b6001600160a01b0383166000818152602081815260408083209490945583518581529351929391927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9281900390910190a35050565b505050565b60008282018381101562000499576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b9392505050565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f10620004e357805160ff191683800117855562000513565b8280016001018555821562000513579182015b8281111562000513578251825591602001919060010190620004f6565b506200052192915062000525565b5090565b5b8082111562000521576000815560010162000526565b60805160601c61168862000569600039806107ab5280610dd95280610ef65280610f3152506116886000f3fe6080604052600436106101485760003560e01c806367243482116100c0578063a457c2d711610074578063dd62ed3e11610059578063dd62ed3e14610583578063e2f45605146105be578063f2fde38b146105d35761014f565b8063a457c2d714610511578063a9059cbb1461054a5761014f565b8063715018a6116100a5578063715018a6146104d25780638da5cb5b146104e757806395d89b41146104fc5761014f565b8063672434821461036b57806370a082311461049f5761014f565b806323b872dd1161011757806339509351116100fc57806339509351146102f157806349bd5a5e1461032a5780636402511e1461033f5761014f565b806323b872dd14610283578063313ce567146102c65761014f565b806306fdde0314610154578063095ea7b3146101de5780631694505e1461022b57806318160ddd1461025c5761014f565b3661014f57005b600080fd5b34801561016057600080fd5b50610169610606565b6040805160208082528351818301528351919283929083019185019080838360005b838110156101a357818101518382015260200161018b565b50505050905090810190601f1680156101d05780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b3480156101ea57600080fd5b506102176004803603604081101561020157600080fd5b506001600160a01b03813516906020013561069c565b604080519115158252519081900360200190f35b34801561023757600080fd5b506102406106ba565b604080516001600160a01b039092168252519081900360200190f35b34801561026857600080fd5b506102716106c9565b60408051918252519081900360200190f35b34801561028f57600080fd5b50610217600480360360608110156102a657600080fd5b506001600160a01b038135811691602081013590911690604001356106cf565b3480156102d257600080fd5b506102db610756565b6040805160ff9092168252519081900360200190f35b3480156102fd57600080fd5b506102176004803603604081101561031457600080fd5b506001600160a01b03813516906020013561075b565b34801561033657600080fd5b506102406107a9565b34801561034b57600080fd5b506103696004803603602081101561036257600080fd5b50356107cd565b005b34801561037757600080fd5b506103696004803603604081101561038e57600080fd5b8101906020810181356401000000008111156103a957600080fd5b8201836020820111156103bb57600080fd5b803590602001918460208302840111640100000000831117156103dd57600080fd5b919080806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250929594936020810193503591505064010000000081111561042d57600080fd5b82018360208201111561043f57600080fd5b8035906020019184602083028401116401000000008311171561046157600080fd5b91908080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525092955061083c945050505050565b3480156104ab57600080fd5b50610271600480360360208110156104c257600080fd5b50356001600160a01b0316610906565b3480156104de57600080fd5b50610369610921565b3480156104f357600080fd5b506102406109e2565b34801561050857600080fd5b506101696109f1565b34801561051d57600080fd5b506102176004803603604081101561053457600080fd5b506001600160a01b038135169060200135610a52565b34801561055657600080fd5b506102176004803603604081101561056d57600080fd5b506001600160a01b038135169060200135610aba565b34801561058f57600080fd5b50610271600480360360408110156105a657600080fd5b506001600160a01b0381358116916020013516610ace565b3480156105ca57600080fd5b50610271610af9565b3480156105df57600080fd5b50610369600480360360208110156105f657600080fd5b50356001600160a01b0316610aff565b60038054604080516020601f60026000196101006001881615020190951694909404938401819004810282018101909252828152606093909290918301828280156106925780601f1061066757610100808354040283529160200191610692565b820191906000526020600020905b81548152906001019060200180831161067557829003601f168201915b5050505050905090565b60006106b06106a9610c78565b8484610c7c565b5060015b92915050565b6006546001600160a01b031681565b60025490565b60006106dc848484610d68565b61074c846106e8610c78565b610747856040518060600160405280602881526020016115bd602891396001600160a01b038a16600090815260016020526040812090610726610c78565b6001600160a01b031681526020810191909152604001600020549190610fb1565b610c7c565b5060019392505050565b601290565b60006106b0610768610c78565b846107478560016000610779610c78565b6001600160a01b03908116825260208083019390935260409182016000908120918c168152925290205490610c17565b7f000000000000000000000000000000000000000000000000000000000000000081565b6107d5610c78565b6005546001600160a01b03908116911614610837576040805162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015290519081900360640190fd5b600755565b610844610c78565b6005546001600160a01b039081169116146108a6576040805162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015290519081900360640190fd5b8151815181146108b557600080fd5b60005b81811015610900576108f86108cb610c78565b8583815181106108d757fe5b60200260200101518584815181106108eb57fe5b6020026020010151611048565b6001016108b8565b50505050565b6001600160a01b031660009081526020819052604090205490565b610929610c78565b6005546001600160a01b0390811691161461098b576040805162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015290519081900360640190fd5b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a36005805473ffffffffffffffffffffffffffffffffffffffff19169055565b6005546001600160a01b031690565b60048054604080516020601f60026000196101006001881615020190951694909404938401819004810282018101909252828152606093909290918301828280156106925780601f1061066757610100808354040283529160200191610692565b60006106b0610a5f610c78565b846107478560405180606001604052806025815260200161162e6025913960016000610a89610c78565b6001600160a01b03908116825260208083019390935260409182016000908120918d16815292529020549190610fb1565b60006106b0610ac7610c78565b8484610d68565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b60075481565b610b07610c78565b6005546001600160a01b03908116911614610b69576040805162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015290519081900360640190fd5b6001600160a01b038116610bae5760405162461bcd60e51b815260040180806020018281038252602681526020018061152e6026913960400191505060405180910390fd5b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a36005805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b600082820183811015610c71576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b9392505050565b3390565b6001600160a01b038316610cc15760405162461bcd60e51b815260040180806020018281038252602481526020018061160a6024913960400191505060405180910390fd5b6001600160a01b038216610d065760405162461bcd60e51b81526004018080602001828103825260228152602001806115546022913960400191505060405180910390fd5b6001600160a01b03808416600081815260016020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b6001600160a01b038316610d7b57600080fd5b6001600160a01b038216610d8e57600080fd5b80610da457610d9f83836000611048565b610fac565b6000610daf30610906565b60075490915081108015908190610dd05750600654600160a01b900460ff16155b8015610e0e57507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316856001600160a01b031614155b8015610e335750610e1d6109e2565b6001600160a01b0316856001600160a01b031614155b8015610e585750610e426109e2565b6001600160a01b0316846001600160a01b031614155b15610e95576006805460ff60a01b1916600160a01b1790556000610e7b30610906565b9050610e86816111a3565b506006805460ff60a01b191690555b6006546001600160a01b03861660009081526008602052604090205460ff600160a01b909204821615911680610ee357506001600160a01b03851660009081526008602052604090205460ff165b15610eec575060005b808015610f6557507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316856001600160a01b03161480610f6557507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316866001600160a01b0316145b15610f9d576000610f826064610f7c8760056111f0565b90611249565b9050610f8e858261128b565b9450610f9b873083611048565b505b610fa8868686611048565b5050505b505050565b600081848411156110405760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b83811015611005578181015183820152602001610fed565b50505050905090810190601f1680156110325780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b6001600160a01b03831661108d5760405162461bcd60e51b81526004018080602001828103825260258152602001806115e56025913960400191505060405180910390fd5b6001600160a01b0382166110d25760405162461bcd60e51b815260040180806020018281038252602381526020018061150b6023913960400191505060405180910390fd5b6110dd838383610fac565b61111a81604051806060016040528060268152602001611576602691396001600160a01b0386166000908152602081905260409020549190610fb1565b6001600160a01b0380851660009081526020819052604080822093909355908416815220546111499082610c17565b6001600160a01b038084166000818152602081815260409182902094909455805185815290519193928716927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef92918290030190a3505050565b6111ac816112cd565b6111b46109e2565b6001600160a01b03166108fc479081150290604051600060405180830381858888f193505050501580156111ec573d6000803e3d6000fd5b5050565b6000826111ff575060006106b4565b8282028284828161120c57fe5b0414610c715760405162461bcd60e51b815260040180806020018281038252602181526020018061159c6021913960400191505060405180910390fd5b6000610c7183836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506114a5565b6000610c7183836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250610fb1565b604080516002808252606080830184529260208301908036833701905050905030816000815181106112fb57fe5b6001600160a01b03928316602091820292909201810191909152600654604080517fad5c46480000000000000000000000000000000000000000000000000000000081529051919093169263ad5c4648926004808301939192829003018186803b15801561136857600080fd5b505afa15801561137c573d6000803e3d6000fd5b505050506040513d602081101561139257600080fd5b50518151829060019081106113a357fe5b6001600160a01b0392831660209182029290920101526006546113c99130911684610c7c565b6006546040517f791ac947000000000000000000000000000000000000000000000000000000008152600481018481526000602483018190523060648401819052426084850181905260a060448601908152875160a487015287516001600160a01b039097169663791ac947968a968a9594939092909160c40190602080880191028083838b5b83811015611468578181015183820152602001611450565b505050509050019650505050505050600060405180830381600087803b15801561149157600080fd5b505af1158015610fa8573d6000803e3d6000fd5b600081836114f45760405162461bcd60e51b8152602060048201818152835160248401528351909283926044909101919085019080838360008315611005578181015183820152602001610fed565b50600083858161150057fe5b049594505050505056fe45524332303a207472616e7366657220746f20746865207a65726f20616464726573734f776e61626c653a206e6577206f776e657220697320746865207a65726f206164647265737345524332303a20617070726f766520746f20746865207a65726f206164647265737345524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e6365536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f7745524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a207472616e736665722066726f6d20746865207a65726f206164647265737345524332303a20617070726f76652066726f6d20746865207a65726f206164647265737345524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220a624e3e0365ad76648525bafa09632977e13d8301d3bcf1955323b1f4d94c37b64736f6c634300060c0033
Deployed Bytecode
0x6080604052600436106101485760003560e01c806367243482116100c0578063a457c2d711610074578063dd62ed3e11610059578063dd62ed3e14610583578063e2f45605146105be578063f2fde38b146105d35761014f565b8063a457c2d714610511578063a9059cbb1461054a5761014f565b8063715018a6116100a5578063715018a6146104d25780638da5cb5b146104e757806395d89b41146104fc5761014f565b8063672434821461036b57806370a082311461049f5761014f565b806323b872dd1161011757806339509351116100fc57806339509351146102f157806349bd5a5e1461032a5780636402511e1461033f5761014f565b806323b872dd14610283578063313ce567146102c65761014f565b806306fdde0314610154578063095ea7b3146101de5780631694505e1461022b57806318160ddd1461025c5761014f565b3661014f57005b600080fd5b34801561016057600080fd5b50610169610606565b6040805160208082528351818301528351919283929083019185019080838360005b838110156101a357818101518382015260200161018b565b50505050905090810190601f1680156101d05780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b3480156101ea57600080fd5b506102176004803603604081101561020157600080fd5b506001600160a01b03813516906020013561069c565b604080519115158252519081900360200190f35b34801561023757600080fd5b506102406106ba565b604080516001600160a01b039092168252519081900360200190f35b34801561026857600080fd5b506102716106c9565b60408051918252519081900360200190f35b34801561028f57600080fd5b50610217600480360360608110156102a657600080fd5b506001600160a01b038135811691602081013590911690604001356106cf565b3480156102d257600080fd5b506102db610756565b6040805160ff9092168252519081900360200190f35b3480156102fd57600080fd5b506102176004803603604081101561031457600080fd5b506001600160a01b03813516906020013561075b565b34801561033657600080fd5b506102406107a9565b34801561034b57600080fd5b506103696004803603602081101561036257600080fd5b50356107cd565b005b34801561037757600080fd5b506103696004803603604081101561038e57600080fd5b8101906020810181356401000000008111156103a957600080fd5b8201836020820111156103bb57600080fd5b803590602001918460208302840111640100000000831117156103dd57600080fd5b919080806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250929594936020810193503591505064010000000081111561042d57600080fd5b82018360208201111561043f57600080fd5b8035906020019184602083028401116401000000008311171561046157600080fd5b91908080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525092955061083c945050505050565b3480156104ab57600080fd5b50610271600480360360208110156104c257600080fd5b50356001600160a01b0316610906565b3480156104de57600080fd5b50610369610921565b3480156104f357600080fd5b506102406109e2565b34801561050857600080fd5b506101696109f1565b34801561051d57600080fd5b506102176004803603604081101561053457600080fd5b506001600160a01b038135169060200135610a52565b34801561055657600080fd5b506102176004803603604081101561056d57600080fd5b506001600160a01b038135169060200135610aba565b34801561058f57600080fd5b50610271600480360360408110156105a657600080fd5b506001600160a01b0381358116916020013516610ace565b3480156105ca57600080fd5b50610271610af9565b3480156105df57600080fd5b50610369600480360360208110156105f657600080fd5b50356001600160a01b0316610aff565b60038054604080516020601f60026000196101006001881615020190951694909404938401819004810282018101909252828152606093909290918301828280156106925780601f1061066757610100808354040283529160200191610692565b820191906000526020600020905b81548152906001019060200180831161067557829003601f168201915b5050505050905090565b60006106b06106a9610c78565b8484610c7c565b5060015b92915050565b6006546001600160a01b031681565b60025490565b60006106dc848484610d68565b61074c846106e8610c78565b610747856040518060600160405280602881526020016115bd602891396001600160a01b038a16600090815260016020526040812090610726610c78565b6001600160a01b031681526020810191909152604001600020549190610fb1565b610c7c565b5060019392505050565b601290565b60006106b0610768610c78565b846107478560016000610779610c78565b6001600160a01b03908116825260208083019390935260409182016000908120918c168152925290205490610c17565b7f000000000000000000000000396ff45b933117809068b1e66529f5e226551b1b81565b6107d5610c78565b6005546001600160a01b03908116911614610837576040805162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015290519081900360640190fd5b600755565b610844610c78565b6005546001600160a01b039081169116146108a6576040805162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015290519081900360640190fd5b8151815181146108b557600080fd5b60005b81811015610900576108f86108cb610c78565b8583815181106108d757fe5b60200260200101518584815181106108eb57fe5b6020026020010151611048565b6001016108b8565b50505050565b6001600160a01b031660009081526020819052604090205490565b610929610c78565b6005546001600160a01b0390811691161461098b576040805162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015290519081900360640190fd5b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a36005805473ffffffffffffffffffffffffffffffffffffffff19169055565b6005546001600160a01b031690565b60048054604080516020601f60026000196101006001881615020190951694909404938401819004810282018101909252828152606093909290918301828280156106925780601f1061066757610100808354040283529160200191610692565b60006106b0610a5f610c78565b846107478560405180606001604052806025815260200161162e6025913960016000610a89610c78565b6001600160a01b03908116825260208083019390935260409182016000908120918d16815292529020549190610fb1565b60006106b0610ac7610c78565b8484610d68565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b60075481565b610b07610c78565b6005546001600160a01b03908116911614610b69576040805162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015290519081900360640190fd5b6001600160a01b038116610bae5760405162461bcd60e51b815260040180806020018281038252602681526020018061152e6026913960400191505060405180910390fd5b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a36005805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b600082820183811015610c71576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b9392505050565b3390565b6001600160a01b038316610cc15760405162461bcd60e51b815260040180806020018281038252602481526020018061160a6024913960400191505060405180910390fd5b6001600160a01b038216610d065760405162461bcd60e51b81526004018080602001828103825260228152602001806115546022913960400191505060405180910390fd5b6001600160a01b03808416600081815260016020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b6001600160a01b038316610d7b57600080fd5b6001600160a01b038216610d8e57600080fd5b80610da457610d9f83836000611048565b610fac565b6000610daf30610906565b60075490915081108015908190610dd05750600654600160a01b900460ff16155b8015610e0e57507f000000000000000000000000396ff45b933117809068b1e66529f5e226551b1b6001600160a01b0316856001600160a01b031614155b8015610e335750610e1d6109e2565b6001600160a01b0316856001600160a01b031614155b8015610e585750610e426109e2565b6001600160a01b0316846001600160a01b031614155b15610e95576006805460ff60a01b1916600160a01b1790556000610e7b30610906565b9050610e86816111a3565b506006805460ff60a01b191690555b6006546001600160a01b03861660009081526008602052604090205460ff600160a01b909204821615911680610ee357506001600160a01b03851660009081526008602052604090205460ff165b15610eec575060005b808015610f6557507f000000000000000000000000396ff45b933117809068b1e66529f5e226551b1b6001600160a01b0316856001600160a01b03161480610f6557507f000000000000000000000000396ff45b933117809068b1e66529f5e226551b1b6001600160a01b0316866001600160a01b0316145b15610f9d576000610f826064610f7c8760056111f0565b90611249565b9050610f8e858261128b565b9450610f9b873083611048565b505b610fa8868686611048565b5050505b505050565b600081848411156110405760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b83811015611005578181015183820152602001610fed565b50505050905090810190601f1680156110325780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b6001600160a01b03831661108d5760405162461bcd60e51b81526004018080602001828103825260258152602001806115e56025913960400191505060405180910390fd5b6001600160a01b0382166110d25760405162461bcd60e51b815260040180806020018281038252602381526020018061150b6023913960400191505060405180910390fd5b6110dd838383610fac565b61111a81604051806060016040528060268152602001611576602691396001600160a01b0386166000908152602081905260409020549190610fb1565b6001600160a01b0380851660009081526020819052604080822093909355908416815220546111499082610c17565b6001600160a01b038084166000818152602081815260409182902094909455805185815290519193928716927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef92918290030190a3505050565b6111ac816112cd565b6111b46109e2565b6001600160a01b03166108fc479081150290604051600060405180830381858888f193505050501580156111ec573d6000803e3d6000fd5b5050565b6000826111ff575060006106b4565b8282028284828161120c57fe5b0414610c715760405162461bcd60e51b815260040180806020018281038252602181526020018061159c6021913960400191505060405180910390fd5b6000610c7183836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506114a5565b6000610c7183836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250610fb1565b604080516002808252606080830184529260208301908036833701905050905030816000815181106112fb57fe5b6001600160a01b03928316602091820292909201810191909152600654604080517fad5c46480000000000000000000000000000000000000000000000000000000081529051919093169263ad5c4648926004808301939192829003018186803b15801561136857600080fd5b505afa15801561137c573d6000803e3d6000fd5b505050506040513d602081101561139257600080fd5b50518151829060019081106113a357fe5b6001600160a01b0392831660209182029290920101526006546113c99130911684610c7c565b6006546040517f791ac947000000000000000000000000000000000000000000000000000000008152600481018481526000602483018190523060648401819052426084850181905260a060448601908152875160a487015287516001600160a01b039097169663791ac947968a968a9594939092909160c40190602080880191028083838b5b83811015611468578181015183820152602001611450565b505050509050019650505050505050600060405180830381600087803b15801561149157600080fd5b505af1158015610fa8573d6000803e3d6000fd5b600081836114f45760405162461bcd60e51b8152602060048201818152835160248401528351909283926044909101919085019080838360008315611005578181015183820152602001610fed565b50600083858161150057fe5b049594505050505056fe45524332303a207472616e7366657220746f20746865207a65726f20616464726573734f776e61626c653a206e6577206f776e657220697320746865207a65726f206164647265737345524332303a20617070726f766520746f20746865207a65726f206164647265737345524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e6365536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f7745524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a207472616e736665722066726f6d20746865207a65726f206164647265737345524332303a20617070726f76652066726f6d20746865207a65726f206164647265737345524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220a624e3e0365ad76648525bafa09632977e13d8301d3bcf1955323b1f4d94c37b64736f6c634300060c0033
Deployed Bytecode Sourcemap
23027:3225:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;14423:100;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;16590:169;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;16590:169:0;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;23110:41;;;;;;;;;;;;;:::i;:::-;;;;-1:-1:-1;;;;;23110:41:0;;;;;;;;;;;;;;15543:108;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;17241:355;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;17241:355:0;;;;;;;;;;;;;;;;;:::i;15385:93::-;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;18005:218;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;18005:218:0;;;;;;;;:::i;23158:38::-;;;;;;;;;;;;;:::i;26141:106::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;26141:106:0;;:::i;:::-;;25835:294;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;25835:294:0;;;;;;;;-1:-1:-1;25835:294:0;;-1:-1:-1;;25835:294:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;25835:294:0;;-1:-1:-1;25835:294:0;;-1:-1:-1;;;;;25835:294:0:i;15714:127::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;15714:127:0;-1:-1:-1;;;;;15714:127:0;;:::i;2136:148::-;;;;;;;;;;;;;:::i;1926:79::-;;;;;;;;;;;;;:::i;14642:104::-;;;;;;;;;;;;;:::i;18726:269::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;18726:269:0;;;;;;;;:::i;16054:175::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;16054:175:0;;;;;;;;:::i;16292:151::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;16292:151:0;;;;;;;;;;:::i;23235:53::-;;;;;;;;;;;;;:::i;2290:244::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;2290:244:0;-1:-1:-1;;;;;2290:244:0;;:::i;14423:100::-;14510:5;14503:12;;;;;;;;-1:-1:-1;;14503:12:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;14477:13;;14503:12;;14510:5;;14503:12;;14510:5;14503:12;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;14423:100;:::o;16590:169::-;16673:4;16690:39;16699:12;:10;:12::i;:::-;16713:7;16722:6;16690:8;:39::i;:::-;-1:-1:-1;16747:4:0;16590:169;;;;;:::o;23110:41::-;;;-1:-1:-1;;;;;23110:41:0;;:::o;15543:108::-;15631:12;;15543:108;:::o;17241:355::-;17381:4;17398:36;17408:6;17416:9;17427:6;17398:9;:36::i;:::-;17445:121;17454:6;17462:12;:10;:12::i;:::-;17476:89;17514:6;17476:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;17476:19:0;;;;;;:11;:19;;;;;;17496:12;:10;:12::i;:::-;-1:-1:-1;;;;;17476:33:0;;;;;;;;;;;;-1:-1:-1;17476:33:0;;;:89;:37;:89::i;:::-;17445:8;:121::i;:::-;-1:-1:-1;17584:4:0;17241:355;;;;;:::o;15385:93::-;15468:2;15385:93;:::o;18005:218::-;18093:4;18110:83;18119:12;:10;:12::i;:::-;18133:7;18142:50;18181:10;18142:11;:25;18154:12;:10;:12::i;:::-;-1:-1:-1;;;;;18142:25:0;;;;;;;;;;;;;;;;;-1:-1:-1;18142:25:0;;;:34;;;;;;;;;;;:38;:50::i;23158:38::-;;;:::o;26141:106::-;2061:12;:10;:12::i;:::-;2051:6;;-1:-1:-1;;;;;2051:6:0;;;:22;;;2043:67;;;;;-1:-1:-1;;;2043:67:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;26212:18:::1;:27:::0;26141:106::o;25835:294::-;2061:12;:10;:12::i;:::-;2051:6;;-1:-1:-1;;;;;2051:6:0;;;:22;;;2043:67;;;;;-1:-1:-1;;;2043:67:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;25946:12;;25984:14;;25977:21;::::1;25969:30;;;::::0;::::1;;26015:9;26010:112;26034:3;26030:1;:7;26010:112;;;26059:51;26075:12;:10;:12::i;:::-;26089:5;26095:1;26089:8;;;;;;;;;;;;;;26099:7;26107:1;26099:10;;;;;;;;;;;;;;26059:15;:51::i;:::-;26039:3;;26010:112;;;;2121:1;25835:294:::0;;:::o;15714:127::-;-1:-1:-1;;;;;15815:18:0;15788:7;15815:18;;;;;;;;;;;;15714:127::o;2136:148::-;2061:12;:10;:12::i;:::-;2051:6;;-1:-1:-1;;;;;2051:6:0;;;:22;;;2043:67;;;;;-1:-1:-1;;;2043:67:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2227:6:::1;::::0;2206:40:::1;::::0;2243:1:::1;::::0;-1:-1:-1;;;;;2227:6:0::1;::::0;2206:40:::1;::::0;2243:1;;2206:40:::1;2257:6;:19:::0;;-1:-1:-1;;2257:19:0::1;::::0;;2136:148::o;1926:79::-;1991:6;;-1:-1:-1;;;;;1991:6:0;1926:79;:::o;14642:104::-;14731:7;14724:14;;;;;;;;-1:-1:-1;;14724:14:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;14698:13;;14724:14;;14731:7;;14724:14;;14731:7;14724:14;;;;;;;;;;;;;;;;;;;;;;;;18726:269;18819:4;18836:129;18845:12;:10;:12::i;:::-;18859:7;18868:96;18907:15;18868:96;;;;;;;;;;;;;;;;;:11;:25;18880:12;:10;:12::i;:::-;-1:-1:-1;;;;;18868:25:0;;;;;;;;;;;;;;;;;-1:-1:-1;18868:25:0;;;:34;;;;;;;;;;;:96;:38;:96::i;16054:175::-;16140:4;16157:42;16167:12;:10;:12::i;:::-;16181:9;16192:6;16157:9;:42::i;16292:151::-;-1:-1:-1;;;;;16408:18:0;;;16381:7;16408:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;16292:151::o;23235:53::-;;;;:::o;2290:244::-;2061:12;:10;:12::i;:::-;2051:6;;-1:-1:-1;;;;;2051:6:0;;;:22;;;2043:67;;;;;-1:-1:-1;;;2043:67:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;2379:22:0;::::1;2371:73;;;;-1:-1:-1::0;;;2371:73:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2481:6;::::0;2460:38:::1;::::0;-1:-1:-1;;;;;2460:38:0;;::::1;::::0;2481:6:::1;::::0;2460:38:::1;::::0;2481:6:::1;::::0;2460:38:::1;2509:6;:17:::0;;-1:-1:-1;;2509:17:0::1;-1:-1:-1::0;;;;;2509:17:0;;;::::1;::::0;;;::::1;::::0;;2290:244::o;50:181::-;108:7;140:5;;;164:6;;;;156:46;;;;;-1:-1:-1;;;156:46:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;222:1;50:181;-1:-1:-1;;;50:181:0:o;1502:98::-;1582:10;1502:98;:::o;21912:380::-;-1:-1:-1;;;;;22048:19:0;;22040:68;;;;-1:-1:-1;;;22040:68:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;22127:21:0;;22119:68;;;;-1:-1:-1;;;22119:68:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;22200:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;22252:32;;;;;;;;;;;;;;;;;21912:380;;;:::o;23960:1206::-;-1:-1:-1;;;;;24092:18:0;;24084:27;;;;;;-1:-1:-1;;;;;24130:16:0;;24122:25;;;;;;24163:11;24160:92;;24191:28;24207:4;24213:2;24217:1;24191:15;:28::i;:::-;24234:7;;24160:92;24258:28;24289:24;24307:4;24289:9;:24::i;:::-;24363:18;;24258:55;;-1:-1:-1;24339:42:0;;;;;;;24411:33;;-1:-1:-1;24436:8:0;;-1:-1:-1;;;24436:8:0;;;;24435:9;24411:33;:71;;;;;24469:13;-1:-1:-1;;;;;24461:21:0;:4;-1:-1:-1;;;;;24461:21:0;;;24411:71;:103;;;;;24507:7;:5;:7::i;:::-;-1:-1:-1;;;;;24499:15:0;:4;-1:-1:-1;;;;;24499:15:0;;;24411:103;:133;;;;;24537:7;:5;:7::i;:::-;-1:-1:-1;;;;;24531:13:0;:2;-1:-1:-1;;;;;24531:13:0;;;24411:133;24394:357;;;24582:8;:15;;-1:-1:-1;;;;24582:15:0;-1:-1:-1;;;24582:15:0;;;;24635:24;24653:4;24635:9;:24::i;:::-;24614:45;;24674:32;24695:10;24674:20;:32::i;:::-;-1:-1:-1;24723:8:0;:16;;-1:-1:-1;;;;24723:16:0;;;24394:357;24779:8;;-1:-1:-1;;;;;24803:17:0;;24763:12;24803:17;;;:11;:17;;;;;;24779:8;-1:-1:-1;;;24779:8:0;;;;;24778:9;;24803:17;;:36;;-1:-1:-1;;;;;;24824:15:0;;;;;;:11;:15;;;;;;;;24803:36;24800:83;;;-1:-1:-1;24866:5:0;24800:83;24898:7;:57;;;;;24916:13;-1:-1:-1;;;;;24910:19:0;:2;-1:-1:-1;;;;;24910:19:0;;:44;;;;24941:13;-1:-1:-1;;;;;24933:21:0;:4;-1:-1:-1;;;;;24933:21:0;;24910:44;24895:216;;;24970:12;24985:22;25003:3;24985:13;:6;24996:1;24985:10;:13::i;:::-;:17;;:22::i;:::-;24970:37;-1:-1:-1;25028:16:0;:6;24970:37;25028:10;:16::i;:::-;25019:25;;25057:42;25073:4;25087;25094;25057:15;:42::i;:::-;24895:216;;25123:33;25139:4;25145:2;25149:6;25123:15;:33::i;:::-;23960:1206;;;;;;;:::o;379:192::-;465:7;501:12;493:6;;;;485:29;;;;-1:-1:-1;;;485:29:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;537:5:0;;;379:192::o;19485:573::-;-1:-1:-1;;;;;19625:20:0;;19617:70;;;;-1:-1:-1;;;19617:70:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;19706:23:0;;19698:71;;;;-1:-1:-1;;;19698:71:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;19782:47;19803:6;19811:9;19822:6;19782:20;:47::i;:::-;19862:71;19884:6;19862:71;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;19862:17:0;;:9;:17;;;;;;;;;;;;:71;:21;:71::i;:::-;-1:-1:-1;;;;;19842:17:0;;;:9;:17;;;;;;;;;;;:91;;;;19967:20;;;;;;;:32;;19992:6;19967:24;:32::i;:::-;-1:-1:-1;;;;;19944:20:0;;;:9;:20;;;;;;;;;;;;:55;;;;20015:35;;;;;;;19944:20;;20015:35;;;;;;;;;;;;;19485:573;;;:::o;25667:156::-;25732:24;25749:6;25732:16;:24::i;:::-;25775:7;:5;:7::i;:::-;-1:-1:-1;;;;;25767:25:0;:48;25793:21;25767:48;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;25667:156;:::o;577:246::-;635:7;659:6;655:47;;-1:-1:-1;689:1:0;682:8;;655:47;724:5;;;728:1;724;:5;:1;748:5;;;;;:10;740:56;;;;-1:-1:-1;;;740:56:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;829:132;887:7;914:39;918:1;921;914:39;;;;;;;;;;;;;;;;;:3;:39::i;237:136::-;295:7;322:43;326:1;329;322:43;;;;;;;;;;;;;;;;;:3;:43::i;25178:481::-;25268:16;;;25282:1;25268:16;;;25244:21;25268:16;;;;;25244:21;25268:16;;;;;;;;;;-1:-1:-1;25268:16:0;25244:40;;25313:4;25295;25300:1;25295:7;;;;;;;;-1:-1:-1;;;;;25295:23:0;;;:7;;;;;;;;;;:23;;;;25339:15;;:22;;;;;;;;:15;;;;;:20;;:22;;;;;25295:7;;25339:22;;;;;:15;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;25339:22:0;25329:7;;:4;;25334:1;;25329:7;;;;;;-1:-1:-1;;;;;25329:32:0;;;:7;;;;;;;;;:32;25404:15;;25372:62;;25389:4;;25404:15;25422:11;25372:8;:62::i;:::-;25445:15;;:196;;;;;;;;;;;:15;:196;;;;;;25595:4;25445:196;;;;;;25615:15;25445:196;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;25445:15:0;;;;:66;;25526:11;;25568:4;;25595;25615:15;25445:196;;;;;;;;;;;;;;;;:15;:196;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;967:189;1053:7;1088:12;1081:5;1073:28;;;;-1:-1:-1;;;1073:28:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;1112:9;1128:1;1124;:5;;;;;;;967:189;-1:-1:-1;;;;;967:189:0:o
Swarm Source
ipfs://a624e3e0365ad76648525bafa09632977e13d8301d3bcf1955323b1f4d94c37b
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.