Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x5E9C14B5B13FAA352c4068A9bd7a3FCbAc5d5D05
Balance 0 ETH
Nonce 1
Code Size 13801 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

13801 bytes
0x608060405260043610610143575f3560e01c8063751039fc116100b5578063bf474bed1161006e578063bf474bed14610434578063c876d0b91461045e578063c9567bf914610488578063d34628cc1461049e578063dd62ed3e146104c6578063ec1f3f63146105025761014a565b8063751039fc1461033a5780637d1db4a5146103505780638da5cb5b1461037a5780638f9a55c0146103a457806395d89b41146103ce578063a9059cbb146103f85761014a565b8063313ce56711610107578063313ce5671461024457806331c2d8471461026e5780633bbac5791461029657806351bc3c85146102d257806370a08231146102e8578063715018a6146103245761014a565b806306fdde031461014e578063095ea7b3146101785780630faee56f146101b457806318160ddd146101de57806323b872dd146102085761014a565b3661014a57005b5f80fd5b348015610159575f80fd5b5061016261052a565b60405161016f9190612522565b60405180910390f35b348015610183575f80fd5b5061019e600480360381019061019991906125e0565b61054a565b6040516101ab9190612638565b60405180910390f35b3480156101bf575f80fd5b506101c8610567565b6040516101d59190612660565b60405180910390f35b3480156101e9575f80fd5b506101f261056d565b6040516101ff9190612660565b60405180910390f35b348015610213575f80fd5b5061022e60048036038101906102299190612679565b610591565b60405161023b9190612638565b60405180910390f35b34801561024f575f80fd5b50610258610665565b60405161026591906126e4565b60405180910390f35b348015610279575f80fd5b50610294600480360381019061028f919061283d565b61066d565b005b3480156102a1575f80fd5b506102bc60048036038101906102b79190612884565b610791565b6040516102c99190612638565b60405180910390f35b3480156102dd575f80fd5b506102e66107e3565b005b3480156102f3575f80fd5b5061030e60048036038101906103099190612884565b61087b565b60405161031b9190612660565b60405180910390f35b34801561032f575f80fd5b506103386108c1565b005b348015610345575f80fd5b5061034e610a0f565b005b34801561035b575f80fd5b50610364610b5a565b6040516103719190612660565b60405180910390f35b348015610385575f80fd5b5061038e610b60565b60405161039b91906128be565b60405180910390f35b3480156103af575f80fd5b506103b8610b87565b6040516103c59190612660565b60405180910390f35b3480156103d9575f80fd5b506103e2610b8d565b6040516103ef9190612522565b60405180910390f35b348015610403575f80fd5b5061041e600480360381019061041991906125e0565b610bca565b60405161042b9190612638565b60405180910390f35b34801561043f575f80fd5b50610448610be7565b6040516104559190612660565b60405180910390f35b348015610469575f80fd5b50610472610bed565b60405161047f9190612638565b60405180910390f35b348015610493575f80fd5b5061049c610bff565b005b3480156104a9575f80fd5b506104c460048036038101906104bf919061283d565b61111f565b005b3480156104d1575f80fd5b506104ec60048036038101906104e791906128d7565b611244565b6040516104f99190612660565b60405180910390f35b34801561050d575f80fd5b5061052860048036038101906105239190612915565b6112c6565b005b606060405180606001604052806027815260200161356560279139905090565b5f61055d610556611353565b848461135a565b6001905092915050565b60125481565b5f6009600a61057c9190612a9c565b64174876e80061058c9190612ae6565b905090565b5f61059d84848461151d565b61065a846105a9611353565b6106558560405180606001604052806028815260200161358c6028913960025f8b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f61060c611353565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054611f839092919063ffffffff16565b61135a565b600190509392505050565b5f6009905090565b610675611353565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610701576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016106f890612b71565b60405180910390fd5b5f5b815181101561078d575f60045f84848151811061072357610722612b8f565b5b602002602001015173ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6101000a81548160ff021916908315150217905550808061078590612bbc565b915050610703565b5050565b5f60045f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff169050919050565b600660019054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16610824611353565b73ffffffffffffffffffffffffffffffffffffffff1614610843575f80fd5b5f61084d3061087b565b90505f8111156108615761086081611fe5565b5b5f4790505f8111156108775761087681612250565b5b5050565b5f60015f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20549050919050565b6108c9611353565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610955576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161094c90612b71565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35f805f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b610a17611353565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610aa3576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610a9a90612b71565b60405180910390fd5b6009600a610ab19190612a9c565b64174876e800610ac19190612ae6565b600f819055506009600a610ad59190612a9c565b64174876e800610ae59190612ae6565b6010819055505f60065f6101000a81548160ff0219169083151502179055507f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf6009600a610b339190612a9c565b64174876e800610b439190612ae6565b604051610b509190612660565b60405180910390a1565b600f5481565b5f805f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60105481565b60606040518060400160405280600481526020017f47524f4b00000000000000000000000000000000000000000000000000000000815250905090565b5f610bdd610bd6611353565b848461151d565b6001905092915050565b60115481565b60065f9054906101000a900460ff1681565b610c07611353565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610c93576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610c8a90612b71565b60405180910390fd5b60148054906101000a900460ff1615610ce1576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610cd890612c4d565b60405180910390fd5b737a250d5630b4cf539739df2c5dacb4c659f2488d60135f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550610d7e3060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff166009600a610d699190612a9c565b64174876e800610d799190612ae6565b61135a565b60135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610de8573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610e0c9190612c7f565b73ffffffffffffffffffffffffffffffffffffffff1663c9c653963060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610e92573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610eb69190612c7f565b6040518363ffffffff1660e01b8152600401610ed3929190612caa565b6020604051808303815f875af1158015610eef573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610f139190612c7f565b60145f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663f305d7194730610f9a3061087b565b5f80610fa4610b60565b426040518863ffffffff1660e01b8152600401610fc696959493929190612d13565b60606040518083038185885af1158015610fe2573d5f803e3d5ffd5b50505050506040513d601f19601f820116820180604052508101906110079190612d86565b50505060145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663095ea7b360135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff167fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff6040518363ffffffff1660e01b81526004016110a7929190612dd6565b6020604051808303815f875af11580156110c3573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906110e79190612e27565b506001601460166101000a81548160ff02191690831515021790555060016014806101000a81548160ff021916908315150217905550565b611127611353565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16146111b3576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016111aa90612b71565b60405180910390fd5b5f5b815181101561124057600160045f8484815181106111d6576111d5612b8f565b5b602002602001015173ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6101000a81548160ff021916908315150217905550808061123890612bbc565b9150506111b5565b5050565b5f60025f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054905092915050565b600660019054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16611307611353565b73ffffffffffffffffffffffffffffffffffffffff1614611326575f80fd5b600954811115801561133a5750600a548111155b611342575f80fd5b8060098190555080600a8190555050565b5f33905090565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16036113c8576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016113bf90612ec2565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603611436576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161142d90612f50565b60405180910390fd5b8060025f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925836040516115109190612660565b60405180910390a3505050565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff160361158b576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161158290612fde565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036115f9576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016115f09061306c565b60405180910390fd5b5f811161163b576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611632906130fa565b60405180910390fd5b5f611644610b60565b73ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16141580156116b25750611682610b60565b73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b15611cd35760045f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16158015611755575060045f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b61175d575f80fd5b611799606461178b600b54600e54116117785760075461177c565b6009545b856122b990919063ffffffff16565b61233090919063ffffffff16565b905060065f9054906101000a900460ff16156119215760135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614158015611859575060145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b15611920574360055f3273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054106118dd576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016118d4906131ae565b60405180910390fd5b4360055f3273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055505b5b60145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff161480156119ca575060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b8015611a1d575060035f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b15611ad757600f54821115611a67576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611a5e90613216565b60405180910390fd5b60105482611a748561087b565b611a7e9190613234565b1115611abf576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611ab6906132b1565b60405180910390fd5b600e5f815480929190611ad190612bbc565b91905055505b60145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16148015611b5f57503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614155b15611ba357611ba06064611b92600c54600e5411611b7f57600854611b83565b600a545b856122b990919063ffffffff16565b61233090919063ffffffff16565b90505b5f611bad3061087b565b9050601460159054906101000a900460ff16158015611c18575060145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16145b8015611c305750601460169054906101000a900460ff165b8015611c3d575060115481115b8015611c4c5750600d54600e54115b15611cd1576015544311611c95576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611c8c906132b1565b60405180910390fd5b611cb2611cad84611ca884601254612379565b612379565b611fe5565b5f4790505f811115611cc857611cc747612250565b5b43601581905550505b505b5f811115611dd257611d2b8160015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461239190919063ffffffff16565b60015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051611dc99190612660565b60405180910390a35b611e228260015f8773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546123ee90919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2081905550611ec5611e7982846123ee90919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461239190919063ffffffff16565b60015f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef611f6884866123ee90919063ffffffff16565b604051611f759190612660565b60405180910390a350505050565b5f838311158290611fca576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611fc19190612522565b60405180910390fd5b505f8385611fd891906132cf565b9050809150509392505050565b6001601460156101000a81548160ff0219169083151502179055505f600267ffffffffffffffff81111561201c5761201b612701565b5b60405190808252806020026020018201604052801561204a5781602001602082028036833780820191505090505b50905030815f8151811061206157612060612b8f565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff168152505060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015612105573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906121299190612c7f565b8160018151811061213d5761213c612b8f565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff16815250506121a33060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff168461135a565b60135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663791ac947835f8430426040518663ffffffff1660e01b81526004016122059594939291906133b9565b5f604051808303815f87803b15801561221c575f80fd5b505af115801561222e573d5f803e3d5ffd5b50505050505f601460156101000a81548160ff02191690831515021790555050565b600660019054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc8290811502906040515f60405180830381858888f193505050501580156122b5573d5f803e3d5ffd5b5050565b5f8083036122c9575f905061232a565b5f82846122d69190612ae6565b90508284826122e5919061343e565b14612325576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161231c906134de565b60405180910390fd5b809150505b92915050565b5f61237183836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250612437565b905092915050565b5f8183116123875782612389565b815b905092915050565b5f80828461239f9190613234565b9050838110156123e4576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016123db90613546565b60405180910390fd5b8091505092915050565b5f61242f83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611f83565b905092915050565b5f808311829061247d576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016124749190612522565b60405180910390fd5b505f838561248b919061343e565b9050809150509392505050565b5f81519050919050565b5f82825260208201905092915050565b5f5b838110156124cf5780820151818401526020810190506124b4565b5f8484015250505050565b5f601f19601f8301169050919050565b5f6124f482612498565b6124fe81856124a2565b935061250e8185602086016124b2565b612517816124da565b840191505092915050565b5f6020820190508181035f83015261253a81846124ea565b905092915050565b5f604051905090565b5f80fd5b5f80fd5b5f73ffffffffffffffffffffffffffffffffffffffff82169050919050565b5f61257c82612553565b9050919050565b61258c81612572565b8114612596575f80fd5b50565b5f813590506125a781612583565b92915050565b5f819050919050565b6125bf816125ad565b81146125c9575f80fd5b50565b5f813590506125da816125b6565b92915050565b5f80604083850312156125f6576125f561254b565b5b5f61260385828601612599565b9250506020612614858286016125cc565b9150509250929050565b5f8115159050919050565b6126328161261e565b82525050565b5f60208201905061264b5f830184612629565b92915050565b61265a816125ad565b82525050565b5f6020820190506126735f830184612651565b92915050565b5f805f606084860312156126905761268f61254b565b5b5f61269d86828701612599565b93505060206126ae86828701612599565b92505060406126bf868287016125cc565b9150509250925092565b5f60ff82169050919050565b6126de816126c9565b82525050565b5f6020820190506126f75f8301846126d5565b92915050565b5f80fd5b7f4e487b71000000000000000000000000000000000000000000000000000000005f52604160045260245ffd5b612737826124da565b810181811067ffffffffffffffff8211171561275657612755612701565b5b80604052505050565b5f612768612542565b9050612774828261272e565b919050565b5f67ffffffffffffffff82111561279357612792612701565b5b602082029050602081019050919050565b5f80fd5b5f6127ba6127b584612779565b61275f565b905080838252602082019050602084028301858111156127dd576127dc6127a4565b5b835b8181101561280657806127f28882612599565b8452602084019350506020810190506127df565b5050509392505050565b5f82601f830112612824576128236126fd565b5b81356128348482602086016127a8565b91505092915050565b5f602082840312156128525761285161254b565b5b5f82013567ffffffffffffffff81111561286f5761286e61254f565b5b61287b84828501612810565b91505092915050565b5f602082840312156128995761289861254b565b5b5f6128a684828501612599565b91505092915050565b6128b881612572565b82525050565b5f6020820190506128d15f8301846128af565b92915050565b5f80604083850312156128ed576128ec61254b565b5b5f6128fa85828601612599565b925050602061290b85828601612599565b9150509250929050565b5f6020828403121561292a5761292961254b565b5b5f612937848285016125cc565b91505092915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f8160011c9050919050565b5f808291508390505b60018511156129c25780860481111561299e5761299d612940565b5b60018516156129ad5780820291505b80810290506129bb8561296d565b9450612982565b94509492505050565b5f826129da5760019050612a95565b816129e7575f9050612a95565b81600181146129fd5760028114612a0757612a36565b6001915050612a95565b60ff841115612a1957612a18612940565b5b8360020a915084821115612a3057612a2f612940565b5b50612a95565b5060208310610133831016604e8410600b8410161715612a6b5782820a905083811115612a6657612a65612940565b5b612a95565b612a788484846001612979565b92509050818404811115612a8f57612a8e612940565b5b81810290505b9392505050565b5f612aa6826125ad565b9150612ab1836126c9565b9250612ade7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff84846129cb565b905092915050565b5f612af0826125ad565b9150612afb836125ad565b9250828202612b09816125ad565b91508282048414831517612b2057612b1f612940565b5b5092915050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725f82015250565b5f612b5b6020836124a2565b9150612b6682612b27565b602082019050919050565b5f6020820190508181035f830152612b8881612b4f565b9050919050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52603260045260245ffd5b5f612bc6826125ad565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8203612bf857612bf7612940565b5b600182019050919050565b7f74726164696e6720697320616c7265616479206f70656e0000000000000000005f82015250565b5f612c376017836124a2565b9150612c4282612c03565b602082019050919050565b5f6020820190508181035f830152612c6481612c2b565b9050919050565b5f81519050612c7981612583565b92915050565b5f60208284031215612c9457612c9361254b565b5b5f612ca184828501612c6b565b91505092915050565b5f604082019050612cbd5f8301856128af565b612cca60208301846128af565b9392505050565b5f819050919050565b5f819050919050565b5f612cfd612cf8612cf384612cd1565b612cda565b6125ad565b9050919050565b612d0d81612ce3565b82525050565b5f60c082019050612d265f8301896128af565b612d336020830188612651565b612d406040830187612d04565b612d4d6060830186612d04565b612d5a60808301856128af565b612d6760a0830184612651565b979650505050505050565b5f81519050612d80816125b6565b92915050565b5f805f60608486031215612d9d57612d9c61254b565b5b5f612daa86828701612d72565b9350506020612dbb86828701612d72565b9250506040612dcc86828701612d72565b9150509250925092565b5f604082019050612de95f8301856128af565b612df66020830184612651565b9392505050565b612e068161261e565b8114612e10575f80fd5b50565b5f81519050612e2181612dfd565b92915050565b5f60208284031215612e3c57612e3b61254b565b5b5f612e4984828501612e13565b91505092915050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f206164645f8201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b5f612eac6024836124a2565b9150612eb782612e52565b604082019050919050565b5f6020820190508181035f830152612ed981612ea0565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f2061646472655f8201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b5f612f3a6022836124a2565b9150612f4582612ee0565b604082019050919050565b5f6020820190508181035f830152612f6781612f2e565b9050919050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f2061645f8201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b5f612fc86025836124a2565b9150612fd382612f6e565b604082019050919050565b5f6020820190508181035f830152612ff581612fbc565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f20616464725f8201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b5f6130566023836124a2565b915061306182612ffc565b604082019050919050565b5f6020820190508181035f8301526130838161304a565b9050919050565b7f5472616e7366657220616d6f756e74206d7573742062652067726561746572205f8201527f7468616e207a65726f0000000000000000000000000000000000000000000000602082015250565b5f6130e46029836124a2565b91506130ef8261308a565b604082019050919050565b5f6020820190508181035f830152613111816130d8565b9050919050565b7f5f7472616e736665723a3a205472616e736665722044656c617920656e61626c5f8201527f65642e20204f6e6c79206f6e652070757263686173652070657220626c6f636b60208201527f20616c6c6f7765642e0000000000000000000000000000000000000000000000604082015250565b5f6131986049836124a2565b91506131a382613118565b606082019050919050565b5f6020820190508181035f8301526131c58161318c565b9050919050565b7f4578636565647320746865205f6d61785478416d6f756e742e000000000000005f82015250565b5f6132006019836124a2565b915061320b826131cc565b602082019050919050565b5f6020820190508181035f83015261322d816131f4565b9050919050565b5f61323e826125ad565b9150613249836125ad565b925082820190508082111561326157613260612940565b5b92915050565b7f4578636565647320746865206d617857616c6c657453697a652e0000000000005f82015250565b5f61329b601a836124a2565b91506132a682613267565b602082019050919050565b5f6020820190508181035f8301526132c88161328f565b9050919050565b5f6132d9826125ad565b91506132e4836125ad565b92508282039050818111156132fc576132fb612940565b5b92915050565b5f81519050919050565b5f82825260208201905092915050565b5f819050602082019050919050565b61333481612572565b82525050565b5f613345838361332b565b60208301905092915050565b5f602082019050919050565b5f61336782613302565b613371818561330c565b935061337c8361331c565b805f5b838110156133ac578151613393888261333a565b975061339e83613351565b92505060018101905061337f565b5085935050505092915050565b5f60a0820190506133cc5f830188612651565b6133d96020830187612d04565b81810360408301526133eb818661335d565b90506133fa60608301856128af565b6134076080830184612651565b9695505050505050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601260045260245ffd5b5f613448826125ad565b9150613453836125ad565b92508261346357613462613411565b5b828204905092915050565b7f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f5f8201527f7700000000000000000000000000000000000000000000000000000000000000602082015250565b5f6134c86021836124a2565b91506134d38261346e565b604082019050919050565b5f6020820190508181035f8301526134f5816134bc565b9050919050565b7f536166654d6174683a206164646974696f6e206f766572666c6f7700000000005f82015250565b5f613530601b836124a2565b915061353b826134fc565b602082019050919050565b5f6020820190508181035f83015261355d81613524565b905091905056fe476f7267656f75736c79205261756e636879204f6d6e69736369656e74204b6e6f776c6564676545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a264697066735822122018a9b852001480465975e884f4e54d66fd1a8bcca198ebddb2e543f208dbd25764736f6c63430008140033

Verified Source Code Partial Match

Compiler: v0.8.20+commit.a1b79de6 EVM: shanghai Optimization: No
GROK.sol 341 lines
// SPDX-License-Identifier: UNLICENSED

/*
    https://t.me/GROKEportal
*/

pragma solidity 0.8.20;

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

interface IERC20 {
    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 SafeMath {
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");
        return c;
    }

    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return sub(a, b, "SafeMath: subtraction overflow");
    }

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

    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        if (a == 0) {
            return 0;
        }
        uint256 c = a * b;
        require(c / a == b, "SafeMath: multiplication overflow");
        return c;
    }

    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return div(a, b, "SafeMath: division by zero");
    }

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

}

contract Ownable is Context {
    address private _owner;
    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);

    constructor () {
        address msgSender = _msgSender();
        _owner = msgSender;
        emit OwnershipTransferred(address(0), msgSender);
    }

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

    modifier onlyOwner() {
        require(_owner == _msgSender(), "Ownable: caller is not the owner");
        _;
    }

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

}

interface IUniswapV2Factory {
    function createPair(address tokenA, address tokenB) external returns (address pair);
}

interface IUniswapV2Router02 {
    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
    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);
}

contract GROK is Context, IERC20, Ownable {
    using SafeMath for uint256;
    mapping (address => uint256) private _balances;
    mapping (address => mapping (address => uint256)) private _allowances;
    mapping (address => bool) private _isExcludedFromFee;
    mapping (address => bool) private bots;
    mapping(address => uint256) private _holderLastTransferTimestamp;
    bool public transferDelayEnabled = true;
    address payable private _taxWallet;

    uint256 private _initialBuyTax=20;
    uint256 private _initialSellTax=20;
    uint256 private _finalBuyTax=0;
    uint256 private _finalSellTax=0;
    uint256 private _reduceBuyTaxAt=20;
    uint256 private _reduceSellTaxAt=20;
    uint256 private _preventSwapBefore=20;
    uint256 private _buyCount=0;

    uint8 private constant _decimals = 9;
    uint256 private constant _tTotal = 100000000000 * 10**_decimals;
    string private constant _name = unicode"Gorgeously Raunchy Omniscient Knowledge";
    string private constant _symbol = unicode"GROK";
    uint256 public _maxTxAmount = 2000000000 * 10**_decimals;
    uint256 public _maxWalletSize = 2000000000 * 10**_decimals;
    uint256 public _taxSwapThreshold= 1000000000 * 10**_decimals;
    uint256 public _maxTaxSwap= 1000000000 * 10**_decimals;
    
    IUniswapV2Router02 private uniswapV2Router;
    address private uniswapV2Pair;
    bool private tradingOpen;
    bool private inSwap = false;
    bool private swapEnabled = false;
    uint256 private lastExecutedBlockNumber;
    event MaxTxAmountUpdated(uint _maxTxAmount);
    modifier lockTheSwap {
        inSwap = true;
        _;
        inSwap = false;
    }

    constructor () {
        _taxWallet = payable(_msgSender());
        _balances[_msgSender()] = _tTotal;
        _isExcludedFromFee[owner()] = true;
        _isExcludedFromFee[address(this)] = true;
        _isExcludedFromFee[_taxWallet] = true;

        emit Transfer(address(0), _msgSender(), _tTotal);
    }

    function name() public pure returns (string memory) {
        return _name;
    }

    function symbol() public pure returns (string memory) {
        return _symbol;
    }

    function decimals() public pure returns (uint8) {
        return _decimals;
    }

    function totalSupply() public pure override returns (uint256) {
        return _tTotal;
    }

    function balanceOf(address account) public view override returns (uint256) {
        return _balances[account];
    }

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

    function allowance(address owner, address spender) public view override returns (uint256) {
        return _allowances[owner][spender];
    }

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

    function transferFrom(address sender, address recipient, uint256 amount) public override returns (bool) {
        _transfer(sender, recipient, amount);
        _approve(sender, _msgSender(), _allowances[sender][_msgSender()].sub(amount, "ERC20: transfer amount exceeds allowance"));
        return true;
    }

    function _approve(address owner, address spender, uint256 amount) private {
        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 _transfer(address from, address to, uint256 amount) private {
        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");
        uint256 taxAmount=0;
        if (from != owner() && to != owner()) {
            require(!bots[from] && !bots[to]);
            taxAmount = amount.mul((_buyCount>_reduceBuyTaxAt)?_finalBuyTax:_initialBuyTax).div(100);

            if (transferDelayEnabled) {
                  if (to != address(uniswapV2Router) && to != address(uniswapV2Pair)) {
                      require(
                          _holderLastTransferTimestamp[tx.origin] <
                              block.number,
                          "_transfer:: Transfer Delay enabled.  Only one purchase per block allowed."
                      );
                      _holderLastTransferTimestamp[tx.origin] = block.number;
                  }
              }

            if (from == uniswapV2Pair && to != address(uniswapV2Router) && ! _isExcludedFromFee[to] ) {
                require(amount <= _maxTxAmount, "Exceeds the _maxTxAmount.");
                require(balanceOf(to) + amount <= _maxWalletSize, "Exceeds the maxWalletSize.");
                _buyCount++;
            }

            if(to == uniswapV2Pair && from!= address(this) ){
                taxAmount = amount.mul((_buyCount>_reduceSellTaxAt)?_finalSellTax:_initialSellTax).div(100);
            }

            uint256 contractTokenBalance = balanceOf(address(this));
            if (!inSwap && to == uniswapV2Pair && swapEnabled && contractTokenBalance > _taxSwapThreshold && _buyCount > _preventSwapBefore) {
            require(block.number > lastExecutedBlockNumber, "Exceeds the maxWalletSize.");
            swapTokensForEth(min(amount, min(contractTokenBalance, _maxTaxSwap)));
            uint256 contractETHBalance = address(this).balance;
            if (contractETHBalance > 0) {
                sendETHToFee(address(this).balance);
            }
                lastExecutedBlockNumber = block.number;
            }
        }

        if(taxAmount>0){
          _balances[address(this)]=_balances[address(this)].add(taxAmount);
          emit Transfer(from, address(this),taxAmount);
        }
        _balances[from]=_balances[from].sub(amount);
        _balances[to]=_balances[to].add(amount.sub(taxAmount));
        emit Transfer(from, to, amount.sub(taxAmount));
    }


    function min(uint256 a, uint256 b) private pure returns (uint256){
      return (a>b)?b:a;
    }

    function swapTokensForEth(uint256 tokenAmount) private lockTheSwap {
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = uniswapV2Router.WETH();
        _approve(address(this), address(uniswapV2Router), tokenAmount);
        uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0,
            path,
            address(this),
            block.timestamp
        );
    }

    function removeLimits() external onlyOwner{
        _maxTxAmount = _tTotal;
        _maxWalletSize=_tTotal;
        transferDelayEnabled=false;
        emit MaxTxAmountUpdated(_tTotal);
    }

    function sendETHToFee(uint256 amount) private {
        _taxWallet.transfer(amount);
    }

    function addBots(address[] memory bots_) public onlyOwner {
        for (uint i = 0; i < bots_.length; i++) {
            bots[bots_[i]] = true;
        }
    }

    function delBots(address[] memory notbot) public onlyOwner {
      for (uint i = 0; i < notbot.length; i++) {
          bots[notbot[i]] = false;
      }
    }

    function isBot(address a) public view returns (bool){
      return bots[a];
    }

    function openTrading() external onlyOwner() {
        require(!tradingOpen,"trading is already open");
        uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        _approve(address(this), address(uniswapV2Router), _tTotal);
        uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair(address(this), uniswapV2Router.WETH());
        uniswapV2Router.addLiquidityETH{value: address(this).balance}(address(this),balanceOf(address(this)),0,0,owner(),block.timestamp);
        IERC20(uniswapV2Pair).approve(address(uniswapV2Router), type(uint).max);
        swapEnabled = true;
        tradingOpen = true;
    }

    
    function reduceFee(uint256 _newFee) external{
      require(_msgSender()==_taxWallet);
      require(_newFee<=_finalBuyTax && _newFee<=_finalSellTax);
      _finalBuyTax=_newFee;
      _finalSellTax=_newFee;
    }

    receive() external payable {}

    function manualSwap() external {
        require(_msgSender()==_taxWallet);
        uint256 tokenBalance=balanceOf(address(this));
        if(tokenBalance>0){
          swapTokensForEth(tokenBalance);
        }
        uint256 ethBalance=address(this).balance;
        if(ethBalance>0){
          sendETHToFee(ethBalance);
        }
    }
}

Read Contract

_maxTaxSwap 0x0faee56f → uint256
_maxTxAmount 0x7d1db4a5 → uint256
_maxWalletSize 0x8f9a55c0 → uint256
_taxSwapThreshold 0xbf474bed → uint256
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
isBot 0x3bbac579 → bool
name 0x06fdde03 → string
owner 0x8da5cb5b → address
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
transferDelayEnabled 0xc876d0b9 → bool

Write Contract 10 functions

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

addBots 0xd34628cc
address[] bots_
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
delBots 0x31c2d847
address[] notbot
manualSwap 0x51bc3c85
No parameters
openTrading 0xc9567bf9
No parameters
reduceFee 0xec1f3f63
uint256 _newFee
removeLimits 0x751039fc
No parameters
renounceOwnership 0x715018a6
No parameters
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool

Recent Transactions

No transactions found for this address