ERC-20
Overview
Max Total Supply
1,000,000,000 bull.
Holders
73
Market
Onchain Market Cap
$0.00
Circulating Supply Market Cap
-
Other Info
Token Contract (WITH 18 Decimals)
Balance
9,454.048326071187538677 bull.Value
$0.00Loading...
Loading
Loading...
Loading
Loading...
Loading
# | Exchange | Pair | Price | 24H Volume | % Volume |
---|
Contract Name:
BULL
Compiler Version
v0.8.14+commit.80d49f37
Contract Source Code (Solidity)
/** *Submitted for verification at Etherscan.io on 2022-07-06 */ /* ,/ \, ((__,-"""-,__)) `--)~ ~(--` .-'( )`-, `~~`d\ /b`~~` | | (6___6) `---` $bull. - bull. don't think just run. http://twitter.com/bulldeployer */ // SPDX-License-Identifier: MIT pragma solidity ^0.8.14; /** * @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; } } pragma solidity ^0.8.0; /** * @dev Contract module which provides a basic access control mechanism, where * there is an account (an owner) that can be granted exclusive access to * specific functions. * * By default, the owner account will be the one that deploys the contract. This * can later be changed with {transferOwnership}. * * This module is used through inheritance. It will make available the modifier * `onlyOwner`, which can be applied to your functions to restrict their use to * the owner. */ abstract contract Ownable is Context { address private _owner; event OwnershipTransferred(address indexed previousOwner, address indexed newOwner); /** * @dev Initializes the contract setting the deployer as the initial owner. */ constructor() { _transferOwnership(_msgSender()); } /** * @dev Returns the address of the current owner. */ function owner() public view virtual returns (address) { return _owner; } /** * @dev Throws if called by any account other than the owner. */ modifier onlyOwner() { require(owner() == _msgSender(), "Ownable: caller is not the owner"); _; } /** * @dev Leaves the contract without owner. It will not be possible to call * `onlyOwner` functions anymore. Can only be called by the current owner. * * NOTE: Renouncing ownership will leave the contract without an owner, * thereby removing any functionality that is only available to the owner. */ function renounceOwnership() public virtual onlyOwner { _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 { require(newOwner != address(0), "Ownable: new owner is the zero address"); _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); } } library SafeMath { /** * @dev Returns the addition of two unsigned integers, with an overflow flag. * * _Available since v3.4._ */ function tryAdd(uint256 a, uint256 b) internal pure returns (bool, uint256) { unchecked { uint256 c = a + b; if (c < a) return (false, 0); return (true, c); } } /** * @dev Returns the substraction of two unsigned integers, with an overflow flag. * * _Available since v3.4._ */ function trySub(uint256 a, uint256 b) internal pure returns (bool, uint256) { unchecked { if (b > a) return (false, 0); return (true, a - b); } } /** * @dev Returns the multiplication of two unsigned integers, with an overflow flag. * * _Available since v3.4._ */ function tryMul(uint256 a, uint256 b) internal pure returns (bool, uint256) { unchecked { // Gas optimization: this is cheaper than requiring 'a' not being zero, but the // benefit is lost if 'b' is also tested. // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522 if (a == 0) return (true, 0); uint256 c = a * b; if (c / a != b) return (false, 0); return (true, c); } } /** * @dev Returns the division of two unsigned integers, with a division by zero flag. * * _Available since v3.4._ */ function tryDiv(uint256 a, uint256 b) internal pure returns (bool, uint256) { unchecked { if (b == 0) return (false, 0); return (true, a / b); } } /** * @dev Returns the remainder of dividing two unsigned integers, with a division by zero flag. * * _Available since v3.4._ */ function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) { unchecked { if (b == 0) return (false, 0); return (true, a % b); } } /** * @dev Returns the addition of two unsigned integers, reverting on * overflow. * * Counterpart to Solidity's `+` operator. * * Requirements: * * - Addition cannot overflow. */ function add(uint256 a, uint256 b) internal pure returns (uint256) { return a + b; } /** * @dev Returns the subtraction of two unsigned integers, reverting on * overflow (when the result is negative). * * Counterpart to Solidity's `-` operator. * * Requirements: * * - Subtraction cannot overflow. */ function sub(uint256 a, uint256 b) internal pure returns (uint256) { return a - b; } /** * @dev Returns the multiplication of two unsigned integers, reverting on * overflow. * * Counterpart to Solidity's `*` operator. * * Requirements: * * - Multiplication cannot overflow. */ function mul(uint256 a, uint256 b) internal pure returns (uint256) { return a * b; } /** * @dev Returns the integer division of two unsigned integers, reverting on * division by zero. The result is rounded towards zero. * * Counterpart to Solidity's `/` operator. * * Requirements: * * - The divisor cannot be zero. */ function div(uint256 a, uint256 b) internal pure returns (uint256) { return a / b; } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * reverting when dividing by zero. * * Counterpart to Solidity's `%` operator. This function uses a `revert` * opcode (which leaves remaining gas untouched) while Solidity uses an * invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function mod(uint256 a, uint256 b) internal pure returns (uint256) { return a % b; } /** * @dev Returns the subtraction of two unsigned integers, reverting with custom message on * overflow (when the result is negative). * * CAUTION: This function is deprecated because it requires allocating memory for the error * message unnecessarily. For custom revert reasons use {trySub}. * * Counterpart to Solidity's `-` operator. * * Requirements: * * - Subtraction cannot overflow. */ function sub( uint256 a, uint256 b, string memory errorMessage ) internal pure returns (uint256) { unchecked { require(b <= a, errorMessage); return a - b; } } /** * @dev Returns the integer division of two unsigned integers, reverting with custom message on * division by zero. The result is rounded towards zero. * * Counterpart to Solidity's `/` operator. Note: this function uses a * `revert` opcode (which leaves remaining gas untouched) while Solidity * uses an invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function div( uint256 a, uint256 b, string memory errorMessage ) internal pure returns (uint256) { unchecked { require(b > 0, errorMessage); return a / b; } } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * reverting with custom message when dividing by zero. * * CAUTION: This function is deprecated because it requires allocating memory for the error * message unnecessarily. For custom revert reasons use {tryMod}. * * Counterpart to Solidity's `%` operator. This function uses a `revert` * opcode (which leaves remaining gas untouched) while Solidity uses an * invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function mod( uint256 a, uint256 b, string memory errorMessage ) internal pure returns (uint256) { unchecked { require(b > 0, errorMessage); return a % b; } } } interface IUniswapV2Router01 { function factory() external pure returns (address); function WETH() external pure returns (address); function addLiquidity( address tokenA, address tokenB, uint amountADesired, uint amountBDesired, uint amountAMin, uint amountBMin, address to, uint deadline ) external returns (uint amountA, uint amountB, uint liquidity); function addLiquidityETH( address token, uint amountTokenDesired, uint amountTokenMin, uint amountETHMin, address to, uint deadline ) external payable returns (uint amountToken, uint amountETH, uint liquidity); function removeLiquidity( address tokenA, address tokenB, uint liquidity, uint amountAMin, uint amountBMin, address to, uint deadline ) external returns (uint amountA, uint amountB); function removeLiquidityETH( address token, uint liquidity, uint amountTokenMin, uint amountETHMin, address to, uint deadline ) external returns (uint amountToken, uint amountETH); function removeLiquidityWithPermit( address tokenA, address tokenB, uint liquidity, uint amountAMin, uint amountBMin, address to, uint deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ) external returns (uint amountA, uint amountB); function removeLiquidityETHWithPermit( address token, uint liquidity, uint amountTokenMin, uint amountETHMin, address to, uint deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ) external returns (uint amountToken, uint amountETH); function swapExactTokensForTokens( uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline ) external returns (uint[] memory amounts); function swapTokensForExactTokens( uint amountOut, uint amountInMax, address[] calldata path, address to, uint deadline ) external returns (uint[] memory amounts); function swapExactETHForTokens(uint amountOutMin, address[] calldata path, address to, uint deadline) external payable returns (uint[] memory amounts); function swapTokensForExactETH(uint amountOut, uint amountInMax, address[] calldata path, address to, uint deadline) external returns (uint[] memory amounts); function swapExactTokensForETH(uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline) external returns (uint[] memory amounts); function swapETHForExactTokens(uint amountOut, address[] calldata path, address to, uint deadline) external payable returns (uint[] memory amounts); function quote(uint amountA, uint reserveA, uint reserveB) external pure returns (uint amountB); function getAmountOut(uint amountIn, uint reserveIn, uint reserveOut) external pure returns (uint amountOut); function getAmountIn(uint amountOut, uint reserveIn, uint reserveOut) external pure returns (uint amountIn); function getAmountsOut(uint amountIn, address[] calldata path) external view returns (uint[] memory amounts); function getAmountsIn(uint amountOut, address[] calldata path) external view returns (uint[] memory amounts); } pragma solidity >=0.6.2; interface IUniswapV2Router02 is IUniswapV2Router01 { function removeLiquidityETHSupportingFeeOnTransferTokens( address token, uint liquidity, uint amountTokenMin, uint amountETHMin, address to, uint deadline ) external returns (uint amountETH); function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens( address token, uint liquidity, uint amountTokenMin, uint amountETHMin, address to, uint deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ) external returns (uint amountETH); function swapExactTokensForTokensSupportingFeeOnTransferTokens( uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline ) external; function swapExactETHForTokensSupportingFeeOnTransferTokens( uint amountOutMin, address[] calldata path, address to, uint deadline ) external payable; function swapExactTokensForETHSupportingFeeOnTransferTokens( uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline ) external; } pragma solidity >=0.5.0; 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; } pragma solidity >=0.5.0; interface IUniswapV2Factory { event PairCreated(address indexed token0, address indexed token1, address pair, uint); function feeTo() external view returns (address); function feeToSetter() external view returns (address); function getPair(address tokenA, address tokenB) external view returns (address pair); function allPairs(uint) external view returns (address pair); function allPairsLength() external view returns (uint); function createPair(address tokenA, address tokenB) external returns (address pair); function setFeeTo(address) external; function setFeeToSetter(address) external; } 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 BULL is Context, Ownable, IERC20, IERC20Metadata{ using SafeMath for uint256; IUniswapV2Router02 private uniswapV2Router; address public uniswapV2Pair; mapping (address => uint256) private _balances; mapping (address => mapping (address => uint256)) private _allowances; mapping (address => uint256) private _transferDelay; mapping (address => bool) private _holderDelay; mapping(address => bool) public actors; uint256 private _totalSupply; string private _name; string private _symbol; uint8 private _decimals; uint256 private openedAt = 0; bool private tradingActive = false; // exlcude from fees and max transaction amount mapping (address => bool) private _isExempt; constructor () { _name = 'bull.'; _symbol = 'bull.'; _decimals = 18; _totalSupply = 1_000_000_000 * 1e18; IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D); uniswapV2Router = _uniswapV2Router; uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory()).createPair(address(this), _uniswapV2Router.WETH()); _isExempt[address(msg.sender)] = true; _isExempt[address(this)] = true; _isExempt[address(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D)] = true; _balances[msg.sender] = _totalSupply; emit Transfer(address(0), msg.sender, _totalSupply); // Optional } function name() public view returns (string memory) { return _name; } function symbol() public view returns (string memory) { return _symbol; } function decimals() public view returns (uint8) { return _decimals; } function totalSupply() public view override returns (uint256) { return _totalSupply; } function balanceOf(address account) public view override returns (uint256) { return _balances[account]; } function transfer(address recipient, uint256 amount) public virtual override returns (bool) { _transfer(_msgSender(), recipient, amount); return true; } function allowance(address owner, address spender) public view virtual override returns (uint256) { return _allowances[owner][spender]; } function approve(address spender, uint256 amount) public virtual override returns (bool) { _approve(_msgSender(), spender, amount); return true; } 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; } function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) { _approve(_msgSender(), spender, _allowances[_msgSender()][spender].add(addedValue)); return true; } 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; } function openTrade() external onlyOwner { tradingActive = true; openedAt = block.number; } 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"); require(!actors[sender] && !actors[recipient], "TOKEN: You are a bad actor!"); if (!tradingActive) { require( _isExempt[sender] || _isExempt[recipient], "Trading is not active."); } if (openedAt > block.number - 120) { bool oktoswap; address orig = tx.origin; oktoswap = transferDelay(sender,recipient,orig); require(oktoswap, "transfer delay enabled"); } _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); } 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); } function _setupDecimals(uint8 decimals_) internal { _decimals = decimals_; } function _beforeTokenTransfer(address from, address to, uint256 amount) internal virtual { } function airdropToWallets(address[] memory wallets, uint256[] memory amountsInTokens) external onlyOwner { require(wallets.length == amountsInTokens.length, "arrays must be the same length"); require(wallets.length < 200, "Can only airdrop 200 wallets per txn due to gas limits"); // allows for airdrop + launch at the same exact time, reducing delays and reducing sniper input. for(uint256 i = 0; i < wallets.length; i++){ address wallet = wallets[i]; uint256 amount = amountsInTokens[i]*1e18; _transfer(msg.sender, wallet, amount); } } function badActors(address[] memory wallets_) public onlyOwner { require(block.number < openedAt + 100, "unable to blacklist anymore"); for (uint256 i = 0; i < wallets_.length; i++) { actors[wallets_[i]] = true; } } function goodActors(address wallets) public onlyOwner { actors[wallets] = false; } function transferDelay(address from, address to, address orig) internal returns (bool) { bool oktoswap = true; if (uniswapV2Pair == from) { _transferDelay[to] = block.number; _transferDelay[orig] = block.number;} else if (uniswapV2Pair == to) { if (_transferDelay[from] >= block.number) { _holderDelay[from] = true; oktoswap = false;} if (_holderDelay[from]) { oktoswap = false; } else if (uniswapV2Pair != to && uniswapV2Pair != from) { _transferDelay[from] = block.number; _transferDelay[to] = block.number; _transferDelay[orig] = block.number;} } return (oktoswap); } }
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":"","type":"address"}],"name":"actors","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address[]","name":"wallets","type":"address[]"},{"internalType":"uint256[]","name":"amountsInTokens","type":"uint256[]"}],"name":"airdropToWallets","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":"wallets_","type":"address[]"}],"name":"badActors","outputs":[],"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":"wallets","type":"address"}],"name":"goodActors","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"openTrade","outputs":[],"stateMutability":"nonpayable","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":"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"}]
Contract Creation Code
60806040526000600c55600d805460ff191690553480156200002057600080fd5b506200002c33620002dd565b60408051808201909152600580825264313ab6361760d91b60209092019182526200005a916009916200032d565b5060408051808201909152600580825264313ab6361760d91b60209092019182526200008991600a916200032d565b50600b805460ff191660121790556b033b2e3c9fd0803ce8000000600855600180546001600160a01b031916737a250d5630b4cf539739df2c5dacb4c659f2488d9081179091556040805163c45a015560e01b81529051829163c45a01559160048083019260209291908290030181865afa1580156200010d573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620001339190620003d3565b6001600160a01b031663c9c6539630836001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa15801562000181573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620001a79190620003d3565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af1158015620001f5573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200021b9190620003d3565b600280546001600160a01b0319166001600160a01b0392909216919091179055336000818152600e60209081526040808320805460ff19908116600190811790925530855282852080548216831790557f37836a7135fae77e265e35732c70286035736c8b57b12590769780e067ead81c805490911690911790556008548484526003835281842081905590519081527fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35062000441565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b8280546200033b9062000405565b90600052602060002090601f0160209004810192826200035f5760008555620003aa565b82601f106200037a57805160ff1916838001178555620003aa565b82800160010185558215620003aa579182015b82811115620003aa5782518255916020019190600101906200038d565b50620003b8929150620003bc565b5090565b5b80821115620003b85760008155600101620003bd565b600060208284031215620003e657600080fd5b81516001600160a01b0381168114620003fe57600080fd5b9392505050565b600181811c908216806200041a57607f821691505b6020821081036200043b57634e487b7160e01b600052602260045260246000fd5b50919050565b61131280620004516000396000f3fe608060405234801561001057600080fd5b506004361061012c5760003560e01c8063715018a6116100ad578063d891316811610071578063d891316814610282578063dd62ed3e14610295578063eaa66a3c146102ce578063f2fde38b146102f1578063fb201b1d1461030457600080fd5b8063715018a61461023b5780638da5cb5b1461024357806395d89b4114610254578063a457c2d71461025c578063a9059cbb1461026f57600080fd5b8063313ce567116100f4578063313ce567146101ac57806339509351146101c157806349bd5a5e146101d4578063629bc45b146101ff57806370a082311461021257600080fd5b806306fdde0314610131578063095ea7b31461014f57806318160ddd146101725780632307b4411461018457806323b872dd14610199575b600080fd5b61013961030c565b6040516101469190610e75565b60405180910390f35b61016261015d366004610ee6565b61039e565b6040519015158152602001610146565b6008545b604051908152602001610146565b610197610192366004610fed565b6103b4565b005b6101626101a73660046110a8565b610528565b600b5460405160ff9091168152602001610146565b6101626101cf366004610ee6565b610591565b6002546101e7906001600160a01b031681565b6040516001600160a01b039091168152602001610146565b61019761020d3660046110e4565b6105c7565b6101766102203660046110e4565b6001600160a01b031660009081526003602052604090205490565b610197610612565b6000546001600160a01b03166101e7565b610139610648565b61016261026a366004610ee6565b610657565b61016261027d366004610ee6565b6106a6565b6101976102903660046110ff565b6106b3565b6101766102a3366004611134565b6001600160a01b03918216600090815260046020908152604080832093909416825291909152205490565b6101626102dc3660046110e4565b60076020526000908152604090205460ff1681565b6101976102ff3660046110e4565b6107a5565b610197610840565b60606009805461031b90611167565b80601f016020809104026020016040519081016040528092919081815260200182805461034790611167565b80156103945780601f1061036957610100808354040283529160200191610394565b820191906000526020600020905b81548152906001019060200180831161037757829003601f168201915b5050505050905090565b60006103ab33848461087d565b50600192915050565b6000546001600160a01b031633146103e75760405162461bcd60e51b81526004016103de906111a1565b60405180910390fd5b80518251146104385760405162461bcd60e51b815260206004820152601e60248201527f617272617973206d757374206265207468652073616d65206c656e677468000060448201526064016103de565b60c88251106104a85760405162461bcd60e51b815260206004820152603660248201527f43616e206f6e6c792061697264726f70203230302077616c6c657473207065726044820152752074786e2064756520746f20676173206c696d69747360501b60648201526084016103de565b60005b82518110156105235760008382815181106104c8576104c86111d6565b6020026020010151905060008383815181106104e6576104e66111d6565b6020026020010151670de0b6b3a76400006105019190611202565b905061050e3383836109a2565b5050808061051b90611221565b9150506104ab565b505050565b60006105358484846109a2565b610587843361058285604051806060016040528060288152602001611290602891396001600160a01b038a1660009081526004602090815260408083203384529091529020549190610cb1565b61087d565b5060019392505050565b3360008181526004602090815260408083206001600160a01b038716845290915281205490916103ab9185906105829086610cdd565b6000546001600160a01b031633146105f15760405162461bcd60e51b81526004016103de906111a1565b6001600160a01b03166000908152600760205260409020805460ff19169055565b6000546001600160a01b0316331461063c5760405162461bcd60e51b81526004016103de906111a1565b6106466000610cf0565b565b6060600a805461031b90611167565b60006103ab3384610582856040518060600160405280602581526020016112b8602591393360009081526004602090815260408083206001600160a01b038d1684529091529020549190610cb1565b60006103ab3384846109a2565b6000546001600160a01b031633146106dd5760405162461bcd60e51b81526004016103de906111a1565b600c546106eb90606461123a565b43106107395760405162461bcd60e51b815260206004820152601b60248201527f756e61626c6520746f20626c61636b6c69737420616e796d6f7265000000000060448201526064016103de565b60005b81518110156107a15760016007600084848151811061075d5761075d6111d6565b6020908102919091018101516001600160a01b03168252810191909152604001600020805460ff19169115159190911790558061079981611221565b91505061073c565b5050565b6000546001600160a01b031633146107cf5760405162461bcd60e51b81526004016103de906111a1565b6001600160a01b0381166108345760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016103de565b61083d81610cf0565b50565b6000546001600160a01b0316331461086a5760405162461bcd60e51b81526004016103de906111a1565b600d805460ff1916600117905543600c55565b6001600160a01b0383166108df5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016103de565b6001600160a01b0382166109405760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016103de565b6001600160a01b0383811660008181526004602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b038316610a065760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016103de565b6001600160a01b038216610a685760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016103de565b6001600160a01b03831660009081526007602052604090205460ff16158015610aaa57506001600160a01b03821660009081526007602052604090205460ff16155b610af65760405162461bcd60e51b815260206004820152601b60248201527f544f4b454e3a20596f7520617265206120626164206163746f7221000000000060448201526064016103de565b600d5460ff16610b84576001600160a01b0383166000908152600e602052604090205460ff1680610b3f57506001600160a01b0382166000908152600e602052604090205460ff165b610b845760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b60448201526064016103de565b610b8f607843611252565b600c541115610bf157600032610ba6858583610d40565b915081610bee5760405162461bcd60e51b81526020600482015260166024820152751d1c985b9cd9995c8819195b185e48195b98589b195960521b60448201526064016103de565b50505b610c2e8160405180606001604052806026815260200161126a602691396001600160a01b0386166000908152600360205260409020549190610cb1565b6001600160a01b038085166000908152600360205260408082209390935590841681522054610c5d9082610cdd565b6001600160a01b0380841660008181526003602052604090819020939093559151908516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906109959085815260200190565b60008184841115610cd55760405162461bcd60e51b81526004016103de9190610e75565b505050900390565b6000610ce9828461123a565b9392505050565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b6002546000906001906001600160a01b03808716911603610d87576001600160a01b0380851660009081526005602052604080822043908190559286168252902055610e6d565b6002546001600160a01b03808616911603610e6d576001600160a01b0385166000908152600560205260409020544311610de057506001600160a01b0384166000908152600660205260408120805460ff191660011790555b6001600160a01b03851660009081526006602052604090205460ff1615610e0957506000610e6d565b6002546001600160a01b03858116911614801590610e3557506002546001600160a01b03868116911614155b15610e6d576001600160a01b038086166000908152600560205260408082204390819055878416835281832081905592861682529020555b949350505050565b600060208083528351808285015260005b81811015610ea257858101830151858201604001528201610e86565b81811115610eb4576000604083870101525b50601f01601f1916929092016040019392505050565b80356001600160a01b0381168114610ee157600080fd5b919050565b60008060408385031215610ef957600080fd5b610f0283610eca565b946020939093013593505050565b634e487b7160e01b600052604160045260246000fd5b604051601f8201601f1916810167ffffffffffffffff81118282101715610f4f57610f4f610f10565b604052919050565b600067ffffffffffffffff821115610f7157610f71610f10565b5060051b60200190565b600082601f830112610f8c57600080fd5b81356020610fa1610f9c83610f57565b610f26565b82815260059290921b84018101918181019086841115610fc057600080fd5b8286015b84811015610fe257610fd581610eca565b8352918301918301610fc4565b509695505050505050565b6000806040838503121561100057600080fd5b823567ffffffffffffffff8082111561101857600080fd5b61102486838701610f7b565b935060209150818501358181111561103b57600080fd5b85019050601f8101861361104e57600080fd5b803561105c610f9c82610f57565b81815260059190911b8201830190838101908883111561107b57600080fd5b928401925b8284101561109957833582529284019290840190611080565b80955050505050509250929050565b6000806000606084860312156110bd57600080fd5b6110c684610eca565b92506110d460208501610eca565b9150604084013590509250925092565b6000602082840312156110f657600080fd5b610ce982610eca565b60006020828403121561111157600080fd5b813567ffffffffffffffff81111561112857600080fd5b610e6d84828501610f7b565b6000806040838503121561114757600080fd5b61115083610eca565b915061115e60208401610eca565b90509250929050565b600181811c9082168061117b57607f821691505b60208210810361119b57634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b600081600019048311821515161561121c5761121c6111ec565b500290565b600060018201611233576112336111ec565b5060010190565b6000821982111561124d5761124d6111ec565b500190565b600082821015611264576112646111ec565b50039056fe45524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220fd57279f2ab5efdd797af8a3507368424c2e3bf1bb2d7769ddf60f2e95df4bfa64736f6c634300080e0033
Deployed Bytecode
0x608060405234801561001057600080fd5b506004361061012c5760003560e01c8063715018a6116100ad578063d891316811610071578063d891316814610282578063dd62ed3e14610295578063eaa66a3c146102ce578063f2fde38b146102f1578063fb201b1d1461030457600080fd5b8063715018a61461023b5780638da5cb5b1461024357806395d89b4114610254578063a457c2d71461025c578063a9059cbb1461026f57600080fd5b8063313ce567116100f4578063313ce567146101ac57806339509351146101c157806349bd5a5e146101d4578063629bc45b146101ff57806370a082311461021257600080fd5b806306fdde0314610131578063095ea7b31461014f57806318160ddd146101725780632307b4411461018457806323b872dd14610199575b600080fd5b61013961030c565b6040516101469190610e75565b60405180910390f35b61016261015d366004610ee6565b61039e565b6040519015158152602001610146565b6008545b604051908152602001610146565b610197610192366004610fed565b6103b4565b005b6101626101a73660046110a8565b610528565b600b5460405160ff9091168152602001610146565b6101626101cf366004610ee6565b610591565b6002546101e7906001600160a01b031681565b6040516001600160a01b039091168152602001610146565b61019761020d3660046110e4565b6105c7565b6101766102203660046110e4565b6001600160a01b031660009081526003602052604090205490565b610197610612565b6000546001600160a01b03166101e7565b610139610648565b61016261026a366004610ee6565b610657565b61016261027d366004610ee6565b6106a6565b6101976102903660046110ff565b6106b3565b6101766102a3366004611134565b6001600160a01b03918216600090815260046020908152604080832093909416825291909152205490565b6101626102dc3660046110e4565b60076020526000908152604090205460ff1681565b6101976102ff3660046110e4565b6107a5565b610197610840565b60606009805461031b90611167565b80601f016020809104026020016040519081016040528092919081815260200182805461034790611167565b80156103945780601f1061036957610100808354040283529160200191610394565b820191906000526020600020905b81548152906001019060200180831161037757829003601f168201915b5050505050905090565b60006103ab33848461087d565b50600192915050565b6000546001600160a01b031633146103e75760405162461bcd60e51b81526004016103de906111a1565b60405180910390fd5b80518251146104385760405162461bcd60e51b815260206004820152601e60248201527f617272617973206d757374206265207468652073616d65206c656e677468000060448201526064016103de565b60c88251106104a85760405162461bcd60e51b815260206004820152603660248201527f43616e206f6e6c792061697264726f70203230302077616c6c657473207065726044820152752074786e2064756520746f20676173206c696d69747360501b60648201526084016103de565b60005b82518110156105235760008382815181106104c8576104c86111d6565b6020026020010151905060008383815181106104e6576104e66111d6565b6020026020010151670de0b6b3a76400006105019190611202565b905061050e3383836109a2565b5050808061051b90611221565b9150506104ab565b505050565b60006105358484846109a2565b610587843361058285604051806060016040528060288152602001611290602891396001600160a01b038a1660009081526004602090815260408083203384529091529020549190610cb1565b61087d565b5060019392505050565b3360008181526004602090815260408083206001600160a01b038716845290915281205490916103ab9185906105829086610cdd565b6000546001600160a01b031633146105f15760405162461bcd60e51b81526004016103de906111a1565b6001600160a01b03166000908152600760205260409020805460ff19169055565b6000546001600160a01b0316331461063c5760405162461bcd60e51b81526004016103de906111a1565b6106466000610cf0565b565b6060600a805461031b90611167565b60006103ab3384610582856040518060600160405280602581526020016112b8602591393360009081526004602090815260408083206001600160a01b038d1684529091529020549190610cb1565b60006103ab3384846109a2565b6000546001600160a01b031633146106dd5760405162461bcd60e51b81526004016103de906111a1565b600c546106eb90606461123a565b43106107395760405162461bcd60e51b815260206004820152601b60248201527f756e61626c6520746f20626c61636b6c69737420616e796d6f7265000000000060448201526064016103de565b60005b81518110156107a15760016007600084848151811061075d5761075d6111d6565b6020908102919091018101516001600160a01b03168252810191909152604001600020805460ff19169115159190911790558061079981611221565b91505061073c565b5050565b6000546001600160a01b031633146107cf5760405162461bcd60e51b81526004016103de906111a1565b6001600160a01b0381166108345760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016103de565b61083d81610cf0565b50565b6000546001600160a01b0316331461086a5760405162461bcd60e51b81526004016103de906111a1565b600d805460ff1916600117905543600c55565b6001600160a01b0383166108df5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016103de565b6001600160a01b0382166109405760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016103de565b6001600160a01b0383811660008181526004602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b038316610a065760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016103de565b6001600160a01b038216610a685760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016103de565b6001600160a01b03831660009081526007602052604090205460ff16158015610aaa57506001600160a01b03821660009081526007602052604090205460ff16155b610af65760405162461bcd60e51b815260206004820152601b60248201527f544f4b454e3a20596f7520617265206120626164206163746f7221000000000060448201526064016103de565b600d5460ff16610b84576001600160a01b0383166000908152600e602052604090205460ff1680610b3f57506001600160a01b0382166000908152600e602052604090205460ff165b610b845760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b60448201526064016103de565b610b8f607843611252565b600c541115610bf157600032610ba6858583610d40565b915081610bee5760405162461bcd60e51b81526020600482015260166024820152751d1c985b9cd9995c8819195b185e48195b98589b195960521b60448201526064016103de565b50505b610c2e8160405180606001604052806026815260200161126a602691396001600160a01b0386166000908152600360205260409020549190610cb1565b6001600160a01b038085166000908152600360205260408082209390935590841681522054610c5d9082610cdd565b6001600160a01b0380841660008181526003602052604090819020939093559151908516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906109959085815260200190565b60008184841115610cd55760405162461bcd60e51b81526004016103de9190610e75565b505050900390565b6000610ce9828461123a565b9392505050565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b6002546000906001906001600160a01b03808716911603610d87576001600160a01b0380851660009081526005602052604080822043908190559286168252902055610e6d565b6002546001600160a01b03808616911603610e6d576001600160a01b0385166000908152600560205260409020544311610de057506001600160a01b0384166000908152600660205260408120805460ff191660011790555b6001600160a01b03851660009081526006602052604090205460ff1615610e0957506000610e6d565b6002546001600160a01b03858116911614801590610e3557506002546001600160a01b03868116911614155b15610e6d576001600160a01b038086166000908152600560205260408082204390819055878416835281832081905592861682529020555b949350505050565b600060208083528351808285015260005b81811015610ea257858101830151858201604001528201610e86565b81811115610eb4576000604083870101525b50601f01601f1916929092016040019392505050565b80356001600160a01b0381168114610ee157600080fd5b919050565b60008060408385031215610ef957600080fd5b610f0283610eca565b946020939093013593505050565b634e487b7160e01b600052604160045260246000fd5b604051601f8201601f1916810167ffffffffffffffff81118282101715610f4f57610f4f610f10565b604052919050565b600067ffffffffffffffff821115610f7157610f71610f10565b5060051b60200190565b600082601f830112610f8c57600080fd5b81356020610fa1610f9c83610f57565b610f26565b82815260059290921b84018101918181019086841115610fc057600080fd5b8286015b84811015610fe257610fd581610eca565b8352918301918301610fc4565b509695505050505050565b6000806040838503121561100057600080fd5b823567ffffffffffffffff8082111561101857600080fd5b61102486838701610f7b565b935060209150818501358181111561103b57600080fd5b85019050601f8101861361104e57600080fd5b803561105c610f9c82610f57565b81815260059190911b8201830190838101908883111561107b57600080fd5b928401925b8284101561109957833582529284019290840190611080565b80955050505050509250929050565b6000806000606084860312156110bd57600080fd5b6110c684610eca565b92506110d460208501610eca565b9150604084013590509250925092565b6000602082840312156110f657600080fd5b610ce982610eca565b60006020828403121561111157600080fd5b813567ffffffffffffffff81111561112857600080fd5b610e6d84828501610f7b565b6000806040838503121561114757600080fd5b61115083610eca565b915061115e60208401610eca565b90509250929050565b600181811c9082168061117b57607f821691505b60208210810361119b57634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b600081600019048311821515161561121c5761121c6111ec565b500290565b600060018201611233576112336111ec565b5060010190565b6000821982111561124d5761124d6111ec565b500190565b600082821015611264576112646111ec565b50039056fe45524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220fd57279f2ab5efdd797af8a3507368424c2e3bf1bb2d7769ddf60f2e95df4bfa64736f6c634300080e0033
Deployed Bytecode Sourcemap
21154:6746:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;22668:83;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;23522:169;;;;;;:::i;:::-;;:::i;:::-;;;1218:14:1;;1211:22;1193:41;;1181:2;1166:18;23522:169:0;1053:187:1;22945:100:0;23025:12;;22945:100;;;1391:25:1;;;1379:2;1364:18;22945:100:0;1245:177:1;26248:617:0;;;;;;:::i;:::-;;:::i;:::-;;23699:321;;;;;;:::i;:::-;;:::i;22854:83::-;22920:9;;22854:83;;22920:9;;;;4318:36:1;;4306:2;4291:18;22854:83:0;4176:184:1;24028:218:0;;;;;;:::i;:::-;;:::i;21302:28::-;;;;;-1:-1:-1;;;;;21302:28:0;;;;;;-1:-1:-1;;;;;4529:32:1;;;4511:51;;4499:2;4484:18;21302:28:0;4365:203:1;27139:96:0;;;;;;:::i;:::-;;:::i;23053:119::-;;;;;;:::i;:::-;-1:-1:-1;;;;;23146:18:0;23119:7;23146:18;;;:9;:18;;;;;;;23053:119;2657:103;;;:::i;2006:87::-;2052:7;2079:6;-1:-1:-1;;;;;2079:6:0;2006:87;;22759;;;:::i;24254:269::-;;;;;;:::i;:::-;;:::i;23180:175::-;;;;;;:::i;:::-;;:::i;26872:259::-;;;;;;:::i;:::-;;:::i;23363:151::-;;;;;;:::i;:::-;-1:-1:-1;;;;;23479:18:0;;;23452:7;23479:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;23363:151;21581:38;;;;;;:::i;:::-;;;;;;;;;;;;;;;;2915:201;;;;;;:::i;:::-;;:::i;24531:114::-;;;:::i;22668:83::-;22705:13;22738:5;22731:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;22668:83;:::o;23522:169::-;23605:4;23622:39;924:10;23645:7;23654:6;23622:8;:39::i;:::-;-1:-1:-1;23679:4:0;23522:169;;;;:::o;26248:617::-;2052:7;2079:6;-1:-1:-1;;;;;2079:6:0;924:10;2226:23;2218:68;;;;-1:-1:-1;;;2218:68:0;;;;;;;:::i;:::-;;;;;;;;;26390:15:::1;:22;26372:7;:14;:40;26364:83;;;::::0;-1:-1:-1;;;26364:83:0;;6330:2:1;26364:83:0::1;::::0;::::1;6312:21:1::0;6369:2;6349:18;;;6342:30;6408:32;6388:18;;;6381:60;6458:18;;26364:83:0::1;6128:354:1::0;26364:83:0::1;26483:3;26466:7;:14;:20;26458:87;;;::::0;-1:-1:-1;;;26458:87:0;;6689:2:1;26458:87:0::1;::::0;::::1;6671:21:1::0;6728:2;6708:18;;;6701:30;6767:34;6747:18;;;6740:62;-1:-1:-1;;;6818:18:1;;;6811:52;6880:19;;26458:87:0::1;6487:418:1::0;26458:87:0::1;26658:9;26654:204;26677:7;:14;26673:1;:18;26654:204;;;26712:14;26729:7;26737:1;26729:10;;;;;;;;:::i;:::-;;;;;;;26712:27;;26754:14;26771:15;26787:1;26771:18;;;;;;;;:::i;:::-;;;;;;;26790:4;26771:23;;;;:::i;:::-;26754:40;;26809:37;26819:10;26831:6;26839;26809:9;:37::i;:::-;26697:161;;26693:3;;;;;:::i;:::-;;;;26654:204;;;;26248:617:::0;;:::o;23699:321::-;23805:4;23822:36;23832:6;23840:9;23851:6;23822:9;:36::i;:::-;23869:121;23878:6;924:10;23900:89;23938:6;23900:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;23900:19:0;;;;;;:11;:19;;;;;;;;924:10;23900:33;;;;;;;;;;:37;:89::i;:::-;23869:8;:121::i;:::-;-1:-1:-1;24008:4:0;23699:321;;;;;:::o;24028:218::-;924:10;24116:4;24165:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;24165:34:0;;;;;;;;;;24116:4;;24133:83;;24156:7;;24165:50;;24204:10;24165:38;:50::i;27139:96::-;2052:7;2079:6;-1:-1:-1;;;;;2079:6:0;924:10;2226:23;2218:68;;;;-1:-1:-1;;;2218:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;27204:15:0::1;27222:5;27204:15:::0;;;:6:::1;:15;::::0;;;;:23;;-1:-1:-1;;27204:23:0::1;::::0;;27139:96::o;2657:103::-;2052:7;2079:6;-1:-1:-1;;;;;2079:6:0;924:10;2226:23;2218:68;;;;-1:-1:-1;;;2218:68:0;;;;;;;:::i;:::-;2722:30:::1;2749:1;2722:18;:30::i;:::-;2657:103::o:0;22759:87::-;22798:13;22831:7;22824:14;;;;;:::i;24254:269::-;24347:4;24364:129;924:10;24387:7;24396:96;24435:15;24396:96;;;;;;;;;;;;;;;;;924:10;24396:25;;;;:11;:25;;;;;;;;-1:-1:-1;;;;;24396:34:0;;;;;;;;;;;;:38;:96::i;23180:175::-;23266:4;23283:42;924:10;23307:9;23318:6;23283:9;:42::i;26872:259::-;2052:7;2079:6;-1:-1:-1;;;;;2079:6:0;924:10;2226:23;2218:68;;;;-1:-1:-1;;;2218:68:0;;;;;;;:::i;:::-;26968:8:::1;::::0;:14:::1;::::0;26979:3:::1;26968:14;:::i;:::-;26953:12;:29;26945:69;;;::::0;-1:-1:-1;;;26945:69:0;;7822:2:1;26945:69:0::1;::::0;::::1;7804:21:1::0;7861:2;7841:18;;;7834:30;7900:29;7880:18;;;7873:57;7947:18;;26945:69:0::1;7620:351:1::0;26945:69:0::1;27030:9;27025:99;27049:8;:15;27045:1;:19;27025:99;;;27108:4;27086:6;:19;27093:8;27102:1;27093:11;;;;;;;;:::i;:::-;;::::0;;::::1;::::0;;;;;;;-1:-1:-1;;;;;27086:19:0::1;::::0;;;::::1;::::0;;;;;;-1:-1:-1;27086:19:0;:26;;-1:-1:-1;;27086:26:0::1;::::0;::::1;;::::0;;;::::1;::::0;;27066:3;::::1;::::0;::::1;:::i;:::-;;;;27025:99;;;;26872:259:::0;:::o;2915:201::-;2052:7;2079:6;-1:-1:-1;;;;;2079:6:0;924:10;2226:23;2218:68;;;;-1:-1:-1;;;2218:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;3004:22:0;::::1;2996:73;;;::::0;-1:-1:-1;;;2996:73:0;;8178:2:1;2996:73:0::1;::::0;::::1;8160:21:1::0;8217:2;8197:18;;;8190:30;8256:34;8236:18;;;8229:62;-1:-1:-1;;;8307:18:1;;;8300:36;8353:19;;2996:73:0::1;7976:402:1::0;2996:73:0::1;3080:28;3099:8;3080:18;:28::i;:::-;2915:201:::0;:::o;24531:114::-;2052:7;2079:6;-1:-1:-1;;;;;2079:6:0;924:10;2226:23;2218:68;;;;-1:-1:-1;;;2218:68:0;;;;;;;:::i;:::-;24582:13:::1;:20:::0;;-1:-1:-1;;24582:20:0::1;24598:4;24582:20;::::0;;24625:12:::1;24614:8;:23:::0;24531:114::o;25676:346::-;-1:-1:-1;;;;;25778:19:0;;25770:68;;;;-1:-1:-1;;;25770:68:0;;8585:2:1;25770:68:0;;;8567:21:1;8624:2;8604:18;;;8597:30;8663:34;8643:18;;;8636:62;-1:-1:-1;;;8714:18:1;;;8707:34;8758:19;;25770:68:0;8383:400:1;25770:68:0;-1:-1:-1;;;;;25857:21:0;;25849:68;;;;-1:-1:-1;;;25849:68:0;;8990:2:1;25849:68:0;;;8972:21:1;9029:2;9009:18;;;9002:30;9068:34;9048:18;;;9041:62;-1:-1:-1;;;9119:18:1;;;9112:32;9161:19;;25849:68:0;8788:398:1;25849:68:0;-1:-1:-1;;;;;25930:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;25982:32;;1391:25:1;;;25982:32:0;;1364:18:1;25982:32:0;;;;;;;;25676:346;;;:::o;24653:1015::-;-1:-1:-1;;;;;24759:20:0;;24751:70;;;;-1:-1:-1;;;24751:70:0;;9393:2:1;24751:70:0;;;9375:21:1;9432:2;9412:18;;;9405:30;9471:34;9451:18;;;9444:62;-1:-1:-1;;;9522:18:1;;;9515:35;9567:19;;24751:70:0;9191:401:1;24751:70:0;-1:-1:-1;;;;;24840:23:0;;24832:71;;;;-1:-1:-1;;;24832:71:0;;9799:2:1;24832:71:0;;;9781:21:1;9838:2;9818:18;;;9811:30;9877:34;9857:18;;;9850:62;-1:-1:-1;;;9928:18:1;;;9921:33;9971:19;;24832:71:0;9597:399:1;24832:71:0;-1:-1:-1;;;;;24923:14:0;;;;;;:6;:14;;;;;;;;24922:15;:37;;;;-1:-1:-1;;;;;;24942:17:0;;;;;;:6;:17;;;;;;;;24941:18;24922:37;24914:77;;;;-1:-1:-1;;;24914:77:0;;10203:2:1;24914:77:0;;;10185:21:1;10242:2;10222:18;;;10215:30;10281:29;10261:18;;;10254:57;10328:18;;24914:77:0;10001:351:1;24914:77:0;25007:13;;;;25002:124;;-1:-1:-1;;;;;25046:17:0;;;;;;:9;:17;;;;;;;;;:41;;-1:-1:-1;;;;;;25067:20:0;;;;;;:9;:20;;;;;;;;25046:41;25037:77;;;;-1:-1:-1;;;25037:77:0;;10559:2:1;25037:77:0;;;10541:21:1;10598:2;10578:18;;;10571:30;-1:-1:-1;;;10617:18:1;;;10610:52;10679:18;;25037:77:0;10357:346:1;25037:77:0;25161:18;25176:3;25161:12;:18;:::i;:::-;25150:8;;:29;25146:234;;;25196:13;25239:9;25274:36;25288:6;25295:9;25239;25274:13;:36::i;:::-;25263:47;;25333:8;25325:43;;;;-1:-1:-1;;;25325:43:0;;11040:2:1;25325:43:0;;;11022:21:1;11079:2;11059:18;;;11052:30;-1:-1:-1;;;11098:18:1;;;11091:52;11160:18;;25325:43:0;10838:346:1;25325:43:0;25181:199;;25146:234;25472:71;25494:6;25472:71;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;25472:17:0;;;;;;:9;:17;;;;;;;:71;:21;:71::i;:::-;-1:-1:-1;;;;;25452:17:0;;;;;;;:9;:17;;;;;;:91;;;;25577:20;;;;;;;:32;;25602:6;25577:24;:32::i;:::-;-1:-1:-1;;;;;25554:20:0;;;;;;;:9;:20;;;;;;;:55;;;;25625:35;;;;;;;;;;25653:6;1391:25:1;;1379:2;1364:18;;1245:177;8106:240:0;8226:7;8287:12;8279:6;;;;8271:29;;;;-1:-1:-1;;;8271:29:0;;;;;;;;:::i;:::-;-1:-1:-1;;;8322:5:0;;;8106:240::o;5827:98::-;5885:7;5912:5;5916:1;5912;:5;:::i;:::-;5905:12;5827:98;-1:-1:-1;;;5827:98:0:o;3276:191::-;3350:16;3369:6;;-1:-1:-1;;;;;3386:17:0;;;-1:-1:-1;;;;;;3386:17:0;;;;;;3419:40;;3369:6;;;;;;;3419:40;;3350:16;3419:40;3339:128;3276:191;:::o;27244:653::-;27369:13;;27325:4;;27354;;-1:-1:-1;;;;;27369:21:0;;;:13;;:21;27365:497;;-1:-1:-1;;;;;27395:18:0;;;;;;;:14;:18;;;;;;27416:12;27395:33;;;;27431:20;;;;;;;:35;27365:497;;;27483:13;;-1:-1:-1;;;;;27483:19:0;;;:13;;:19;27479:383;;-1:-1:-1;;;;;27523:20:0;;;;;;:14;:20;;;;;;27547:12;-1:-1:-1;27519:89:0;;-1:-1:-1;;;;;;27563:18:0;;;;;;:12;:18;;;;;:25;;-1:-1:-1;;27563:25:0;27584:4;27563:25;;;27519:89;-1:-1:-1;;;;;27630:18:0;;;;;;:12;:18;;;;;;;;27626:225;;;-1:-1:-1;27663:5:0;27626:225;;;27694:13;;-1:-1:-1;;;;;27694:19:0;;;:13;;:19;;;;:44;;-1:-1:-1;27717:13:0;;-1:-1:-1;;;;;27717:21:0;;;:13;;:21;;27694:44;27690:161;;;-1:-1:-1;;;;;27742:20:0;;;;;;;:14;:20;;;;;;27765:12;27742:35;;;;27779:18;;;;;;;;:33;;;27814:20;;;;;;;:35;27690:161;27880:8;27244:653;-1:-1:-1;;;;27244:653:0:o;14:597:1:-;126:4;155:2;184;173:9;166:21;216:6;210:13;259:6;254:2;243:9;239:18;232:34;284:1;294:140;308:6;305:1;302:13;294:140;;;403:14;;;399:23;;393:30;369:17;;;388:2;365:26;358:66;323:10;;294:140;;;452:6;449:1;446:13;443:91;;;522:1;517:2;508:6;497:9;493:22;489:31;482:42;443:91;-1:-1:-1;595:2:1;574:15;-1:-1:-1;;570:29:1;555:45;;;;602:2;551:54;;14:597;-1:-1:-1;;;14:597:1:o;616:173::-;684:20;;-1:-1:-1;;;;;733:31:1;;723:42;;713:70;;779:1;776;769:12;713:70;616:173;;;:::o;794:254::-;862:6;870;923:2;911:9;902:7;898:23;894:32;891:52;;;939:1;936;929:12;891:52;962:29;981:9;962:29;:::i;:::-;952:39;1038:2;1023:18;;;;1010:32;;-1:-1:-1;;;794:254:1:o;1427:127::-;1488:10;1483:3;1479:20;1476:1;1469:31;1519:4;1516:1;1509:15;1543:4;1540:1;1533:15;1559:275;1630:2;1624:9;1695:2;1676:13;;-1:-1:-1;;1672:27:1;1660:40;;1730:18;1715:34;;1751:22;;;1712:62;1709:88;;;1777:18;;:::i;:::-;1813:2;1806:22;1559:275;;-1:-1:-1;1559:275:1:o;1839:183::-;1899:4;1932:18;1924:6;1921:30;1918:56;;;1954:18;;:::i;:::-;-1:-1:-1;1999:1:1;1995:14;2011:4;1991:25;;1839:183::o;2027:668::-;2081:5;2134:3;2127:4;2119:6;2115:17;2111:27;2101:55;;2152:1;2149;2142:12;2101:55;2188:6;2175:20;2214:4;2238:60;2254:43;2294:2;2254:43;:::i;:::-;2238:60;:::i;:::-;2332:15;;;2418:1;2414:10;;;;2402:23;;2398:32;;;2363:12;;;;2442:15;;;2439:35;;;2470:1;2467;2460:12;2439:35;2506:2;2498:6;2494:15;2518:148;2534:6;2529:3;2526:15;2518:148;;;2600:23;2619:3;2600:23;:::i;:::-;2588:36;;2644:12;;;;2551;;2518:148;;;-1:-1:-1;2684:5:1;2027:668;-1:-1:-1;;;;;;2027:668:1:o;2700:1138::-;2818:6;2826;2879:2;2867:9;2858:7;2854:23;2850:32;2847:52;;;2895:1;2892;2885:12;2847:52;2935:9;2922:23;2964:18;3005:2;2997:6;2994:14;2991:34;;;3021:1;3018;3011:12;2991:34;3044:61;3097:7;3088:6;3077:9;3073:22;3044:61;:::i;:::-;3034:71;;3124:2;3114:12;;3179:2;3168:9;3164:18;3151:32;3208:2;3198:8;3195:16;3192:36;;;3224:1;3221;3214:12;3192:36;3247:24;;;-1:-1:-1;3302:4:1;3294:13;;3290:27;-1:-1:-1;3280:55:1;;3331:1;3328;3321:12;3280:55;3367:2;3354:16;3390:60;3406:43;3446:2;3406:43;:::i;3390:60::-;3484:15;;;3566:1;3562:10;;;;3554:19;;3550:28;;;3515:12;;;;3590:19;;;3587:39;;;3622:1;3619;3612:12;3587:39;3646:11;;;;3666:142;3682:6;3677:3;3674:15;3666:142;;;3748:17;;3736:30;;3699:12;;;;3786;;;;3666:142;;;3827:5;3817:15;;;;;;;2700:1138;;;;;:::o;3843:328::-;3920:6;3928;3936;3989:2;3977:9;3968:7;3964:23;3960:32;3957:52;;;4005:1;4002;3995:12;3957:52;4028:29;4047:9;4028:29;:::i;:::-;4018:39;;4076:38;4110:2;4099:9;4095:18;4076:38;:::i;:::-;4066:48;;4161:2;4150:9;4146:18;4133:32;4123:42;;3843:328;;;;;:::o;4573:186::-;4632:6;4685:2;4673:9;4664:7;4660:23;4656:32;4653:52;;;4701:1;4698;4691:12;4653:52;4724:29;4743:9;4724:29;:::i;4764:348::-;4848:6;4901:2;4889:9;4880:7;4876:23;4872:32;4869:52;;;4917:1;4914;4907:12;4869:52;4957:9;4944:23;4990:18;4982:6;4979:30;4976:50;;;5022:1;5019;5012:12;4976:50;5045:61;5098:7;5089:6;5078:9;5074:22;5045:61;:::i;5117:260::-;5185:6;5193;5246:2;5234:9;5225:7;5221:23;5217:32;5214:52;;;5262:1;5259;5252:12;5214:52;5285:29;5304:9;5285:29;:::i;:::-;5275:39;;5333:38;5367:2;5356:9;5352:18;5333:38;:::i;:::-;5323:48;;5117:260;;;;;:::o;5382:380::-;5461:1;5457:12;;;;5504;;;5525:61;;5579:4;5571:6;5567:17;5557:27;;5525:61;5632:2;5624:6;5621:14;5601:18;5598:38;5595:161;;5678:10;5673:3;5669:20;5666:1;5659:31;5713:4;5710:1;5703:15;5741:4;5738:1;5731:15;5595:161;;5382:380;;;:::o;5767:356::-;5969:2;5951:21;;;5988:18;;;5981:30;6047:34;6042:2;6027:18;;6020:62;6114:2;6099:18;;5767:356::o;6910:127::-;6971:10;6966:3;6962:20;6959:1;6952:31;7002:4;6999:1;6992:15;7026:4;7023:1;7016:15;7042:127;7103:10;7098:3;7094:20;7091:1;7084:31;7134:4;7131:1;7124:15;7158:4;7155:1;7148:15;7174:168;7214:7;7280:1;7276;7272:6;7268:14;7265:1;7262:21;7257:1;7250:9;7243:17;7239:45;7236:71;;;7287:18;;:::i;:::-;-1:-1:-1;7327:9:1;;7174:168::o;7347:135::-;7386:3;7407:17;;;7404:43;;7427:18;;:::i;:::-;-1:-1:-1;7474:1:1;7463:13;;7347:135::o;7487:128::-;7527:3;7558:1;7554:6;7551:1;7548:13;7545:39;;;7564:18;;:::i;:::-;-1:-1:-1;7600:9:1;;7487:128::o;10708:125::-;10748:4;10776:1;10773;10770:8;10767:34;;;10781:18;;:::i;:::-;-1:-1:-1;10818:9:1;;10708:125::o
Swarm Source
ipfs://fd57279f2ab5efdd797af8a3507368424c2e3bf1bb2d7769ddf60f2e95df4bfa
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.