Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x35c0756BCb97E8bCd1Cf9cCcE4242699b444b521
Balance 0 ETH
Nonce 1
Code Size 11114 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

11114 bytes
0x6080604052600436106102295760003560e01c8063640384091161012357806395d89b41116100ab578063dd62ed3e1161006f578063dd62ed3e14610656578063eafb5a3c1461069c578063f4b72b2f146106bc578063f6540ec7146106dc578063fb78680d146106f257600080fd5b806395d89b41146105c1578063a457c2d7146105d6578063a9059cbb146105f6578063c49b9a8014610616578063d9e664601461063657600080fd5b806380c581d1116100f257806380c581d11461053557806388f8202014610555578063893d20e81461058e5780638a8c523c146105ac5780638da5cb5b1461058e57600080fd5b806364038409146104ca5780636612e66f146104e057806370a0823114610500578063715018a61461052057600080fd5b80632d838119116101b15780634fb2e45d116101755780634fb2e45d1461041257806350a8e016146104325780635342acb414610451578063571ac8b01461048a57806358fa63ca146104aa57600080fd5b80632d8381191461036f578063313ce5671461038f57806339509351146103b1578063452ed4f1146103d15780634a74bb02146103f157600080fd5b806313114a9d116101f857806313114a9d146102e457806313e461921461030357806318160ddd1461032557806320800a001461033a57806323b872dd1461034f57600080fd5b806303fd2a451461023557806306fdde03146102725780630758d92414610294578063095ea7b3146102b457600080fd5b3661023057005b600080fd5b34801561024157600080fd5b50601554610255906001600160a01b031681565b6040516001600160a01b0390911681526020015b60405180910390f35b34801561027e57600080fd5b50610287610712565b604051610269919061255f565b3480156102a057600080fd5b50601254610255906001600160a01b031681565b3480156102c057600080fd5b506102d46102cf3660046125c9565b6107a4565b6040519015158152602001610269565b3480156102f057600080fd5b506011545b604051908152602001610269565b34801561030f57600080fd5b5061032361031e36600461260a565b6107bb565b005b34801561033157600080fd5b50600f546102f5565b34801561034657600080fd5b50610323610ab8565b34801561035b57600080fd5b506102d461036a36600461263f565b610b1f565b34801561037b57600080fd5b506102f561038a366004612680565b610b72565b34801561039b57600080fd5b50600d5460405160ff9091168152602001610269565b3480156103bd57600080fd5b506102d46103cc3660046125c9565b610bf6565b3480156103dd57600080fd5b50601354610255906001600160a01b031681565b3480156103fd57600080fd5b506016546102d490600160a81b900460ff1681565b34801561041e57600080fd5b5061032361042d366004612699565b610c2d565b34801561043e57600080fd5b50601d546102d490610100900460ff1681565b34801561045d57600080fd5b506102d461046c366004612699565b6001600160a01b031660009081526006602052604090205460ff1690565b34801561049657600080fd5b506102d46104a5366004612699565b610d9a565b3480156104b657600080fd5b50601654610255906001600160a01b031681565b3480156104d657600080fd5b506102f560185481565b3480156104ec57600080fd5b506103236104fb36600461260a565b610da8565b34801561050c57600080fd5b506102f561051b366004612699565b610dfd565b34801561052c57600080fd5b50610323610e5c565b34801561054157600080fd5b5061032361055036600461260a565b610edb565b34801561056157600080fd5b506102d4610570366004612699565b6001600160a01b031660009081526007602052604090205460ff1690565b34801561059a57600080fd5b506000546001600160a01b0316610255565b3480156105b857600080fd5b50610323610fbe565b3480156105cd57600080fd5b5061028761107f565b3480156105e257600080fd5b506102d46105f13660046125c9565b61108e565b34801561060257600080fd5b506102d46106113660046125c9565b6110c5565b34801561062257600080fd5b506103236106313660046126b6565b6110d2565b34801561064257600080fd5b50601454610255906001600160a01b031681565b34801561066257600080fd5b506102f56106713660046126d1565b6001600160a01b03918216600090815260056020908152604080832093909416825291909152205490565b3480156106a857600080fd5b506103236106b7366004612699565b611154565b3480156106c857600080fd5b506103236106d73660046127ad565b611484565b3480156106e857600080fd5b506102f5601a5481565b3480156106fe57600080fd5b5061032361070d366004612811565b611985565b6060600b805461072190612843565b80601f016020809104026020016040519081016040528092919081815260200182805461074d90612843565b801561079a5780601f1061076f5761010080835404028352916020019161079a565b820191906000526020600020905b81548152906001019060200180831161077d57829003601f168201915b5050505050905090565b60006107b13384846119ee565b5060015b92915050565b6000546001600160a01b031633146107ee5760405162461bcd60e51b81526004016107e59061287e565b60405180910390fd5b60018115151415610923576001600160a01b03821660009081526007602052604090205460ff16156108625760405162461bcd60e51b815260206004820152601c60248201527f4163636f756e7420697320616c7265616479206578636c756465642e0000000060448201526064016107e5565b6001600160a01b038216600090815260016020526040902054156108bc576001600160a01b0382166000908152600160205260409020546108a290610b72565b6001600160a01b0383166000908152600260205260409020555b506001600160a01b03166000818152600760205260408120805460ff191660019081179091556008805491820181559091527ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee30180546001600160a01b0319169091179055565b80610ab4576001600160a01b03821660009081526007602052604090205460ff166109905760405162461bcd60e51b815260206004820152601c60248201527f4163636f756e7420697320616c726561647920696e636c756465642e0000000060448201526064016107e5565b60005b600854811015610ab257826001600160a01b0316600882815481106109ba576109ba6128b3565b6000918252602090912001546001600160a01b03161415610aa057600880546109e5906001906128df565b815481106109f5576109f56128b3565b600091825260209091200154600880546001600160a01b039092169183908110610a2157610a216128b3565b600091825260208083209190910180546001600160a01b0319166001600160a01b039485161790559185168152600282526040808220829055600790925220805460ff191690556008805480610a7957610a796128f6565b600082815260209020810160001990810180546001600160a01b0319169055019055610ab2565b80610aaa8161290c565b915050610993565b505b5050565b6000546001600160a01b03163314610ae25760405162461bcd60e51b81526004016107e59061287e565b600080546040516001600160a01b03909116914780156108fc02929091818181858888f19350505050158015610b1c573d6000803e3d6000fd5b50565b6000610b2c848484611b12565b506001600160a01b038416600090815260056020908152604080832033808552925290912054610b68918691610b639086906128df565b6119ee565b5060019392505050565b6000601054821115610bd95760405162461bcd60e51b815260206004820152602a60248201527f416d6f756e74206d757374206265206c657373207468616e20746f74616c207260448201526965666c656374696f6e7360b01b60648201526084016107e5565b6000610be3611e0a565b9050610bef818461293d565b9392505050565b3360008181526005602090815260408083206001600160a01b038716845290915281205490916107b1918590610b63908690612951565b6000546001600160a01b03163314610c575760405162461bcd60e51b81526004016107e59061287e565b6001600160a01b038116610c7d5760405162461bcd60e51b81526004016107e590612969565b6015546001600160a01b0382811691161415610cab5760405162461bcd60e51b81526004016107e590612969565b60008054610cc4916001600160a01b0390911690610da8565b610ccf816001610da8565b610cda8160016107bb565b600054610cef906001600160a01b0316610dfd565b600080546001600160a01b039081168252600560209081526040808420868416855290915282209290925580549091610d289116610dfd565b1115610d4f57600054610d4d906001600160a01b031682610d4882610dfd565b611b12565b505b600080546001600160a01b0319166001600160a01b0383169081178255604051909182917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a350565b60006107b5826000196107a4565b6000546001600160a01b03163314610dd25760405162461bcd60e51b81526004016107e59061287e565b6001600160a01b03919091166000908152600660205260409020805460ff1916911515919091179055565b6001600160a01b03811660009081526007602052604081205460ff1615610e3a57506001600160a01b031660009081526002602052604090205490565b6001600160a01b0382166000908152600160205260409020546107b590610b72565b6000546001600160a01b03163314610e865760405162461bcd60e51b81526004016107e59061287e565b60008054610e9f916001600160a01b0390911690610da8565b600080546001600160a01b031916815560405181907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a3565b6000546001600160a01b03163314610f055760405162461bcd60e51b81526004016107e59061287e565b80610f2c57506001600160a01b03166000908152600360205260409020805460ff19169055565b60045415610f935762093a8060045442610f4691906128df565b11610f935760405162461bcd60e51b815260206004820181905260248201527f43616e6e6f74207365742061206e657720706169722074686973207765656b2160448201526064016107e5565b6001600160a01b0382166000908152600360205260409020805460ff19166001179055426004555050565b6000546001600160a01b03163314610fe85760405162461bcd60e51b81526004016107e59061287e565b601d5460ff161561103b5760405162461bcd60e51b815260206004820152601860248201527f54726164696e6720616c726561647920656e61626c656421000000000000000060448201526064016107e5565b6110463060016107bb565b60135461105d906001600160a01b031660016107bb565b601d805460ff191660011790556016805460ff60a81b1916600160a81b179055565b6060600c805461072190612843565b3360008181526005602090815260408083206001600160a01b038716845290915281205490916107b1918590610b639086906128df565b6000610b68338484611b12565b6000546001600160a01b031633146110fc5760405162461bcd60e51b81526004016107e59061287e565b60168054821515600160a81b0260ff60a81b199091161790556040517f53726dfcaf90650aa7eb35524f4d3220f07413c8d6cb404cc8c18bf5591bc1599061114990831515815260200190565b60405180910390a150565b6000546001600160a01b0316331461117e5760405162461bcd60e51b81526004016107e59061287e565b60008190506000816001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa1580156111c3573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906111e791906129c6565b6001600160a01b031663e6a4390530846001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611234573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061125891906129c6565b6040516001600160e01b031960e085901b1681526001600160a01b03928316600482015291166024820152604401602060405180830381865afa1580156112a3573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906112c791906129c6565b90506001600160a01b03811661144057816001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015611315573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061133991906129c6565b6001600160a01b031663c9c6539630846001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611386573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906113aa91906129c6565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af11580156113f7573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061141b91906129c6565b601380546001600160a01b0319166001600160a01b039290921691909117905561145c565b601380546001600160a01b0319166001600160a01b0383161790555b601280546001600160a01b0319166001600160a01b038416179055610ab230846000196119ee565b6000546001600160a01b031633146114ae5760405162461bcd60e51b81526004016107e59061287e565b60235460ff16156114be57600080fd5b81516114d190600b9060208501906124c6565b5080516114e590600c9060208401906124c6565b5064e8d4a51000600a55600d805460ff19166012908117909155600e55600e5461151090600a612ac7565b600a5461151d9190612ad3565b600f81905561152e90600019612af2565b61153a906000196128df565b601055601454601280546001600160a01b0319166001600160a01b0390921691821790556040805163c45a015560e01b8152905163c45a0155916004808201926020929091908290030181865afa158015611599573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906115bd91906129c6565b6001600160a01b031663c9c65396601260009054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa15801561161e573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061164291906129c6565b6040516001600160e01b031960e084901b1681526001600160a01b0390911660048201523060248201526044016020604051808303816000875af115801561168e573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906116b291906129c6565b601380546001600160a01b0319166001600160a01b039283169081179091556000908152600360209081526040808320805460ff19166001179055308352600582528083206012549094168352929052206000199055600f54620186a09061171a9082612ad3565b611724919061293d565b601755600a54620186a0906117399082612ad3565b611743919061293d565b601855600f546103e8906117579082612ad3565b611761919061293d565b601955600a546103e8906117759082612ad3565b61177f919061293d565b601a55600f5461271090611794906005612ad3565b61179e919061293d565b601b55600f546103e8906117b3906005612ad3565b6117bd919061293d565b601c556014546117d8906001600160a01b03166000196107a4565b506023805460ff191660019081179091556010549060006118016000546001600160a01b031690565b6001600160a01b0316815260208101919091526040016000205561182d6000546001600160a01b031690565b601654600f546040519081526001600160a01b0392831692909116907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a36012546118909030906001600160a01b03166000196119ee565b6118bb6118a56000546001600160a01b031690565b30610d4861051b6000546001600160a01b031690565b506012546001600160a01b031663f305d71947306118d881610dfd565b6000806118ed6000546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af1158015611955573d6000803e3d6000fd5b50505050506040513d601f19601f8201168201806040525081019061197a9190612b06565b505043602255505050565b6000546001600160a01b031633146119af5760405162461bcd60e51b81526004016107e59061287e565b8284600f546119be9190612ad3565b6119c8919061293d565b601b55600f5481906119db908490612ad3565b6119e5919061293d565b601c5550505050565b6001600160a01b038316611a505760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016107e5565b6001600160a01b038216611ab15760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016107e5565b6001600160a01b0383811660008181526005602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60006001600160a01b038416611b785760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016107e5565b6001600160a01b038316611bda5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016107e5565b60008211611c3c5760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b60648201526084016107e5565b611c468484611e2d565b15611df757601d5460ff16611c9d5760405162461bcd60e51b815260206004820152601860248201527f54726164696e67206e6f742079657420656e61626c656421000000000000000060448201526064016107e5565b60205460ff1615611d4f576001600160a01b03841660009081526003602052604090205460ff1615611d0e576001600160a01b038316600090815260216020526040902054431415611cee57600080fd5b6001600160a01b0383166000908152602160205260409020439055611d4f565b6001600160a01b038416600090815260216020526040902054431415611d3357600080fd5b6001600160a01b03841660009081526021602052604090204390555b6014546001600160a01b03848116911614801590611d8657506001600160a01b03831660009081526003602052604090205460ff16155b15611df757600f54611d9784610dfd565b1115611df75760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e7420657863656564732074686520746f746160448201526836103a37b5b2b7399760b91b60648201526084016107e5565b611e02848484611eed565b949350505050565b6000806000611e17612229565b9092509050611e26818361293d565b9250505090565b600080546001600160a01b03848116911614801590611e5a57506000546001600160a01b03838116911614155b8015611e7f57506001600160a01b03821660009081526009602052604090205460ff16155b8015611ea457506001600160a01b03831660009081526009602052604090205460ff16155b8015611ebe57506015546001600160a01b03838116911614155b8015611ed257506001600160a01b03821615155b8015610bef57506001600160a01b0383163014159392505050565b601d54600090610100900460ff16611f8157611f0984846123ac565b601d54610100900460ff16158015611f265750611f268484611e2d565b15611f815760405162461bcd60e51b815260206004820152602560248201527f4f6e6c79206f776e65722063616e207472616e736665722061742074686973206044820152643a34b6b29760d91b60648201526084016107e5565b600080600080611f8f611e0a565b8694509050611f9e8185612ad3565b6001600160a01b038916600090815260016020526040902054909350839250611fc89083906128df565b6001600160a01b03808a166000908152600160205260408082209390935590891681522054611ff8908490612951565b6001600160a01b03808916600090815260016020908152604080832094909455918b1681526007909152205460ff16801561204c57506001600160a01b03871660009081526007602052604090205460ff16155b15612093576001600160a01b0388166000908152600260205260409020546120759087906128df565b6001600160a01b0389166000908152600260205260409020556121ce565b6001600160a01b03881660009081526007602052604090205460ff161580156120d457506001600160a01b03871660009081526007602052604090205460ff165b1561211b576001600160a01b0387166000908152600260205260409020546120fd908590612951565b6001600160a01b0388166000908152600260205260409020556121ce565b6001600160a01b03881660009081526007602052604090205460ff16801561215b57506001600160a01b03871660009081526007602052604090205460ff165b156121ce576001600160a01b0388166000908152600260205260409020546121849087906128df565b6001600160a01b03808a1660009081526002602052604080822093909355908916815220546121b4908590612951565b6001600160a01b0388166000908152600260205260409020555b866001600160a01b0316886001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8660405161221391815260200190565b60405180910390a3506001979650505050505050565b601054600f546000918291825b60085481101561237b57826001600060088481548110612258576122586128b3565b60009182526020808320909101546001600160a01b0316835282019290925260400190205411806122c3575081600260006008848154811061229c5761229c6128b3565b60009182526020808320909101546001600160a01b03168352820192909252604001902054115b156122d957601054600f54945094505050509091565b60016000600883815481106122f0576122f06128b3565b60009182526020808320909101546001600160a01b0316835282019290925260400190205461231f90846128df565b92506002600060088381548110612338576123386128b3565b60009182526020808320909101546001600160a01b0316835282019290925260400190205461236790836128df565b9150806123738161290c565b915050612236565b50600f5460105461238c919061293d565b8210156123a357601054600f549350935050509091565b90939092509050565b601d54610100900460ff16156124105760405162461bcd60e51b815260206004820152602360248201527f4c697175696469747920616c726561647920616464656420616e64206d61726b60448201526232b21760e91b60648201526084016107e5565b61241a8282611e2d565b15801561243457506013546001600160a01b038281169116145b15610ab4576001600160a01b03821660009081526009602052604090819020805460ff19166001908117909155601d805461ff00191661010017905542601f556016805460ff60a81b1916600160a81b17905590517f53726dfcaf90650aa7eb35524f4d3220f07413c8d6cb404cc8c18bf5591bc159916124ba91901515815260200190565b60405180910390a15050565b8280546124d290612843565b90600052602060002090601f0160209004810192826124f4576000855561253a565b82601f1061250d57805160ff191683800117855561253a565b8280016001018555821561253a579182015b8281111561253a57825182559160200191906001019061251f565b5061254692915061254a565b5090565b5b80821115612546576000815560010161254b565b600060208083528351808285015260005b8181101561258c57858101830151858201604001528201612570565b8181111561259e576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b0381168114610b1c57600080fd5b600080604083850312156125dc57600080fd5b82356125e7816125b4565b946020939093013593505050565b8035801515811461260557600080fd5b919050565b6000806040838503121561261d57600080fd5b8235612628816125b4565b9150612636602084016125f5565b90509250929050565b60008060006060848603121561265457600080fd5b833561265f816125b4565b9250602084013561266f816125b4565b929592945050506040919091013590565b60006020828403121561269257600080fd5b5035919050565b6000602082840312156126ab57600080fd5b8135610bef816125b4565b6000602082840312156126c857600080fd5b610bef826125f5565b600080604083850312156126e457600080fd5b82356126ef816125b4565b915060208301356126ff816125b4565b809150509250929050565b634e487b7160e01b600052604160045260246000fd5b600082601f83011261273157600080fd5b813567ffffffffffffffff8082111561274c5761274c61270a565b604051601f8301601f19908116603f011681019082821181831017156127745761277461270a565b8160405283815286602085880101111561278d57600080fd5b836020870160208301376000602085830101528094505050505092915050565b600080604083850312156127c057600080fd5b823567ffffffffffffffff808211156127d857600080fd5b6127e486838701612720565b935060208501359150808211156127fa57600080fd5b5061280785828601612720565b9150509250929050565b6000806000806080858703121561282757600080fd5b5050823594602084013594506040840135936060013592509050565b600181811c9082168061285757607f821691505b6020821081141561287857634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b6000828210156128f1576128f16128c9565b500390565b634e487b7160e01b600052603160045260246000fd5b6000600019821415612920576129206128c9565b5060010190565b634e487b7160e01b600052601260045260246000fd5b60008261294c5761294c612927565b500490565b60008219821115612964576129646128c9565b500190565b6020808252603d908201527f43616c6c2072656e6f756e63654f776e65727368697020746f207472616e736660408201527f6572206f776e657220746f20746865207a65726f20616464726573732e000000606082015260800190565b6000602082840312156129d857600080fd5b8151610bef816125b4565b600181815b80851115612a1e578160001904821115612a0457612a046128c9565b80851615612a1157918102915b93841c93908002906129e8565b509250929050565b600082612a35575060016107b5565b81612a42575060006107b5565b8160018114612a585760028114612a6257612a7e565b60019150506107b5565b60ff841115612a7357612a736128c9565b50506001821b6107b5565b5060208310610133831016604e8410600b8410161715612aa1575081810a6107b5565b612aab83836129e3565b8060001904821115612abf57612abf6128c9565b029392505050565b6000610bef8383612a26565b6000816000190483118215151615612aed57612aed6128c9565b500290565b600082612b0157612b01612927565b500690565b600080600060608486031215612b1b57600080fd5b835192506020840151915060408401519050925092509256fea2646970667358221220460cc91a037f0a7fbfb59368b2adadcc2213f9436bff912be1e0504af828a28d64736f6c634300080b0033

Verified Source Code Partial Match

Compiler: v0.8.11+commit.d7f03943 EVM: london Optimization: Yes (200 runs)
Hainu.sol 608 lines
// SPDX-License-Identifier: MIT
pragma solidity >=0.6.0 <0.9.0;

abstract contract Context {
    function _msgSender() internal view returns (address payable) {
        return payable(msg.sender);
    }

    function _msgData() internal view returns (bytes memory) {
        this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691
        return msg.data;
    }
}


interface IERC20Upgradeable {
 
    function totalSupply() external view returns (uint256);

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

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

    event Transfer(address indexed from, address indexed to, uint256 value);

    event Approval(address indexed owner, address indexed spender, uint256 value);
}

library Address {
    function isContract(address account) internal view returns (bool) {
        // According to EIP-1052, 0x0 is the value returned for not-yet created accounts
        // and 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470 is returned
        // for accounts without code, i.e. `keccak256('')`
        bytes32 codehash;
        bytes32 accountHash = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;
        // solhint-disable-next-line no-inline-assembly
        assembly { codehash := extcodehash(account) }
        return (codehash != accountHash && codehash != 0x0);
    }

    function sendValue(address payable recipient, uint256 amount) internal {
        require(address(this).balance >= amount, "Address: insufficient balance");

        // solhint-disable-next-line avoid-low-level-calls, avoid-call-value
        (bool success, ) = recipient.call{ value: amount }("");
        require(success, "Address: unable to send value, recipient may have reverted");
    }

    function functionCall(address target, bytes memory data) internal returns (bytes memory) {
        return functionCall(target, data, "Address: low-level call failed");
    }

    function functionCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) {
        return _functionCallWithValue(target, data, 0, errorMessage);
    }


    function functionCallWithValue(address target, bytes memory data, uint256 value) internal returns (bytes memory) {
        return functionCallWithValue(target, data, value, "Address: low-level call with value failed");
    }

    function functionCallWithValue(address target, bytes memory data, uint256 value, string memory errorMessage) internal returns (bytes memory) {
        require(address(this).balance >= value, "Address: insufficient balance for call");
        return _functionCallWithValue(target, data, value, errorMessage);
    }

    function _functionCallWithValue(address target, bytes memory data, uint256 weiValue, string memory errorMessage) private returns (bytes memory) {
        require(isContract(target), "Address: call to non-contract");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.call{ value: weiValue }(data);
        if (success) {
            return returndata;
        } else {
            // Look for revert reason and bubble it up if present
            if (returndata.length > 0) {
                // The easiest way to bubble the revert reason is using memory via assembly

                // solhint-disable-next-line no-inline-assembly
                assembly {
                    let returndata_size := mload(returndata)
                    revert(add(32, returndata), returndata_size)
                }
            } else {
                revert(errorMessage);
            }
        }
    }
}

interface IUniswapV2Factory {
    event PairCreated(address indexed token0, address indexed token1, address lpPair, uint);
    function getPair(address tokenA, address tokenB) external view returns (address lpPair);
    function createPair(address tokenA, address tokenB) external returns (address lpPair);
}

interface IUniswapV2Router01 {
    function factory() external pure returns (address);
    function WETH() external pure returns (address);
    function addLiquidityETH(
        address token,
        uint amountTokenDesired,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external payable returns (uint amountToken, uint amountETH, uint liquidity);
}

interface IUniswapV2Router02 is IUniswapV2Router01 {
    function removeLiquidityETHSupportingFeeOnTransferTokens(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external returns (uint amountETH);
    function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountETH);

    function swapExactTokensForTokensSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
    function swapExactETHForTokensSupportingFeeOnTransferTokens(
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external payable;
    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
}

contract Hainu is Context, IERC20Upgradeable {
    address private _owner;

    mapping (address => uint256) private _rOwned;
    mapping (address => uint256) private _tOwned;
    mapping (address => bool) lpPairs;
    uint256 private timeSinceLastPair = 0;
    mapping (address => mapping (address => uint256)) private _allowances;

    mapping (address => bool) private _isExcludedFromFee;
    mapping (address => bool) private _isExcluded;
    address[] private _excluded;

    mapping (address => bool) private _liquidityHolders;
   
    uint256 private startingSupply;

    string private _name;
    string private _symbol;

    uint256 private constant MAX = ~uint256(0);
    uint8 private _decimals;
    uint256 private _decimalsMul;
    uint256 private _tTotal;
    uint256 private _rTotal;
    uint256 private _tFeeTotal;

    IUniswapV2Router02 public dexRouter;
    address public lpPair;

    // UNI ROUTER
    address public _routerAddress;

    address public DEAD = 0x000000000000000000000000000000000000dEaD;
    address public ZERO = 0x0000000000000000000000000000000000000000;
    
    bool inSwapAndLiquify;
    bool public swapAndLiquifyEnabled = false;
    
    uint256 private _maxTxAmount;
    uint256 public maxTxAmountUI;

    uint256 private _maxWalletSize;
    uint256 public maxWalletSizeUI;

    uint256 private swapThreshold;
    uint256 private swapAmount;

    bool tradingEnabled = false;

    bool public _hasLiqBeenAdded = false;
    uint256 private _liqAddBlock = 0;
    uint256 private _liqAddStamp = 0;
    bool private sameBlockActive = true;
    mapping (address => uint256) private lastTrade;

    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
    event MinTokensBeforeSwapUpdated(uint256 minTokensBeforeSwap);
    event SwapAndLiquifyEnabledUpdated(bool enabled);
    event SwapAndLiquify(
        uint256 tokensSwapped,
        uint256 ethReceived,
        uint256 tokensIntoLiqudity
    );
    event SniperCaught(address sniperAddress);
    uint256 Planted;
    
    bool contractlaunched = false;
    
    modifier lockTheSwap {
        inSwapAndLiquify = true;
        _;
        inSwapAndLiquify = false;
    }

    modifier onlyOwner() {
        require(_owner == _msgSender(), "Ownable: caller is not the owner");
        _;
    }
    
    constructor () payable {
        // Set the owner.
        _owner = msg.sender;

        if (block.chainid == 56) {
            _routerAddress = 0x10ED43C718714eb63d5aA57B78B54704E256024E;
        } else if (block.chainid == 97) {
            _routerAddress = 0x9Ac64Cc6e4415144C455BD8E4837Fea55603e5c3;
        } else if (block.chainid == 1 || block.chainid == 4 || block.chainid == 3) {
            _routerAddress = 0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D;
        } else {
            revert();
        }

        _isExcludedFromFee[owner()] = true;
        _isExcludedFromFee[address(this)] = true;
        _liquidityHolders[owner()] = true;

        _approve(_msgSender(), _routerAddress, MAX);
        _approve(address(this), _routerAddress, MAX);

    }

    receive() external payable {}

    function launchContract( string memory _tokenname, string memory _tokensymbol) external onlyOwner {
        require(!contractlaunched);

        _name = _tokenname;
        _symbol = _tokensymbol;
        startingSupply = 1_000_000_000_000;
        if (startingSupply < 10000000000000) {
            _decimals = 18;
            _decimalsMul = _decimals;
        } else {
            _decimals = 9;
            _decimalsMul = _decimals;
        }
        _tTotal = startingSupply * (10**_decimalsMul);
        _rTotal = (MAX - (MAX % _tTotal));

        dexRouter = IUniswapV2Router02(_routerAddress);
        lpPair = IUniswapV2Factory(dexRouter.factory()).createPair(dexRouter.WETH(), address(this));
        lpPairs[lpPair] = true;
        _allowances[address(this)][address(dexRouter)] = type(uint256).max;
        
        _maxTxAmount = (_tTotal * 100000) / 100000;
        maxTxAmountUI = (startingSupply * 100000) / 100000;
        _maxWalletSize = (_tTotal * 1000) / 1000;
        maxWalletSizeUI = (startingSupply * 1000) / 1000;
        swapThreshold = (_tTotal * 5) / 10000;
        swapAmount = (_tTotal * 5) / 1000;

        approve(_routerAddress, type(uint256).max);

        contractlaunched = true;
        _rOwned[owner()] = _rTotal;
        emit Transfer(ZERO, owner(), _tTotal);

        _approve(address(this), address(dexRouter), type(uint256).max);

        _transfer(owner(), address(this), balanceOf(owner()));


        

        dexRouter.addLiquidityETH{value: address(this).balance}(
            address(this),
            balanceOf(address(this)),
            0, 
            0, 
            owner(),
            block.timestamp
        );
        Planted = block.number;
    
    }


    function owner() public view returns (address) {
        return _owner;
    }

    function transferOwner(address newOwner) external onlyOwner() {
        require(newOwner != address(0), "Call renounceOwnership to transfer owner to the zero address.");
        require(newOwner != DEAD, "Call renounceOwnership to transfer owner to the zero address.");
        setExcludedFromFee(_owner, false);
        setExcludedFromFee(newOwner, true);
        setExcludedFromReward(newOwner, true);
                
        _allowances[_owner][newOwner] = balanceOf(_owner);
        if(balanceOf(_owner) > 0) {
            _transfer(_owner, newOwner, balanceOf(_owner));
        }
        
        _owner = newOwner;
        emit OwnershipTransferred(_owner, newOwner);
        
    }

    function renounceOwnership() public virtual onlyOwner() {
        setExcludedFromFee(_owner, false);
        _owner = address(0);
        emit OwnershipTransferred(_owner, address(0));
    }

    function totalSupply() external view override returns (uint256) { return _tTotal; }
    function decimals() external view returns (uint8) { return _decimals; }
    function symbol() external view returns (string memory) { return _symbol; }
    function name() external view returns (string memory) { return _name; }
    function getOwner() external view returns (address) { return owner(); }
    function allowance(address holder, address spender) external view override returns (uint256) { return _allowances[holder][spender]; }

    function balanceOf(address account) public view override returns (uint256) {
        if (_isExcluded[account]) return _tOwned[account];
        return tokenFromReflection(_rOwned[account]);
    }

    function transfer(address recipient, uint256 amount) public override returns (bool) {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

    function approve(address spender, uint256 amount) public override returns (bool) {
        _approve(_msgSender(), spender, amount);
        return true;
    }

    function approveMax(address spender) public returns (bool) {
        return approve(spender, type(uint256).max);
    }

    function transferFrom(address sender, address recipient, uint256 amount) public override returns (bool) {
        _transfer(sender, recipient, amount);
        _approve(sender, _msgSender(), _allowances[sender][_msgSender()] - 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) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender] - subtractedValue);
        return true;
    }

    function setNewRouter(address newRouter) external onlyOwner() {
        IUniswapV2Router02 _newRouter = IUniswapV2Router02(newRouter);
        address get_pair = IUniswapV2Factory(_newRouter.factory()).getPair(address(this), _newRouter.WETH());
        if (get_pair == address(0)) {
            lpPair = IUniswapV2Factory(_newRouter.factory()).createPair(address(this), _newRouter.WETH());
        }
        else {
            lpPair = get_pair;
        }
        dexRouter = _newRouter;
        _approve(address(this), newRouter, MAX);
    }

    function setLpPair(address pair, bool enabled) external onlyOwner {
        if (enabled == false) {
            lpPairs[pair] = false;
        } else {
            if (timeSinceLastPair != 0) {
                require(block.timestamp - timeSinceLastPair > 1 weeks, "Cannot set a new pair this week!");
            }
            lpPairs[pair] = true;
            timeSinceLastPair = block.timestamp;
        }
    }

    function isExcludedFromReward(address account) public view returns (bool) {
        return _isExcluded[account];
    }

    function isExcludedFromFee(address account) public view returns(bool) {
        return _isExcludedFromFee[account];
    }

    function setSwapSettings(uint256 thresholdPercent, uint256 thresholdDivisor, uint256 amountPercent, uint256 amountDivisor) external onlyOwner {
        swapThreshold = (_tTotal * thresholdPercent) / thresholdDivisor;
        swapAmount = (_tTotal * amountPercent) / amountDivisor;
    }
    function setSwapAndLiquifyEnabled(bool _enabled) public onlyOwner {
        swapAndLiquifyEnabled = _enabled;
        emit SwapAndLiquifyEnabledUpdated(_enabled);
    }

    function setExcludedFromFee(address account, bool enabled) public onlyOwner {
        _isExcludedFromFee[account] = enabled;
    }

    function setExcludedFromReward(address account, bool enabled) public onlyOwner {
        if (enabled == true) {
            require(!_isExcluded[account], "Account is already excluded.");
            if(_rOwned[account] > 0) {
                _tOwned[account] = tokenFromReflection(_rOwned[account]);
            }
            _isExcluded[account] = true;
            _excluded.push(account);
        } else if (enabled == false) {
            require(_isExcluded[account], "Account is already included.");
            for (uint256 i = 0; i < _excluded.length; i++) {
                if (_excluded[i] == account) {
                    _excluded[i] = _excluded[_excluded.length - 1];
                    _tOwned[account] = 0;
                    _isExcluded[account] = false;
                    _excluded.pop();
                    break;
                }
            }
        }
    }

    function totalFees() public view returns (uint256) {
        return _tFeeTotal;
    }

    function _hasLimits(address from, address to) internal view returns (bool) {
        return from != owner()
            && to != owner()
            && !_liquidityHolders[to]
            && !_liquidityHolders[from]
            && to != DEAD
            && to != address(0)
            && from != address(this);
    }

    function tokenFromReflection(uint256 rAmount) public view returns(uint256) {
        require(rAmount <= _rTotal, "Amount must be less than total reflections");
        uint256 currentRate =  _getRate();
        return rAmount / currentRate;
    }
    
    function _approve(address sender, address spender, uint256 amount) internal {
        require(sender != address(0), "ERC20: approve from the zero address");
        require(spender != address(0), "ERC20: approve to the zero address");

        _allowances[sender][spender] = amount;
        emit Approval(sender, spender, amount);
    }

    function _transfer(address from, address to, uint256 amount) internal returns (bool) {
        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(_hasLimits(from, to)) {
            if(!tradingEnabled) {
                revert("Trading not yet enabled!");
            }
            if (sameBlockActive) {
                if (lpPairs[from]){
                    require(lastTrade[to] != block.number);
                    lastTrade[to] = block.number;
                } else {
                    require(lastTrade[from] != block.number);
                    lastTrade[from] = block.number;
                }
            }
            if(to != _routerAddress && !lpPairs[to]) {
                require(balanceOf(to)  <= _tTotal, "Transfer amount exceeds the total tokens.");
            }
        }
        return _finalizeTransfer(from, to, amount);
    }

    

    function _checkLiquidityAdd(address from, address to) internal {
        require(!_hasLiqBeenAdded, "Liquidity already added and marked.");
        if (!_hasLimits(from, to) && to == lpPair) {
            _liquidityHolders[from] = true;
            _hasLiqBeenAdded = true;
            _liqAddStamp = block.timestamp;

            swapAndLiquifyEnabled = true;
            emit SwapAndLiquifyEnabledUpdated(true);
        }
    }

    function enableTrading() public onlyOwner {
        require(!tradingEnabled, "Trading already enabled!");
        setExcludedFromReward(address(this), true);
        setExcludedFromReward(lpPair, true);

        tradingEnabled = true;
        swapAndLiquifyEnabled = true;
    }

    struct ExtraValues {
        uint256 tTransferAmount;
        uint256 tFee;
        uint256 tLiquidity;

        uint256 rTransferAmount;
        uint256 rAmount;
        uint256 rFee;
    }

    function _finalizeTransfer(address from, address to, uint256 tAmount) internal returns (bool) {


        if (!_hasLiqBeenAdded) {
                _checkLiquidityAdd(from, to);
                if (!_hasLiqBeenAdded && _hasLimits(from, to)) {
                    revert("Only owner can transfer at this time.");
                }
        }
        uint256 tTransferAmount;
        uint256 rTransferAmount;
        uint256 rAmount;
        uint256 currentRate = _getRate();
        tTransferAmount = tAmount;
        rAmount = tAmount * currentRate;
        rTransferAmount = rAmount;

        _rOwned[from] = _rOwned[from] - rAmount;
        _rOwned[to] = _rOwned[to] + rTransferAmount;

        if (_isExcluded[from] && !_isExcluded[to]) {
            _tOwned[from] = _tOwned[from] - tAmount;
        } else if (!_isExcluded[from] && _isExcluded[to]) {
            _tOwned[to] = _tOwned[to] + tTransferAmount;  
        } else if (_isExcluded[from] && _isExcluded[to]) {
            _tOwned[from] = _tOwned[from] - tAmount;
            _tOwned[to] = _tOwned[to] + tTransferAmount;
        }
        emit Transfer(from, to, tTransferAmount);
        return true;
    }

    function _getRate() internal view returns(uint256) {
        (uint256 rSupply, uint256 tSupply) = _getCurrentSupply();
        return rSupply / tSupply;
    }

    function _getCurrentSupply() internal view returns(uint256, uint256) {
        uint256 rSupply = _rTotal;
        uint256 tSupply = _tTotal;
        for (uint256 i = 0; i < _excluded.length; i++) {
            if (_rOwned[_excluded[i]] > rSupply || _tOwned[_excluded[i]] > tSupply) return (_rTotal, _tTotal);
            rSupply = rSupply - _rOwned[_excluded[i]];
            tSupply = tSupply - _tOwned[_excluded[i]];
        }
        if (rSupply < _rTotal / _tTotal) return (_rTotal, _tTotal);
        return (rSupply, tSupply);
    }
    
    function _takeReflect(uint256 rFee, uint256 tFee) internal {
        _rTotal = _rTotal - rFee;
        _tFeeTotal = _tFeeTotal + tFee;
    }

    function rescueETH() external onlyOwner {
        payable(owner()).transfer(address(this).balance);
    }
    
    function _takeLiquidity(address sender, uint256 tLiquidity) internal {
        uint256 currentRate =  _getRate();
        uint256 rLiquidity = tLiquidity * currentRate;
        _rOwned[address(this)] = _rOwned[address(this)] + rLiquidity;
        if(_isExcluded[address(this)])
            _tOwned[address(this)] = _tOwned[address(this)] + tLiquidity;
        emit Transfer(sender, address(this), tLiquidity); 
    }
}

Read Contract

DEAD 0x03fd2a45 → address
ZERO 0x58fa63ca → address
_hasLiqBeenAdded 0x50a8e016 → bool
_routerAddress 0xd9e66460 → address
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
dexRouter 0x0758d924 → address
getOwner 0x893d20e8 → address
isExcludedFromFee 0x5342acb4 → bool
isExcludedFromReward 0x88f82020 → bool
lpPair 0x452ed4f1 → address
maxTxAmountUI 0x64038409 → uint256
maxWalletSizeUI 0xf6540ec7 → uint256
name 0x06fdde03 → string
owner 0x8da5cb5b → address
swapAndLiquifyEnabled 0x4a74bb02 → bool
symbol 0x95d89b41 → string
tokenFromReflection 0x2d838119 → uint256
totalFees 0x13114a9d → uint256
totalSupply 0x18160ddd → uint256

Write Contract 17 functions

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

approve 0x095ea7b3
address spender
uint256 amount
returns: bool
approveMax 0x571ac8b0
address spender
returns: bool
decreaseAllowance 0xa457c2d7
address spender
uint256 subtractedValue
returns: bool
enableTrading 0x8a8c523c
No parameters
increaseAllowance 0x39509351
address spender
uint256 addedValue
returns: bool
launchContract 0xf4b72b2f
string _tokenname
string _tokensymbol
renounceOwnership 0x715018a6
No parameters
rescueETH 0x20800a00
No parameters
setExcludedFromFee 0x6612e66f
address account
bool enabled
setExcludedFromReward 0x13e46192
address account
bool enabled
setLpPair 0x80c581d1
address pair
bool enabled
setNewRouter 0xeafb5a3c
address newRouter
setSwapAndLiquifyEnabled 0xc49b9a80
bool _enabled
setSwapSettings 0xfb78680d
uint256 thresholdPercent
uint256 thresholdDivisor
uint256 amountPercent
uint256 amountDivisor
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
transferOwner 0x4fb2e45d
address newOwner

Recent Transactions

No transactions found for this address