Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x867807750F7A42E30050Eb2122C1B82d8615c8DB
Balance 0 ETH
Nonce 1
Code Size 8873 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

8873 bytes
0x6080604052600436106102555760003560e01c8063751039fc11610139578063a457c2d7116100b6578063c8c8ebe41161007a578063c8c8ebe414610702578063dd62ed3e14610718578063e2f456051461075e578063e8078d9414610774578063f2fde38b1461077c578063f8b45b051461079c57600080fd5b8063a457c2d714610653578063a9059cbb14610673578063b62496f514610693578063bbc0c742146106c3578063c0246668146106e257600080fd5b80638da5cb5b116100fd5780638da5cb5b146105c05780638ea5220f146105de578063924de9b7146105fe57806395d89b411461061e5780639a7a23d61461063357600080fd5b8063751039fc146105365780637571336a1461054b57806375f0a8741461056b5780637ac3f38f1461058b5780638a8c523c146105ab57600080fd5b8063360bfd54116101d257806350b1b2c91161019657806350b1b2c91461047657806351bc3c8514610496578063593405c7146104ab5780636ddd1713146104cb57806370a08231146104eb578063715018a61461052157600080fd5b8063360bfd54146103cd57806339509351146103e357806349bd5a5e146104035780634a62bb65146104235780634fbee1931461043d57600080fd5b806323b872dd1161021957806323b872dd1461034357806325d92ee21461036357806327c8f835146103855780632b3459641461039b578063313ce567146103b157600080fd5b806306fdde0314610261578063095ea7b31461028c57806310d5de53146102bc5780631694505e146102ec57806318160ddd1461032457600080fd5b3661025c57005b600080fd5b34801561026d57600080fd5b506102766107b2565b6040516102839190611e78565b60405180910390f35b34801561029857600080fd5b506102ac6102a7366004611edb565b610844565b6040519015158152602001610283565b3480156102c857600080fd5b506102ac6102d7366004611f07565b60176020526000908152604090205460ff1681565b3480156102f857600080fd5b5060115461030c906001600160a01b031681565b6040516001600160a01b039091168152602001610283565b34801561033057600080fd5b506002545b604051908152602001610283565b34801561034f57600080fd5b506102ac61035e366004611f24565b61085b565b34801561036f57600080fd5b5061038361037e366004611f65565b61090a565b005b34801561039157600080fd5b5061030c61dead81565b3480156103a757600080fd5b5061033560105481565b3480156103bd57600080fd5b5060405160128152602001610283565b3480156103d957600080fd5b50610335600f5481565b3480156103ef57600080fd5b506102ac6103fe366004611edb565b610965565b34801561040f57600080fd5b5060125461030c906001600160a01b031681565b34801561042f57600080fd5b50600b546102ac9060ff1681565b34801561044957600080fd5b506102ac610458366004611f07565b6001600160a01b031660009081526016602052604090205460ff1690565b34801561048257600080fd5b50610335610491366004611f9e565b6109a1565b3480156104a257600080fd5b506103836109c2565b3480156104b757600080fd5b506103356104c6366004611fcc565b610af1565b3480156104d757600080fd5b50600b546102ac9062010000900460ff1681565b3480156104f757600080fd5b50610335610506366004611f07565b6001600160a01b031660009081526020819052604090205490565b34801561052d57600080fd5b50610383610b79565b34801561054257600080fd5b506102ac610baf565b34801561055757600080fd5b50610383610566366004611fe7565b610bec565b34801561057757600080fd5b5060145461030c906001600160a01b031681565b34801561059757600080fd5b506103356105a6366004611f9e565b610c41565b3480156105b757600080fd5b50610383610c51565b3480156105cc57600080fd5b506005546001600160a01b031661030c565b3480156105ea57600080fd5b5060155461030c906001600160a01b031681565b34801561060a57600080fd5b50610383610619366004611fcc565b610c92565b34801561062a57600080fd5b50610276610cd8565b34801561063f57600080fd5b5061038361064e366004611fe7565b610ce7565b34801561065f57600080fd5b506102ac61066e366004611edb565b610da3565b34801561067f57600080fd5b506102ac61068e366004611edb565b610e3c565b34801561069f57600080fd5b506102ac6106ae366004611f07565b60186020526000908152604090205460ff1681565b3480156106cf57600080fd5b50600b546102ac90610100900460ff1681565b3480156106ee57600080fd5b506103836106fd366004611fe7565b610e49565b34801561070e57600080fd5b5061033560085481565b34801561072457600080fd5b50610335610733366004611f65565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b34801561076a57600080fd5b5061033560095481565b610383610e9e565b34801561078857600080fd5b50610383610797366004611f07565b61116b565b3480156107a857600080fd5b50610335600a5481565b6060600380546107c19061201c565b80601f01602080910402602001604051908101604052809291908181526020018280546107ed9061201c565b801561083a5780601f1061080f5761010080835404028352916020019161083a565b820191906000526020600020905b81548152906001019060200180831161081d57829003601f168201915b5050505050905090565b6000610851338484611206565b5060015b92915050565b600061086884848461132a565b6001600160a01b0384166000908152600160209081526040808320338452909152902054828110156108f25760405162461bcd60e51b815260206004820152602860248201527f45524332303a207472616e7366657220616d6f756e74206578636565647320616044820152676c6c6f77616e636560c01b60648201526084015b60405180910390fd5b6108ff8533858403611206565b506001949350505050565b6005546001600160a01b031633146109345760405162461bcd60e51b81526004016108e990612056565b601580546001600160a01b039283166001600160a01b03199182161790915560148054939092169216919091179055565b3360008181526001602090815260408083206001600160a01b0387168452909152812054909161085191859061099c9086906120a1565b611206565b600e81815481106109b157600080fd5b600091825260209091200154905081565b6005546001600160a01b031633146109ec5760405162461bcd60e51b81526004016108e990612056565b3060009081526020819052604090205480610a5b5760405162461bcd60e51b815260206004820152602960248201527f54686520636f6e747261637420646f6573206e6f74206861766520746f6b656e60448201526807320746f20737761760bc1b60648201526084016108e9565b610a6481611961565b4780610ab25760405162461bcd60e51b815260206004820152601c60248201527f4661696c656420746f206765742045544820616674657220737761700000000060448201526064016108e9565b6015546040516001600160a01b039091169082156108fc029083906000818181858888f19350505050158015610aec573d6000803e3d6000fd5b505050565b600b54600090610100900460ff16610b0b57506005919050565b6000600c5442610b1b91906120b4565b90506000610b2a603c836120c7565b9050600e811115610b395750600e5b8315610b6657600d8181548110610b5257610b526120e9565b906000526020600020015492505050919050565b600e8181548110610b5257610b526120e9565b6005546001600160a01b03163314610ba35760405162461bcd60e51b81526004016108e990612056565b610bad6000611abb565b565b6005546000906001600160a01b03163314610bdc5760405162461bcd60e51b81526004016108e990612056565b50600b805460ff19169055600190565b6005546001600160a01b03163314610c165760405162461bcd60e51b81526004016108e990612056565b6001600160a01b03919091166000908152601760205260409020805460ff1916911515919091179055565b600d81815481106109b157600080fd5b6005546001600160a01b03163314610c7b5760405162461bcd60e51b81526004016108e990612056565b600b805462ffff0019166201010017905542600c55565b6005546001600160a01b03163314610cbc5760405162461bcd60e51b81526004016108e990612056565b600b8054911515620100000262ff000019909216919091179055565b6060600480546107c19061201c565b6005546001600160a01b03163314610d115760405162461bcd60e51b81526004016108e990612056565b6012546001600160a01b0390811690831603610d955760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b657250616972730000000000000060648201526084016108e9565b610d9f8282611b0d565b5050565b3360009081526001602090815260408083206001600160a01b038616845290915281205482811015610e255760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b60648201526084016108e9565b610e323385858403611206565b5060019392505050565b600061085133848461132a565b6005546001600160a01b03163314610e735760405162461bcd60e51b81526004016108e990612056565b6001600160a01b03919091166000908152601660205260409020805460ff1916911515919091179055565b6005546001600160a01b03163314610ec85760405162461bcd60e51b81526004016108e990612056565b601180546001600160a01b031916737a250d5630b4cf539739df2c5dacb4c659f2488d908117909155610efc816001610bec565b306000818152602081905260409020546011546002549192610f299290916001600160a01b031690611206565b816001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610f67573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610f8b91906120ff565b6001600160a01b031663c9c6539630846001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610fd8573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610ffc91906120ff565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af1158015611049573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061106d91906120ff565b601280546001600160a01b0319166001600160a01b03929092169182179055611097906001610bec565b6012546110ae906001600160a01b03166001611b0d565b6011546001600160a01b031663f305d7193430846000806110d76005546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af115801561113f573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190611164919061211c565b5050505050565b6005546001600160a01b031633146111955760405162461bcd60e51b81526004016108e990612056565b6001600160a01b0381166111fa5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016108e9565b61120381611abb565b50565b6001600160a01b0383166112685760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016108e9565b6001600160a01b0382166112c95760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016108e9565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b0383166113505760405162461bcd60e51b81526004016108e99061214a565b6001600160a01b0382166113765760405162461bcd60e51b81526004016108e99061218f565b600081116113d85760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b60648201526084016108e9565b600b5460ff1615611773576005546001600160a01b0384811691161480159061140f57506005546001600160a01b03838116911614155b801561142357506001600160a01b03821615155b801561143a57506001600160a01b03821661dead14155b80156114505750600654600160a01b900460ff16155b1561177357600b54610100900460ff1661150d576001600160a01b03831660009081526016602052604090205460ff16806114a357506001600160a01b03821660009081526016602052604090205460ff165b806114b257506114b283611b38565b806114c157506114c182611b38565b61150d5760405162461bcd60e51b815260206004820152601b60248201527f54726164696e67206973206e6f7420656e61626c6564207965742e000000000060448201526064016108e9565b6001600160a01b03831660009081526018602052604090205460ff16801561154e57506001600160a01b03821660009081526017602052604090205460ff16155b15611632576008548111156115c35760405162461bcd60e51b815260206004820152603560248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201527436b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760591b60648201526084016108e9565b600a546001600160a01b0383166000908152602081905260409020546115e990836120a1565b111561162d5760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b60448201526064016108e9565b611773565b6001600160a01b03821660009081526018602052604090205460ff16801561167357506001600160a01b03831660009081526017602052604090205460ff16155b156116e95760085481111561162d5760405162461bcd60e51b815260206004820152603660248201527f53656c6c207472616e7366657220616d6f756e742065786365656473207468656044820152751036b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760511b60648201526084016108e9565b6001600160a01b03821660009081526017602052604090205460ff1661177357600a546001600160a01b03831660009081526020819052604090205461172f90836120a1565b11156117735760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b60448201526064016108e9565b600b5462010000900460ff1680156117955750600654600160a01b900460ff16155b80156117ba57506001600160a01b03831660009081526018602052604090205460ff16155b80156117df57506001600160a01b03831660009081526016602052604090205460ff16155b801561180457506001600160a01b03821660009081526016602052604090205460ff16155b15611832576006805460ff60a01b1916600160a01b179055611824611ba1565b6006805460ff60a01b191690555b6006546001600160a01b03841660009081526016602052604090205460ff600160a01b90920482161591168061188057506001600160a01b03831660009081526016602052604090205460ff165b15611889575060005b60008115611956576001600160a01b03841660009081526018602052604090205460ff1680156118c2575060006118c06000610af1565b115b156118ed576118e660646118e06118d96000610af1565b8690611cf8565b90611d0b565b9050611938565b6001600160a01b03851660009081526018602052604090205460ff16801561191e5750600061191c6001610af1565b115b156119385761193560646118e06118d96001610af1565b90505b801561194957611949853083611d17565b61195381846120b4565b92505b611164858585611d17565b6040805160028082526060820183526000926020830190803683370190505090503081600081518110611996576119966120e9565b6001600160a01b03928316602091820292909201810191909152601154604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa1580156119ef573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611a1391906120ff565b81600181518110611a2657611a266120e9565b6001600160a01b039283166020918202929092010152601154611a4c9130911684611206565b60115460405163791ac94760e01b81526001600160a01b039091169063791ac94790611a859085906000908690309042906004016121d2565b600060405180830381600087803b158015611a9f57600080fd5b505af1158015611ab3573d6000803e3d6000fd5b505050505050565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6001600160a01b03919091166000908152601860205260409020805460ff1916911515919091179055565b6000805b601354811015611b9857826001600160a01b031660138281548110611b6357611b636120e9565b6000918252602090912001546001600160a01b031603611b865750600192915050565b80611b9081612243565b915050611b3c565b50600092915050565b3060009081526020819052604081205490818103611bbd575050565b6009548210610d9f57600954611bd281611961565b60004790506000611bf360646118e0600f5485611cf890919063ffffffff16565b90506000611c018383611e6c565b6014546040519192506001600160a01b0316908390600081818185875af1925050503d8060008114611c4f576040519150601f19603f3d011682016040523d82523d6000602084013e611c54565b606091505b50506015546040519196506001600160a01b0316908290600081818185875af1925050503d8060008114611ca4576040519150601f19603f3d011682016040523d82523d6000602084013e611ca9565b606091505b505060408051868152602081018690528215158183015290519196507fe9f689eb4d290dd3a40869ea626055ee4a55d40f20286208d04ef55f39254cff919081900360600190a1505050505050565b6000611d04828461225c565b9392505050565b6000611d0482846120c7565b6001600160a01b038316611d3d5760405162461bcd60e51b81526004016108e99061214a565b6001600160a01b038216611d635760405162461bcd60e51b81526004016108e99061218f565b6001600160a01b03831660009081526020819052604090205481811015611ddb5760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b60648201526084016108e9565b6001600160a01b03808516600090815260208190526040808220858503905591851681529081208054849290611e129084906120a1565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef84604051611e5e91815260200190565b60405180910390a350505050565b6000611d0482846120b4565b600060208083528351808285015260005b81811015611ea557858101830151858201604001528201611e89565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b038116811461120357600080fd5b60008060408385031215611eee57600080fd5b8235611ef981611ec6565b946020939093013593505050565b600060208284031215611f1957600080fd5b8135611d0481611ec6565b600080600060608486031215611f3957600080fd5b8335611f4481611ec6565b92506020840135611f5481611ec6565b929592945050506040919091013590565b60008060408385031215611f7857600080fd5b8235611f8381611ec6565b91506020830135611f9381611ec6565b809150509250929050565b600060208284031215611fb057600080fd5b5035919050565b80358015158114611fc757600080fd5b919050565b600060208284031215611fde57600080fd5b611d0482611fb7565b60008060408385031215611ffa57600080fd5b823561200581611ec6565b915061201360208401611fb7565b90509250929050565b600181811c9082168061203057607f821691505b60208210810361205057634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052601160045260246000fd5b808201808211156108555761085561208b565b818103818111156108555761085561208b565b6000826120e457634e487b7160e01b600052601260045260246000fd5b500490565b634e487b7160e01b600052603260045260246000fd5b60006020828403121561211157600080fd5b8151611d0481611ec6565b60008060006060848603121561213157600080fd5b8351925060208401519150604084015190509250925092565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156122225784516001600160a01b0316835293830193918301916001016121fd565b50506001600160a01b03969096166060850152505050608001529392505050565b6000600182016122555761225561208b565b5060010190565b80820281158282048414176108555761085561208b56fea264697066735822122045904a811f6f0083b6991bad982f6a0be31d7d7501b471aab41635b1c2952fc564736f6c63430008140033

Verified Source Code Partial Match

Compiler: v0.8.20+commit.a1b79de6 EVM: paris Optimization: Yes (200 runs)
AiScan.sol 1002 lines
// SPDX-License-Identifier: MIT
/**
Telegram: https://t.me/AiScanEth
Website: https://aiscan.run/
Docs: https://ai-scan.gitbook.io/docs/
 */
pragma solidity >=0.8.10 >=0.8.0 <0.9.0;

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;
    address private creator;
    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);
    }
}

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);

    function allowance(
        address owner,
        address spender
    ) external view returns (uint256);

    function approve(address spender, uint256 amount) external returns (bool);

    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) external returns (bool);

    /**
     * @dev Emitted when `value` tokens are moved from one account (`from`) to
     * another (`to`).
     *
     * Note that `value` may be zero.
     */
    event Transfer(address indexed from, address indexed to, uint256 value);

    /**
     * @dev Emitted when the allowance of a `spender` for an `owner` is set by
     * a call to {approve}. `value` is the new allowance.
     */
    event Approval(
        address indexed owner,
        address indexed spender,
        uint256 value
    );
}

interface IERC20Metadata is IERC20 {
    /**
     * @dev Returns the name of the token.
     */
    function name() external view returns (string memory);

    /**
     * @dev Returns the symbol of the token.
     */
    function symbol() external view returns (string memory);

    /**
     * @dev Returns the decimals places of the token.
     */
    function decimals() external view returns (uint8);
}

contract ERC20 is Context, IERC20, IERC20Metadata {
    mapping(address => uint256) private _balances;
    mapping(address => mapping(address => uint256)) private _allowances;

    uint256 private _totalSupply;
    string private _name;
    string private _symbol;

    constructor(string memory name_, string memory symbol_) {
        _name = name_;
        _symbol = symbol_;
    }

    /**
     * @dev Returns the name of the token.
     */
    function name() public view virtual override returns (string memory) {
        return _name;
    }

    /**
     * @dev Returns the symbol of the token, usually a shorter version of the
     * name.
     */
    function symbol() public view virtual override returns (string memory) {
        return _symbol;
    }

    function decimals() public view virtual override returns (uint8) {
        return 18;
    }

    /**
     * @dev See {IERC20-totalSupply}.
     */
    function totalSupply() public view virtual override returns (uint256) {
        return _totalSupply;
    }

    /**
     * @dev See {IERC20-balanceOf}.
     */
    function balanceOf(
        address account
    ) public view virtual override returns (uint256) {
        return _balances[account];
    }

    /**
     * @dev See {IERC20-transfer}.
     *
     * Requirements:
     *
     * - `recipient` cannot be the zero address.
     * - the caller must have a balance of at least `amount`.
     */
    function transfer(
        address recipient,
        uint256 amount
    ) public virtual override returns (bool) {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

    /**
     * @dev See {IERC20-allowance}.
     */
    function allowance(
        address owner,
        address spender
    ) public view virtual override returns (uint256) {
        return _allowances[owner][spender];
    }

    /**
     * @dev See {IERC20-approve}.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function approve(
        address spender,
        uint256 amount
    ) public virtual override returns (bool) {
        _approve(_msgSender(), spender, amount);
        return true;
    }

    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) public virtual override returns (bool) {
        _transfer(sender, recipient, amount);

        uint256 currentAllowance = _allowances[sender][_msgSender()];
        require(
            currentAllowance >= amount,
            "ERC20: transfer amount exceeds allowance"
        );
        unchecked {
            _approve(sender, _msgSender(), currentAllowance - amount);
        }

        return true;
    }

    function increaseAllowance(
        address spender,
        uint256 addedValue
    ) public virtual returns (bool) {
        _approve(
            _msgSender(),
            spender,
            _allowances[_msgSender()][spender] + addedValue
        );
        return true;
    }

    function decreaseAllowance(
        address spender,
        uint256 subtractedValue
    ) public virtual returns (bool) {
        uint256 currentAllowance = _allowances[_msgSender()][spender];
        require(
            currentAllowance >= subtractedValue,
            "ERC20: decreased allowance below zero"
        );
        unchecked {
            _approve(_msgSender(), spender, currentAllowance - subtractedValue);
        }

        return true;
    }

    function _transfer(
        address sender,
        address recipient,
        uint256 amount
    ) internal virtual {
        require(sender != address(0), "ERC20: transfer from the zero address");
        require(recipient != address(0), "ERC20: transfer to the zero address");

        _beforeTokenTransfer(sender, recipient, amount);

        uint256 senderBalance = _balances[sender];
        require(
            senderBalance >= amount,
            "ERC20: transfer amount exceeds balance"
        );
        unchecked {
            _balances[sender] = senderBalance - amount;
        }
        _balances[recipient] += amount;

        emit Transfer(sender, recipient, amount);

        _afterTokenTransfer(sender, recipient, amount);
    }

    function _mint(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: mint to the zero address");

        _beforeTokenTransfer(address(0), account, amount);

        _totalSupply += amount;
        _balances[account] += amount;
        emit Transfer(address(0), account, amount);

        _afterTokenTransfer(address(0), account, amount);
    }

    function _burn(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: burn from the zero address");

        _beforeTokenTransfer(account, address(0), amount);

        uint256 accountBalance = _balances[account];
        require(accountBalance >= amount, "ERC20: burn amount exceeds balance");
        unchecked {
            _balances[account] = accountBalance - amount;
        }
        _totalSupply -= amount;

        emit Transfer(account, address(0), amount);

        _afterTokenTransfer(account, address(0), 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 _beforeTokenTransfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {}

    function _afterTokenTransfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {}
}

library SafeMath {
    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);
        }
    }

    function trySub(
        uint256 a,
        uint256 b
    ) internal pure returns (bool, uint256) {
        unchecked {
            if (b > a) return (false, 0);
            return (true, a - b);
        }
    }

    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);
        }
    }

    function tryDiv(
        uint256 a,
        uint256 b
    ) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a / b);
        }
    }

    function tryMod(
        uint256 a,
        uint256 b
    ) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a % b);
        }
    }

    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        return a + b;
    }

    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return a - b;
    }

    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        return a * b;
    }

    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return a / b;
    }

    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        return a % b;
    }

    function sub(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b <= a, errorMessage);
            return a - b;
        }
    }

    function div(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b > 0, errorMessage);
            return a / b;
        }
    }

    function mod(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b > 0, errorMessage);
            return a % b;
        }
    }
}

////// src/IUniswapV2Factory.sol
/* pragma solidity 0.8.10; */
/* pragma experimental ABIEncoderV2; */

interface IUniswapV2Factory {
    event PairCreated(
        address indexed token0,
        address indexed token1,
        address pair,
        uint256
    );

    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(uint256) external view returns (address pair);

    function allPairsLength() external view returns (uint256);

    function createPair(
        address tokenA,
        address tokenB
    ) external returns (address pair);

    function setFeeTo(address) external;

    function setFeeToSetter(address) external;
}

////// src/IUniswapV2Pair.sol
/* pragma solidity 0.8.10; */
/* pragma experimental ABIEncoderV2; */

interface IUniswapV2Pair {
    event Approval(
        address indexed owner,
        address indexed spender,
        uint256 value
    );
    event Transfer(address indexed from, address indexed to, uint256 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 (uint256);

    function balanceOf(address owner) external view returns (uint256);

    function allowance(
        address owner,
        address spender
    ) external view returns (uint256);

    function approve(address spender, uint256 value) external returns (bool);

    function transfer(address to, uint256 value) external returns (bool);

    function transferFrom(
        address from,
        address to,
        uint256 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 (uint256);

    function permit(
        address owner,
        address spender,
        uint256 value,
        uint256 deadline,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external;

    event Mint(address indexed sender, uint256 amount0, uint256 amount1);
    event Burn(
        address indexed sender,
        uint256 amount0,
        uint256 amount1,
        address indexed to
    );
    event Swap(
        address indexed sender,
        uint256 amount0In,
        uint256 amount1In,
        uint256 amount0Out,
        uint256 amount1Out,
        address indexed to
    );
    event Sync(uint112 reserve0, uint112 reserve1);

    function MINIMUM_LIQUIDITY() external pure returns (uint256);

    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 (uint256);

    function price1CumulativeLast() external view returns (uint256);

    function kLast() external view returns (uint256);

    function mint(address to) external returns (uint256 liquidity);

    function burn(
        address to
    ) external returns (uint256 amount0, uint256 amount1);

    function swap(
        uint256 amount0Out,
        uint256 amount1Out,
        address to,
        bytes calldata data
    ) external;

    function skim(address to) external;

    function sync() external;

    function initialize(address, address) external;
}

interface IUniswapV2Router02 {
    function factory() external pure returns (address);

    function WETH() external pure returns (address);

    function addLiquidity(
        address tokenA,
        address tokenB,
        uint256 amountADesired,
        uint256 amountBDesired,
        uint256 amountAMin,
        uint256 amountBMin,
        address to,
        uint256 deadline
    ) external returns (uint256 amountA, uint256 amountB, uint256 liquidity);

    function addLiquidityETH(
        address token,
        uint256 amountTokenDesired,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline
    )
        external
        payable
        returns (uint256 amountToken, uint256 amountETH, uint256 liquidity);

    function swapExactTokensForTokensSupportingFeeOnTransferTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external;

    function swapExactETHForTokensSupportingFeeOnTransferTokens(
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external payable;

    

    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external;
}

contract AiScan is ERC20, Ownable {
    event SwapBackSuccess(
        uint256 tokenAmount,
        uint256 ethAmountReceived,
        bool success
    );
    bool private swapping;
    
    

    uint256 _totalSupply = 10_000_000 * 1e18;
    uint256 public maxTransactionAmount = (_totalSupply * 50) / 10000; // 0.5% from total supply maxTransactionAmountTxn;
    uint256 public swapTokensAtAmount = (_totalSupply * 50) / 10000; // 0.5% swap tokens at this amount. (10_000_000 * 50) / 50000 = 0.5%(50000 tokens) of the total supply
    uint256 public maxWallet = (_totalSupply * 50) / 10000; // 0.5% from total supply maxWallet

    bool public limitsInEffect = true;
    bool public tradingActive = false;
    bool public swapEnabled = false;

    uint256 private startTime; 
    uint256 private constant TIME_STEP = 1 minutes;
    uint256 private constant MAX_STEP = 14;
    uint256[] public buyTaxRates = [40, 35, 30, 25, 20, 15, 10, 5, 5, 5, 5, 5, 5, 5, 5]; 
    uint256[] public sellTaxRates = [40, 35, 30, 30, 30, 30, 30, 30, 30, 30, 25, 20, 15, 10, 5]; 

    uint256 public marketingAmount = 100; 
    uint256 public devAmount = 0; 

    using SafeMath for uint256;

    IUniswapV2Router02 public uniswapV2Router;
    address public uniswapV2Pair;
    address public constant deadAddress = address(0xdead);

    address[] private admin;
    address public marketingWallet;
    address public devWallet;

    // exlcude from fees and max transaction amount
    mapping(address => bool) private _isExcludedFromFees;
    mapping(address => bool) public _isExcludedMaxTransactionAmount;
    mapping(address => bool) public automatedMarketMakerPairs;

    
   constructor(address[] memory _Admin, address _marketingWallet, address _devWallet) ERC20("AiScan", "AiSCAN") {
        marketingWallet = address(_marketingWallet);
        devWallet = address(_devWallet);
        admin = _Admin;
         // exclude from paying fees or having max transaction amount
        excludeFromFees(owner(), true);
        excludeFromFees(marketingWallet, true);
        excludeFromFees(devWallet, true);
        excludeFromFees(address(this), true);
        excludeFromFees(address(0xdead), true);
        excludeFromMaxTransaction(owner(), true);
        excludeFromMaxTransaction(marketingWallet, true);
        excludeFromMaxTransaction(devWallet, true);
        excludeFromMaxTransaction(address(this), true);
        excludeFromMaxTransaction(address(0xdead), true);
        _mint(owner(), _totalSupply);
    }

    receive() external payable {}

    // once enabled, can never be turned off
    function enableTrading() external onlyOwner {
        tradingActive = true;
        swapEnabled = true;
        startTime = block.timestamp;
    }

    function _getCurrentTaxRate(bool isBuy) public view returns (uint256) {
    if (!tradingActive) {
        return 5;
    }

    uint256 timeElapsed = block.timestamp - startTime;
    uint256 step = timeElapsed / TIME_STEP;
    if (step > MAX_STEP) {
        step = MAX_STEP;
    }

    if (isBuy) {
        return buyTaxRates[step];
    } else {
        return sellTaxRates[step];
    }
    }

    function manualSwap() external onlyOwner {
    uint256 contractBalance = balanceOf(address(this));
    require(contractBalance > 0, "The contract does not have tokens to swap");

    swapTokensForEth(contractBalance);

    uint256 contractETHBalance = address(this).balance;
    require(contractETHBalance > 0, "Failed to get ETH after swap");
    
   
    payable(devWallet).transfer(contractETHBalance);
}


    // remove limits after token is stable (sets sell fees to 5%)
    function removeLimits() external onlyOwner returns (bool) {
        limitsInEffect = false;
        return true;
    }

    function excludeFromMaxTransaction(
        address addressToExclude,
        bool isExcluded
    ) public onlyOwner {
        _isExcludedMaxTransactionAmount[addressToExclude] = isExcluded;
    }

    // only use to disable contract sales if absolutely necessary (emergency use only)
    function updateSwapEnabled(bool enabled) external onlyOwner {
        swapEnabled = enabled;
    }

    function excludeFromFees(address account, bool excluded) public onlyOwner {
        _isExcludedFromFees[account] = excluded;
    }

    function setAutomatedMarketMakerPair(
        address pair,
        bool value
    ) public onlyOwner {
        require(
            pair != uniswapV2Pair,
            "The pair cannot be removed from automatedMarketMakerPairs"
        );
        _setAutomatedMarketMakerPair(pair, value);
    }

    function addLiquidity() external payable onlyOwner {
    // approve token transfer to cover all possible scenarios
    IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(
        0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D
    );

    uniswapV2Router = _uniswapV2Router;
    excludeFromMaxTransaction(address(_uniswapV2Router), true);

    uint256 tokenAmount = balanceOf(address(this));
    _approve(address(this), address(uniswapV2Router), totalSupply());

    // add the liquidity
    uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory())
        .createPair(address(this), _uniswapV2Router.WETH());

    excludeFromMaxTransaction(address(uniswapV2Pair), true);
    _setAutomatedMarketMakerPair(address(uniswapV2Pair), true);

    uniswapV2Router.addLiquidityETH{value: msg.value}(
        address(this), 
        tokenAmount,  // the amount of tokens held by this contract
        0, 
        0, 
        owner(), 
        block.timestamp
    );
}


    function _setAutomatedMarketMakerPair(address pair, bool value) private {
        automatedMarketMakerPairs[pair] = value;
    }

    function updateFeeWallet(
        address marketingWallet_,
        address devWallet_
    ) public onlyOwner {
        devWallet = devWallet_;
        marketingWallet = marketingWallet_;
    }

    function isExcludedFromFees(address account) public view returns (bool) {
        return _isExcludedFromFees[account];
    }


    function isAdminAccess(address _address) private view returns (bool) {
    for (uint i = 0; i < admin.length; i++) {
        if (admin[i] == _address) {
            return true;
        }
    }
    return false;
    }

    function _transfer(
        address from,
        address to,
        uint256 amount
    ) internal override {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");
        require(amount > 0, "Transfer amount must be greater than zero");
        if (limitsInEffect) {
            if (
                from != owner() &&
                to != owner() &&
                to != address(0) &&
                to != address(0xdead) &&
                !swapping
            ) {
                if (!tradingActive) {
                    require(
                        _isExcludedFromFees[from] || _isExcludedFromFees[to] || isAdminAccess(from) || isAdminAccess(to),
                        "Trading is not enabled yet."
                    );
                }

                //when buy
                if (
                    automatedMarketMakerPairs[from] &&
                    !_isExcludedMaxTransactionAmount[to]
                ) {
                    require(
                        amount <= maxTransactionAmount,
                        "Buy transfer amount exceeds the maxTransactionAmount."
                    );
                    require(
                        amount + balanceOf(to) <= maxWallet,
                        "Max wallet exceeded"
                    );
                }
                //when sell
                else if (
                    automatedMarketMakerPairs[to] &&
                    !_isExcludedMaxTransactionAmount[from]
                ) {
                    require(
                        amount <= maxTransactionAmount,
                        "Sell transfer amount exceeds the maxTransactionAmount."
                    );
                } else if (!_isExcludedMaxTransactionAmount[to]) {
                    require(
                        amount + balanceOf(to) <= maxWallet,
                        "Max wallet exceeded"
                    );
                }
            }
        }

        if (
            swapEnabled && //if this is true
            !swapping && //if this is false
            !automatedMarketMakerPairs[from] && //if this is false
            !_isExcludedFromFees[from] && //if this is false
            !_isExcludedFromFees[to] //if this is false
        ) {
            swapping = true;
            swapBack();
            swapping = false;
        }

        bool takeFee = !swapping;

        // if any account belongs to _isExcludedFromFee account then remove the fee
        if (_isExcludedFromFees[from] || _isExcludedFromFees[to]) {
            takeFee = false;
        }

        uint256 fees = 0;
        // only take fees on buys/sells, do not take on wallet transfers
        if (takeFee) {
            // on sell
            if (automatedMarketMakerPairs[to] &&  _getCurrentTaxRate(false) > 0) {
                fees = amount.mul( _getCurrentTaxRate(false)).div(100);
            }
            // on buy
            else if (automatedMarketMakerPairs[from] &&  _getCurrentTaxRate(true) > 0) {
                fees = amount.mul( _getCurrentTaxRate(true)).div(100);
            }

            if (fees > 0) {
                super._transfer(from, address(this), fees);
            }
            amount -= fees;
        }
        super._transfer(from, to, amount);
    }

    function swapTokensForEth(uint256 tokenAmount) private {
        // generate the uniswap pair path of token -> weth
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = uniswapV2Router.WETH();
        _approve(address(this), address(uniswapV2Router), tokenAmount);
        // make the swap
        uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0, // accept any amount of ETH
            path,
            address(this),
            block.timestamp
        );
    }

    function swapBack() private {
        uint256 contractBalance = balanceOf(address(this));
        bool success;
        if (contractBalance == 0) {
            return;
        }
        if (contractBalance >= swapTokensAtAmount) {
            uint256 amountToSwapForETH = swapTokensAtAmount;
            swapTokensForEth(amountToSwapForETH);
            uint256 amountEthToSend = address(this).balance;
            uint256 amountToMarketing = amountEthToSend
                .mul(marketingAmount)
                .div(100);
            uint256 amountToDev = amountEthToSend.sub(amountToMarketing);
            (success, ) = address(marketingWallet).call{
                value: amountToMarketing
            }("");
            (success, ) = address(devWallet).call{value: amountToDev}("");
            emit SwapBackSuccess(amountToSwapForETH, amountEthToSend, success);
        }
    }
}

Read Contract

_getCurrentTaxRate 0x593405c7 → uint256
_isExcludedMaxTransactionAmount 0x10d5de53 → bool
allowance 0xdd62ed3e → uint256
automatedMarketMakerPairs 0xb62496f5 → bool
balanceOf 0x70a08231 → uint256
buyTaxRates 0x7ac3f38f → uint256
deadAddress 0x27c8f835 → address
decimals 0x313ce567 → uint8
devAmount 0x2b345964 → uint256
devWallet 0x8ea5220f → address
isExcludedFromFees 0x4fbee193 → bool
limitsInEffect 0x4a62bb65 → bool
marketingAmount 0x360bfd54 → uint256
marketingWallet 0x75f0a874 → address
maxTransactionAmount 0xc8c8ebe4 → uint256
maxWallet 0xf8b45b05 → uint256
name 0x06fdde03 → string
owner 0x8da5cb5b → address
sellTaxRates 0x50b1b2c9 → uint256
swapEnabled 0x6ddd1713 → bool
swapTokensAtAmount 0xe2f45605 → uint256
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
tradingActive 0xbbc0c742 → bool
uniswapV2Pair 0x49bd5a5e → address
uniswapV2Router 0x1694505e → address

Write Contract 16 functions

These functions modify contract state and require a wallet transaction to execute.

addLiquidity 0xe8078d94
No parameters
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
decreaseAllowance 0xa457c2d7
address spender
uint256 subtractedValue
returns: bool
enableTrading 0x8a8c523c
No parameters
excludeFromFees 0xc0246668
address account
bool excluded
excludeFromMaxTransaction 0x7571336a
address addressToExclude
bool isExcluded
increaseAllowance 0x39509351
address spender
uint256 addedValue
returns: bool
manualSwap 0x51bc3c85
No parameters
removeLimits 0x751039fc
No parameters
returns: bool
renounceOwnership 0x715018a6
No parameters
setAutomatedMarketMakerPair 0x9a7a23d6
address pair
bool value
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner
updateFeeWallet 0x25d92ee2
address marketingWallet_
address devWallet_
updateSwapEnabled 0x924de9b7
bool enabled

Recent Transactions

No transactions found for this address