Address Contract Partially Verified
Address
0x867807750F7A42E30050Eb2122C1B82d8615c8DB
Balance
0 ETH
Nonce
1
Code Size
8873 bytes
Creator
0x8408a8Bd...9585 at tx 0xdc97bf95...52d0c6
Indexed Transactions
0
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