Overview
S Balance
S Value
$0.00More Info
Private Name Tags
ContractCreator
Loading...
Loading
Contract Name:
safeTokenFactory
Compiler Version
v0.8.20+commit.a1b79de6
Contract Source Code (Solidity)
/** *Submitted for verification at SonicScan.org on 2025-02-20 */ // File: contracts/Context.sol pragma solidity ^0.8.20; abstract contract Context { function _msgSender() internal view virtual returns (address) { return msg.sender; } function _msgData() internal view virtual returns (bytes calldata) { return msg.data; } function _contextSuffixLength() internal view virtual returns (uint256) { return 0; } } // File: interfaces/IERC20.sol pragma solidity ^0.8.20; interface IERC20 { /** * @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 Returns the value of tokens in existence. */ function totalSupply() external view returns (uint256); /** * @dev Returns the value of tokens owned by `account`. */ function balanceOf(address account) external view returns (uint256); /** * @dev Moves a `value` amount of tokens from the caller's account to `to`. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transfer(address to, uint256 value) 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 a `value` amount of tokens 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 value) external returns (bool); /** * @dev Moves a `value` amount of tokens from `from` to `to` using the * allowance mechanism. `value` is then deducted from the caller's * allowance. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transferFrom(address from, address to, uint256 value) external returns (bool); } // File: interfaces/IERC20Metadata.sol pragma solidity ^0.8.20; 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); } // File: interfaces/IERC20Errors.sol pragma solidity ^0.8.20; interface IERC20Errors { /** * @dev Indicates an error related to the current `balance` of a `sender`. Used in transfers. * @param sender Address whose tokens are being transferred. * @param balance Current balance for the interacting account. * @param needed Minimum amount required to perform a transfer. */ error ERC20InsufficientBalance(address sender, uint256 balance, uint256 needed); /** * @dev Indicates a failure with the token `sender`. Used in transfers. * @param sender Address whose tokens are being transferred. */ error ERC20InvalidSender(address sender); /** * @dev Indicates a failure with the token `receiver`. Used in transfers. * @param receiver Address to which tokens are being transferred. */ error ERC20InvalidReceiver(address receiver); /** * @dev Indicates a failure with the `spender`’s `allowance`. Used in transfers. * @param spender Address that may be allowed to operate on tokens without being their owner. * @param allowance Amount of tokens a `spender` is allowed to operate with. * @param needed Minimum amount required to perform a transfer. */ error ERC20InsufficientAllowance(address spender, uint256 allowance, uint256 needed); /** * @dev Indicates a failure with the `approver` of a token to be approved. Used in approvals. * @param approver Address initiating an approval operation. */ error ERC20InvalidApprover(address approver); /** * @dev Indicates a failure with the `spender` to be approved. Used in approvals. * @param spender Address that may be allowed to operate on tokens without being their owner. */ error ERC20InvalidSpender(address spender); } // File: interfaces/IEtherVistaFactory.sol pragma solidity ^0.8.20; interface IEtherVistaFactory { event PairCreated(address indexed token0, address indexed token1, address pair, uint); function feeTo() external view returns (address); function feeToSetter() external view returns (address); function routerSetter() external view returns (address); function router() 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; function setRouterSetter(address) external; function setRouter(address) external; } // File: contracts/ERC20.sol pragma solidity ^0.8.20; abstract contract ERC20 is Context, IERC20, IERC20Metadata, IERC20Errors { mapping(address account => uint256) private _balances; mapping(address account => mapping(address spender => uint256)) private _allowances; uint256 private _totalSupply; string private _name; string private _symbol; address factory = 0x8679749e7bbA02aF1eE054Ba30CDF18019f4960C; //change bool public vistaOnly; /** * @dev Sets the values for {name} and {symbol}. * * All two of these values are immutable: they can only be set once during * construction. */ constructor(string memory name_, string memory symbol_, bool _vistaOnly) { _name = name_; _symbol = symbol_; vistaOnly = _vistaOnly; } /** * @dev Returns the name of the token. */ function name() public view virtual returns (string memory) { return _name; } /** * @dev Returns the symbol of the token, usually a shorter version of the * name. */ function symbol() public view virtual returns (string memory) { return _symbol; } /** * @dev Returns the number of decimals used to get its user representation. * For example, if `decimals` equals `2`, a balance of `505` tokens should * be displayed to a user as `5.05` (`505 / 10 ** 2`). * * Tokens usually opt for a value of 18, imitating the relationship between * Ether and Wei. This is the default value returned by this function, unless * it's overridden. * * NOTE: This information is only used for _display_ purposes: it in * no way affects any of the arithmetic of the contract, including * {IERC20-balanceOf} and {IERC20-transfer}. */ function decimals() public view virtual returns (uint8) { return 18; } /** * @dev See {IERC20-totalSupply}. */ function totalSupply() public view virtual returns (uint256) { return _totalSupply; } /** * @dev See {IERC20-balanceOf}. */ function balanceOf(address account) public view virtual returns (uint256) { return _balances[account]; } /** * @dev See {IERC20-transfer}. * * Requirements: * * - `to` cannot be the zero address. * - the caller must have a balance of at least `value`. */ function transfer(address to, uint256 value) public virtual returns (bool) { address owner = _msgSender(); _transfer(owner, to, value); return true; } /** * @dev See {IERC20-allowance}. */ function allowance(address owner, address spender) public view virtual returns (uint256) { return _allowances[owner][spender]; } /** * @dev See {IERC20-approve}. * * NOTE: If `value` is the maximum `uint256`, the allowance is not updated on * `transferFrom`. This is semantically equivalent to an infinite approval. * * Requirements: * * - `spender` cannot be the zero address. */ function approve(address spender, uint256 value) public virtual returns (bool) { if (vistaOnly == true) { require(spender == IEtherVistaFactory(factory).router()); } address owner = _msgSender(); _approve(owner, spender, value); return true; } /** * @dev See {IERC20-transferFrom}. * * Skips emitting an {Approval} event indicating an allowance update. This is not * required by the ERC. See {xref-ERC20-_approve-address-address-uint256-bool-}[_approve]. * * NOTE: Does not update the allowance if the current allowance * is the maximum `uint256`. * * Requirements: * * - `from` and `to` cannot be the zero address. * - `from` must have a balance of at least `value`. * - the caller must have allowance for ``from``'s tokens of at least * `value`. */ function transferFrom(address from, address to, uint256 value) public virtual returns (bool) { address spender = _msgSender(); _spendAllowance(from, spender, value); _transfer(from, to, value); return true; } /** * @dev Moves a `value` amount of tokens from `from` to `to`. * * This internal function is equivalent to {transfer}, and can be used to * e.g. implement automatic token fees, slashing mechanisms, etc. * * Emits a {Transfer} event. * * NOTE: This function is not virtual, {_update} should be overridden instead. */ function _transfer(address from, address to, uint256 value) internal { if (from == address(0)) { revert ERC20InvalidSender(address(0)); } if (to == address(0)) { revert ERC20InvalidReceiver(address(0)); } _update(from, to, value); } /** * @dev Transfers a `value` amount of tokens from `from` to `to`, or alternatively mints (or burns) if `from` * (or `to`) is the zero address. All customizations to transfers, mints, and burns should be done by overriding * this function. * * Emits a {Transfer} event. */ function _update(address from, address to, uint256 value) internal virtual { if (from == address(0)) { // Overflow check required: The rest of the code assumes that totalSupply never overflows _totalSupply += value; } else { uint256 fromBalance = _balances[from]; if (fromBalance < value) { revert ERC20InsufficientBalance(from, fromBalance, value); } unchecked { // Overflow not possible: value <= fromBalance <= totalSupply. _balances[from] = fromBalance - value; } } if (to == address(0)) { unchecked { // Overflow not possible: value <= totalSupply or value <= fromBalance <= totalSupply. _totalSupply -= value; } } else { unchecked { // Overflow not possible: balance + value is at most totalSupply, which we know fits into a uint256. _balances[to] += value; } } emit Transfer(from, to, value); } /** * @dev Creates a `value` amount of tokens and assigns them to `account`, by transferring it from address(0). * Relies on the `_update` mechanism * * Emits a {Transfer} event with `from` set to the zero address. * * NOTE: This function is not virtual, {_update} should be overridden instead. */ function _mint(address account, uint256 value) internal { if (account == address(0)) { revert ERC20InvalidReceiver(address(0)); } _update(address(0), account, value); } /** * @dev Destroys a `value` amount of tokens from `account`, lowering the total supply. * Relies on the `_update` mechanism. * * Emits a {Transfer} event with `to` set to the zero address. * * NOTE: This function is not virtual, {_update} should be overridden instead */ function _burn(address account, uint256 value) internal { if (account == address(0)) { revert ERC20InvalidSender(address(0)); } _update(account, address(0), value); } /** * @dev Sets `value` as the allowance of `spender` over the `owner` s tokens. * * This internal function is equivalent to `approve`, and can be used to * e.g. set automatic allowances for certain subsystems, etc. * * Emits an {Approval} event. * * Requirements: * * - `owner` cannot be the zero address. * - `spender` cannot be the zero address. * * Overrides to this logic should be done to the variant with an additional `bool emitEvent` argument. */ function _approve(address owner, address spender, uint256 value) internal { _approve(owner, spender, value, true); } /** * @dev Variant of {_approve} with an optional flag to enable or disable the {Approval} event. * * By default (when calling {_approve}) the flag is set to true. On the other hand, approval changes made by * `_spendAllowance` during the `transferFrom` operation set the flag to false. This saves gas by not emitting any * `Approval` event during `transferFrom` operations. * * Anyone who wishes to continue emitting `Approval` events on the`transferFrom` operation can force the flag to * true using the following override: * * ```solidity * function _approve(address owner, address spender, uint256 value, bool) internal virtual override { * super._approve(owner, spender, value, true); * } * ``` * * Requirements are the same as {_approve}. */ function _approve(address owner, address spender, uint256 value, bool emitEvent) internal virtual { if (owner == address(0)) { revert ERC20InvalidApprover(address(0)); } if (spender == address(0)) { revert ERC20InvalidSpender(address(0)); } _allowances[owner][spender] = value; if (emitEvent) { emit Approval(owner, spender, value); } } /** * @dev Updates `owner` s allowance for `spender` based on spent `value`. * * Does not update the allowance value in case of infinite allowance. * Revert if not enough allowance is available. * * Does not emit an {Approval} event. */ function _spendAllowance(address owner, address spender, uint256 value) internal virtual { uint256 currentAllowance = allowance(owner, spender); if (currentAllowance != type(uint256).max) { if (currentAllowance < value) { revert ERC20InsufficientAllowance(spender, currentAllowance, value); } unchecked { _approve(owner, spender, currentAllowance - value, false); } } } } // File: contracts/Token.sol pragma solidity ^0.8.20; contract Token is ERC20 { constructor(string memory name, string memory ticker, uint256 supply, bool vistaOnly) ERC20(name, ticker, vistaOnly) { _mint(tx.origin, supply * (10 ** uint256(decimals()))); } } // File: contracts/SafeTokenFactory.sol pragma solidity ^0.8.20; contract safeTokenFactory { event safeTokenCreated(address tokenAddress, string name, string symbol); mapping(address => bool) public whitelistedTokens; function create(string memory name, string memory symbol,uint256 supply, bool vistaOnly) external returns (address) { Token safeToken = new Token(name, symbol, supply, vistaOnly); emit safeTokenCreated(address(safeToken), name, symbol); whitelistedTokens[address(safeToken)] = true; return address(safeToken); } }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"tokenAddress","type":"address"},{"indexed":false,"internalType":"string","name":"name","type":"string"},{"indexed":false,"internalType":"string","name":"symbol","type":"string"}],"name":"safeTokenCreated","type":"event"},{"inputs":[{"internalType":"string","name":"name","type":"string"},{"internalType":"string","name":"symbol","type":"string"},{"internalType":"uint256","name":"supply","type":"uint256"},{"internalType":"bool","name":"vistaOnly","type":"bool"}],"name":"create","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"whitelistedTokens","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"}]
Contract Creation Code
608060405234801561000f575f80fd5b506111d68061001d5f395ff3fe608060405234801562000010575f80fd5b506004361062000038575f3560e01c8063a1f3f866146200003c578063daf9c2101462000070575b5f80fd5b620000536200004d36600462000202565b620000a6565b6040516001600160a01b0390911681526020015b60405180910390f35b620000956200008136600462000289565b5f6020819052908152604090205460ff1681565b604051901515815260200162000067565b5f8085858585604051620000ba906200014f565b620000c99493929190620002fd565b604051809103905ff080158015620000e3573d5f803e3d5ffd5b5090507f7af6222f62edab5fa312a46f086a615c44ec4627ed57fe8a35f5a7c536ba2d128187876040516200011b939291906200033e565b60405180910390a16001600160a01b0381165f908152602081905260409020805460ff191660011790559050949350505050565b610e1f806200038283390190565b634e487b7160e01b5f52604160045260245ffd5b5f82601f83011262000181575f80fd5b813567ffffffffffffffff808211156200019f576200019f6200015d565b604051601f8301601f19908116603f01168101908282118183101715620001ca57620001ca6200015d565b81604052838152866020858801011115620001e3575f80fd5b836020870160208301375f602085830101528094505050505092915050565b5f805f806080858703121562000216575f80fd5b843567ffffffffffffffff808211156200022e575f80fd5b6200023c8883890162000171565b9550602087013591508082111562000252575f80fd5b50620002618782880162000171565b93505060408501359150606085013580151581146200027e575f80fd5b939692955090935050565b5f602082840312156200029a575f80fd5b81356001600160a01b0381168114620002b1575f80fd5b9392505050565b5f81518084525f5b81811015620002de57602081850181015186830182015201620002c0565b505f602082860101526020601f19601f83011685010191505092915050565b608081525f620003116080830187620002b8565b8281036020840152620003258187620002b8565b6040840195909552505090151560609091015292915050565b6001600160a01b03841681526060602082018190525f906200036390830185620002b8565b8281036040840152620003778185620002b8565b969550505050505056fe6080604052600580546001600160a01b031916738679749e7bba02af1ee054ba30cdf18019f4960c17905534801562000036575f80fd5b5060405162000e1f38038062000e1f833981016040819052620000599162000300565b83838260036200006a848262000412565b50600462000079838262000412565b5060058054911515600160a01b0260ff60a01b1990921691909117905550620000c9905032620000a7601290565b620000b79060ff16600a620005e9565b620000c39085620005fd565b620000d3565b505050506200062d565b6001600160a01b038216620001025760405163ec442f0560e01b81525f60048201526024015b60405180910390fd5b6200010f5f838362000113565b5050565b6001600160a01b03831662000141578060025f82825462000135919062000617565b90915550620001b39050565b6001600160a01b0383165f9081526020819052604090205481811015620001955760405163391434e360e21b81526001600160a01b03851660048201526024810182905260448101839052606401620000f9565b6001600160a01b0384165f9081526020819052604090209082900390555b6001600160a01b038216620001d157600280548290039055620001ef565b6001600160a01b0382165f9081526020819052604090208054820190555b816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef836040516200023591815260200190565b60405180910390a3505050565b634e487b7160e01b5f52604160045260245ffd5b5f82601f83011262000266575f80fd5b81516001600160401b038082111562000283576200028362000242565b604051601f8301601f19908116603f01168101908282118183101715620002ae57620002ae62000242565b81604052838152602092508683858801011115620002ca575f80fd5b5f91505b83821015620002ed5785820183015181830184015290820190620002ce565b5f93810190920192909252949350505050565b5f805f806080858703121562000314575f80fd5b84516001600160401b03808211156200032b575f80fd5b620003398883890162000256565b955060208701519150808211156200034f575f80fd5b506200035e8782880162000256565b93505060408501519150606085015180151581146200037b575f80fd5b939692955090935050565b600181811c908216806200039b57607f821691505b602082108103620003ba57634e487b7160e01b5f52602260045260245ffd5b50919050565b601f8211156200040d575f81815260208120601f850160051c81016020861015620003e85750805b601f850160051c820191505b818110156200040957828155600101620003f4565b5050505b505050565b81516001600160401b038111156200042e576200042e62000242565b62000446816200043f845462000386565b84620003c0565b602080601f8311600181146200047c575f8415620004645750858301515b5f19600386901b1c1916600185901b17855562000409565b5f85815260208120601f198616915b82811015620004ac578886015182559484019460019091019084016200048b565b5085821015620004ca57878501515f19600388901b60f8161c191681555b5050505050600190811b01905550565b634e487b7160e01b5f52601160045260245ffd5b600181815b808511156200052e57815f1904821115620005125762000512620004da565b808516156200052057918102915b93841c9390800290620004f3565b509250929050565b5f826200054657506001620005e3565b816200055457505f620005e3565b81600181146200056d5760028114620005785762000598565b6001915050620005e3565b60ff8411156200058c576200058c620004da565b50506001821b620005e3565b5060208310610133831016604e8410600b8410161715620005bd575081810a620005e3565b620005c98383620004ee565b805f1904821115620005df57620005df620004da565b0290505b92915050565b5f620005f6838362000536565b9392505050565b8082028115828204841417620005e357620005e3620004da565b80820180821115620005e357620005e3620004da565b6107e4806200063b5f395ff3fe608060405234801561000f575f80fd5b506004361061009b575f3560e01c806370a082311161006357806370a0823114610114578063956b956a1461013c57806395d89b4114610150578063a9059cbb14610158578063dd62ed3e1461016b575f80fd5b806306fdde031461009f578063095ea7b3146100bd57806318160ddd146100e057806323b872dd146100f2578063313ce56714610105575b5f80fd5b6100a76101a3565b6040516100b49190610619565b60405180910390f35b6100d06100cb36600461067b565b610233565b60405190151581526020016100b4565b6002545b6040519081526020016100b4565b6100d06101003660046106a5565b6102f3565b604051601281526020016100b4565b6100e46101223660046106e3565b6001600160a01b03165f9081526020819052604090205490565b6005546100d090600160a01b900460ff1681565b6100a7610316565b6100d061016636600461067b565b610325565b6100e4610179366004610705565b6001600160a01b039182165f90815260016020908152604080832093909416825291909152205490565b6060600380546101b29061073c565b80601f01602080910402602001604051908101604052809291908181526020018280546101de9061073c565b80156102295780601f1061020057610100808354040283529160200191610229565b820191905f5260205f20905b81548152906001019060200180831161020c57829003601f168201915b5050505050905090565b6005545f90600160a01b900460ff1615156001036102db5760055f9054906101000a90046001600160a01b03166001600160a01b031663f887ea406040518163ffffffff1660e01b8152600401602060405180830381865afa15801561029b573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906102bf9190610774565b6001600160a01b0316836001600160a01b0316146102db575f80fd5b336102e7818585610332565b60019150505b92915050565b5f33610300858285610344565b61030b8585856103c4565b506001949350505050565b6060600480546101b29061073c565b5f336102e78185856103c4565b61033f8383836001610421565b505050565b6001600160a01b038381165f908152600160209081526040808320938616835292905220545f1981146103be57818110156103b057604051637dc7a0d960e11b81526001600160a01b038416600482015260248101829052604481018390526064015b60405180910390fd5b6103be84848484035f610421565b50505050565b6001600160a01b0383166103ed57604051634b637e8f60e11b81525f60048201526024016103a7565b6001600160a01b0382166104165760405163ec442f0560e01b81525f60048201526024016103a7565b61033f8383836104f3565b6001600160a01b03841661044a5760405163e602df0560e01b81525f60048201526024016103a7565b6001600160a01b03831661047357604051634a1406b160e11b81525f60048201526024016103a7565b6001600160a01b038085165f90815260016020908152604080832093871683529290522082905580156103be57826001600160a01b0316846001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925846040516104e591815260200190565b60405180910390a350505050565b6001600160a01b03831661051d578060025f828254610512919061078f565b9091555061058d9050565b6001600160a01b0383165f908152602081905260409020548181101561056f5760405163391434e360e21b81526001600160a01b038516600482015260248101829052604481018390526064016103a7565b6001600160a01b0384165f9081526020819052604090209082900390555b6001600160a01b0382166105a9576002805482900390556105c7565b6001600160a01b0382165f9081526020819052604090208054820190555b816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8360405161060c91815260200190565b60405180910390a3505050565b5f6020808352835180828501525f5b8181101561064457858101830151858201604001528201610628565b505f604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b0381168114610678575f80fd5b50565b5f806040838503121561068c575f80fd5b823561069781610664565b946020939093013593505050565b5f805f606084860312156106b7575f80fd5b83356106c281610664565b925060208401356106d281610664565b929592945050506040919091013590565b5f602082840312156106f3575f80fd5b81356106fe81610664565b9392505050565b5f8060408385031215610716575f80fd5b823561072181610664565b9150602083013561073181610664565b809150509250929050565b600181811c9082168061075057607f821691505b60208210810361076e57634e487b7160e01b5f52602260045260245ffd5b50919050565b5f60208284031215610784575f80fd5b81516106fe81610664565b808201808211156102ed57634e487b7160e01b5f52601160045260245ffdfea26469706673582212202deb7e03d8dd9600c1ee87a29e058ffb7b0887c3fb12a58cbb0951467a5bf44264736f6c63430008140033a2646970667358221220dfbf0e6236b3b0bfc3dc9ac09d61c3d49cec5e4d30a181dc0d851527e452fe9664736f6c63430008140033
Deployed Bytecode
0x608060405234801562000010575f80fd5b506004361062000038575f3560e01c8063a1f3f866146200003c578063daf9c2101462000070575b5f80fd5b620000536200004d36600462000202565b620000a6565b6040516001600160a01b0390911681526020015b60405180910390f35b620000956200008136600462000289565b5f6020819052908152604090205460ff1681565b604051901515815260200162000067565b5f8085858585604051620000ba906200014f565b620000c99493929190620002fd565b604051809103905ff080158015620000e3573d5f803e3d5ffd5b5090507f7af6222f62edab5fa312a46f086a615c44ec4627ed57fe8a35f5a7c536ba2d128187876040516200011b939291906200033e565b60405180910390a16001600160a01b0381165f908152602081905260409020805460ff191660011790559050949350505050565b610e1f806200038283390190565b634e487b7160e01b5f52604160045260245ffd5b5f82601f83011262000181575f80fd5b813567ffffffffffffffff808211156200019f576200019f6200015d565b604051601f8301601f19908116603f01168101908282118183101715620001ca57620001ca6200015d565b81604052838152866020858801011115620001e3575f80fd5b836020870160208301375f602085830101528094505050505092915050565b5f805f806080858703121562000216575f80fd5b843567ffffffffffffffff808211156200022e575f80fd5b6200023c8883890162000171565b9550602087013591508082111562000252575f80fd5b50620002618782880162000171565b93505060408501359150606085013580151581146200027e575f80fd5b939692955090935050565b5f602082840312156200029a575f80fd5b81356001600160a01b0381168114620002b1575f80fd5b9392505050565b5f81518084525f5b81811015620002de57602081850181015186830182015201620002c0565b505f602082860101526020601f19601f83011685010191505092915050565b608081525f620003116080830187620002b8565b8281036020840152620003258187620002b8565b6040840195909552505090151560609091015292915050565b6001600160a01b03841681526060602082018190525f906200036390830185620002b8565b8281036040840152620003778185620002b8565b969550505050505056fe6080604052600580546001600160a01b031916738679749e7bba02af1ee054ba30cdf18019f4960c17905534801562000036575f80fd5b5060405162000e1f38038062000e1f833981016040819052620000599162000300565b83838260036200006a848262000412565b50600462000079838262000412565b5060058054911515600160a01b0260ff60a01b1990921691909117905550620000c9905032620000a7601290565b620000b79060ff16600a620005e9565b620000c39085620005fd565b620000d3565b505050506200062d565b6001600160a01b038216620001025760405163ec442f0560e01b81525f60048201526024015b60405180910390fd5b6200010f5f838362000113565b5050565b6001600160a01b03831662000141578060025f82825462000135919062000617565b90915550620001b39050565b6001600160a01b0383165f9081526020819052604090205481811015620001955760405163391434e360e21b81526001600160a01b03851660048201526024810182905260448101839052606401620000f9565b6001600160a01b0384165f9081526020819052604090209082900390555b6001600160a01b038216620001d157600280548290039055620001ef565b6001600160a01b0382165f9081526020819052604090208054820190555b816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef836040516200023591815260200190565b60405180910390a3505050565b634e487b7160e01b5f52604160045260245ffd5b5f82601f83011262000266575f80fd5b81516001600160401b038082111562000283576200028362000242565b604051601f8301601f19908116603f01168101908282118183101715620002ae57620002ae62000242565b81604052838152602092508683858801011115620002ca575f80fd5b5f91505b83821015620002ed5785820183015181830184015290820190620002ce565b5f93810190920192909252949350505050565b5f805f806080858703121562000314575f80fd5b84516001600160401b03808211156200032b575f80fd5b620003398883890162000256565b955060208701519150808211156200034f575f80fd5b506200035e8782880162000256565b93505060408501519150606085015180151581146200037b575f80fd5b939692955090935050565b600181811c908216806200039b57607f821691505b602082108103620003ba57634e487b7160e01b5f52602260045260245ffd5b50919050565b601f8211156200040d575f81815260208120601f850160051c81016020861015620003e85750805b601f850160051c820191505b818110156200040957828155600101620003f4565b5050505b505050565b81516001600160401b038111156200042e576200042e62000242565b62000446816200043f845462000386565b84620003c0565b602080601f8311600181146200047c575f8415620004645750858301515b5f19600386901b1c1916600185901b17855562000409565b5f85815260208120601f198616915b82811015620004ac578886015182559484019460019091019084016200048b565b5085821015620004ca57878501515f19600388901b60f8161c191681555b5050505050600190811b01905550565b634e487b7160e01b5f52601160045260245ffd5b600181815b808511156200052e57815f1904821115620005125762000512620004da565b808516156200052057918102915b93841c9390800290620004f3565b509250929050565b5f826200054657506001620005e3565b816200055457505f620005e3565b81600181146200056d5760028114620005785762000598565b6001915050620005e3565b60ff8411156200058c576200058c620004da565b50506001821b620005e3565b5060208310610133831016604e8410600b8410161715620005bd575081810a620005e3565b620005c98383620004ee565b805f1904821115620005df57620005df620004da565b0290505b92915050565b5f620005f6838362000536565b9392505050565b8082028115828204841417620005e357620005e3620004da565b80820180821115620005e357620005e3620004da565b6107e4806200063b5f395ff3fe608060405234801561000f575f80fd5b506004361061009b575f3560e01c806370a082311161006357806370a0823114610114578063956b956a1461013c57806395d89b4114610150578063a9059cbb14610158578063dd62ed3e1461016b575f80fd5b806306fdde031461009f578063095ea7b3146100bd57806318160ddd146100e057806323b872dd146100f2578063313ce56714610105575b5f80fd5b6100a76101a3565b6040516100b49190610619565b60405180910390f35b6100d06100cb36600461067b565b610233565b60405190151581526020016100b4565b6002545b6040519081526020016100b4565b6100d06101003660046106a5565b6102f3565b604051601281526020016100b4565b6100e46101223660046106e3565b6001600160a01b03165f9081526020819052604090205490565b6005546100d090600160a01b900460ff1681565b6100a7610316565b6100d061016636600461067b565b610325565b6100e4610179366004610705565b6001600160a01b039182165f90815260016020908152604080832093909416825291909152205490565b6060600380546101b29061073c565b80601f01602080910402602001604051908101604052809291908181526020018280546101de9061073c565b80156102295780601f1061020057610100808354040283529160200191610229565b820191905f5260205f20905b81548152906001019060200180831161020c57829003601f168201915b5050505050905090565b6005545f90600160a01b900460ff1615156001036102db5760055f9054906101000a90046001600160a01b03166001600160a01b031663f887ea406040518163ffffffff1660e01b8152600401602060405180830381865afa15801561029b573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906102bf9190610774565b6001600160a01b0316836001600160a01b0316146102db575f80fd5b336102e7818585610332565b60019150505b92915050565b5f33610300858285610344565b61030b8585856103c4565b506001949350505050565b6060600480546101b29061073c565b5f336102e78185856103c4565b61033f8383836001610421565b505050565b6001600160a01b038381165f908152600160209081526040808320938616835292905220545f1981146103be57818110156103b057604051637dc7a0d960e11b81526001600160a01b038416600482015260248101829052604481018390526064015b60405180910390fd5b6103be84848484035f610421565b50505050565b6001600160a01b0383166103ed57604051634b637e8f60e11b81525f60048201526024016103a7565b6001600160a01b0382166104165760405163ec442f0560e01b81525f60048201526024016103a7565b61033f8383836104f3565b6001600160a01b03841661044a5760405163e602df0560e01b81525f60048201526024016103a7565b6001600160a01b03831661047357604051634a1406b160e11b81525f60048201526024016103a7565b6001600160a01b038085165f90815260016020908152604080832093871683529290522082905580156103be57826001600160a01b0316846001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925846040516104e591815260200190565b60405180910390a350505050565b6001600160a01b03831661051d578060025f828254610512919061078f565b9091555061058d9050565b6001600160a01b0383165f908152602081905260409020548181101561056f5760405163391434e360e21b81526001600160a01b038516600482015260248101829052604481018390526064016103a7565b6001600160a01b0384165f9081526020819052604090209082900390555b6001600160a01b0382166105a9576002805482900390556105c7565b6001600160a01b0382165f9081526020819052604090208054820190555b816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8360405161060c91815260200190565b60405180910390a3505050565b5f6020808352835180828501525f5b8181101561064457858101830151858201604001528201610628565b505f604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b0381168114610678575f80fd5b50565b5f806040838503121561068c575f80fd5b823561069781610664565b946020939093013593505050565b5f805f606084860312156106b7575f80fd5b83356106c281610664565b925060208401356106d281610664565b929592945050506040919091013590565b5f602082840312156106f3575f80fd5b81356106fe81610664565b9392505050565b5f8060408385031215610716575f80fd5b823561072181610664565b9150602083013561073181610664565b809150509250929050565b600181811c9082168061075057607f821691505b60208210810361076e57634e487b7160e01b5f52602260045260245ffd5b50919050565b5f60208284031215610784575f80fd5b81516106fe81610664565b808201808211156102ed57634e487b7160e01b5f52601160045260245ffdfea26469706673582212202deb7e03d8dd9600c1ee87a29e058ffb7b0887c3fb12a58cbb0951467a5bf44264736f6c63430008140033a2646970667358221220dfbf0e6236b3b0bfc3dc9ac09d61c3d49cec5e4d30a181dc0d851527e452fe9664736f6c63430008140033
Deployed Bytecode Sourcemap
17199:545:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;17369:372;;;;;;:::i;:::-;;:::i;:::-;;;-1:-1:-1;;;;;1812:32:1;;;1794:51;;1782:2;1767:18;17369:372:0;;;;;;;;17311:49;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;2312:14:1;;2305:22;2287:41;;2275:2;2260:18;17311:49:0;2147:187:1;17369:372:0;17476:7;17496:15;17524:4;17530:6;17538;17546:9;17514:42;;;;;:::i;:::-;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;17496:60;;17582:50;17607:9;17619:4;17625:6;17582:50;;;;;;;;:::i;:::-;;;;;;;;-1:-1:-1;;;;;17653:37:0;;:17;:37;;;;;;;;;;:44;;-1:-1:-1;;17653:44:0;17693:4;17653:44;;;17679:9;-1:-1:-1;17369:372:0;;;;;;:::o;-1:-1:-1:-;;;;;;;;:::o;14:127:1:-;75:10;70:3;66:20;63:1;56:31;106:4;103:1;96:15;130:4;127:1;120:15;146:719;189:5;242:3;235:4;227:6;223:17;219:27;209:55;;260:1;257;250:12;209:55;296:6;283:20;322:18;359:2;355;352:10;349:36;;;365:18;;:::i;:::-;440:2;434:9;408:2;494:13;;-1:-1:-1;;490:22:1;;;514:2;486:31;482:40;470:53;;;538:18;;;558:22;;;535:46;532:72;;;584:18;;:::i;:::-;624:10;620:2;613:22;659:2;651:6;644:18;705:3;698:4;693:2;685:6;681:15;677:26;674:35;671:55;;;722:1;719;712:12;671:55;786:2;779:4;771:6;767:17;760:4;752:6;748:17;735:54;833:1;826:4;821:2;813:6;809:15;805:26;798:37;853:6;844:15;;;;;;146:719;;;;:::o;870:773::-;973:6;981;989;997;1050:3;1038:9;1029:7;1025:23;1021:33;1018:53;;;1067:1;1064;1057:12;1018:53;1107:9;1094:23;1136:18;1177:2;1169:6;1166:14;1163:34;;;1193:1;1190;1183:12;1163:34;1216:50;1258:7;1249:6;1238:9;1234:22;1216:50;:::i;:::-;1206:60;;1319:2;1308:9;1304:18;1291:32;1275:48;;1348:2;1338:8;1335:16;1332:36;;;1364:1;1361;1354:12;1332:36;;1387:52;1431:7;1420:8;1409:9;1405:24;1387:52;:::i;:::-;1377:62;;;1486:2;1475:9;1471:18;1458:32;1448:42;;1540:2;1529:9;1525:18;1512:32;1587:5;1580:13;1573:21;1566:5;1563:32;1553:60;;1609:1;1606;1599:12;1553:60;870:773;;;;-1:-1:-1;870:773:1;;-1:-1:-1;;870:773:1:o;1856:286::-;1915:6;1968:2;1956:9;1947:7;1943:23;1939:32;1936:52;;;1984:1;1981;1974:12;1936:52;2010:23;;-1:-1:-1;;;;;2062:31:1;;2052:42;;2042:70;;2108:1;2105;2098:12;2042:70;2131:5;1856:286;-1:-1:-1;;;1856:286:1:o;2339:423::-;2381:3;2419:5;2413:12;2446:6;2441:3;2434:19;2471:1;2481:162;2495:6;2492:1;2489:13;2481:162;;;2557:4;2613:13;;;2609:22;;2603:29;2585:11;;;2581:20;;2574:59;2510:12;2481:162;;;2485:3;2688:1;2681:4;2672:6;2667:3;2663:16;2659:27;2652:38;2751:4;2744:2;2740:7;2735:2;2727:6;2723:15;2719:29;2714:3;2710:39;2706:50;2699:57;;;2339:423;;;;:::o;2767:537::-;3014:3;3003:9;2996:22;2977:4;3041:46;3082:3;3071:9;3067:19;3059:6;3041:46;:::i;:::-;3135:9;3127:6;3123:22;3118:2;3107:9;3103:18;3096:50;3163:33;3189:6;3181;3163:33;:::i;:::-;3227:2;3212:18;;3205:34;;;;-1:-1:-1;;3282:14:1;;3275:22;3270:2;3255:18;;;3248:50;3155:41;2767:537;-1:-1:-1;;2767:537:1:o;3309:480::-;-1:-1:-1;;;;;3534:32:1;;3516:51;;3603:2;3598;3583:18;;3576:30;;;-1:-1:-1;;3629:45:1;;3655:18;;3647:6;3629:45;:::i;:::-;3722:9;3714:6;3710:22;3705:2;3694:9;3690:18;3683:50;3750:33;3776:6;3768;3750:33;:::i;:::-;3742:41;3309:480;-1:-1:-1;;;;;;3309:480:1:o
Swarm Source
ipfs://dfbf0e6236b3b0bfc3dc9ac09d61c3d49cec5e4d30a181dc0d851527e452fe96
Loading...
Loading
Loading...
Loading
Multichain Portfolio | 31 Chains
Chain | Token | Portfolio % | Price | Amount | Value |
---|
A contract address hosts a smart contract, which is a set of code stored on the blockchain that runs when predetermined conditions are met. Learn more about addresses in our Knowledge Base.