Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x5c1D723D9be87494dB06C75fD606f6749Bf0f758
Balance 0 ETH
Nonce 1
Code Size 13751 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

13751 bytes
0x608060405260043610610143575f3560e01c8063715018a6116100b5578063a9059cbb1161006e578063a9059cbb146103fc578063bf474bed14610438578063c9567bf914610462578063dd62ed3e14610478578063ec1f3f63146104b4578063f4293890146104dc5761014a565b8063715018a61461030257806377b54bad146103185780637d1db4a5146103545780638da5cb5b1461037e5780638f9a55c0146103a857806395d89b41146103d25761014a565b806320800a001161010757806320800a001461021e57806323b872dd14610234578063313ce5671461027057806351bc3c851461029a57806362256589146102b057806370a08231146102c65761014a565b806306fdde031461014e578063095ea7b3146101785780630faee56f146101b4578063109daa99146101de57806318160ddd146101f45761014a565b3661014a57005b5f80fd5b348015610159575f80fd5b506101626104f2565b60405161016f9190612517565b60405180910390f35b348015610183575f80fd5b5061019e600480360381019061019991906125c8565b61052f565b6040516101ab9190612620565b60405180910390f35b3480156101bf575f80fd5b506101c861054c565b6040516101d59190612648565b60405180910390f35b3480156101e9575f80fd5b506101f2610552565b005b3480156101ff575f80fd5b50610208610626565b6040516102159190612648565b60405180910390f35b348015610229575f80fd5b50610232610649565b005b34801561023f575f80fd5b5061025a60048036038101906102559190612661565b61070f565b6040516102679190612620565b60405180910390f35b34801561027b575f80fd5b506102846107e3565b60405161029191906126cc565b60405180910390f35b3480156102a5575f80fd5b506102ae6107eb565b005b3480156102bb575f80fd5b506102c4610882565b005b3480156102d1575f80fd5b506102ec60048036038101906102e791906126e5565b6109b1565b6040516102f99190612648565b60405180910390f35b34801561030d575f80fd5b506103166109f7565b005b348015610323575f80fd5b5061033e600480360381019061033991906125c8565b610b45565b60405161034b9190612620565b60405180910390f35b34801561035f575f80fd5b50610368610d04565b6040516103759190612648565b60405180910390f35b348015610389575f80fd5b50610392610d0a565b60405161039f919061271f565b60405180910390f35b3480156103b3575f80fd5b506103bc610d31565b6040516103c99190612648565b60405180910390f35b3480156103dd575f80fd5b506103e6610d37565b6040516103f39190612517565b60405180910390f35b348015610407575f80fd5b50610422600480360381019061041d91906125c8565b610d74565b60405161042f9190612620565b60405180910390f35b348015610443575f80fd5b5061044c610d91565b6040516104599190612648565b60405180910390f35b34801561046d575f80fd5b50610476610d97565b005b348015610483575f80fd5b5061049e60048036038101906104999190612738565b6112c0565b6040516104ab9190612648565b60405180910390f35b3480156104bf575f80fd5b506104da60048036038101906104d59190612776565b611342565b005b3480156104e7575f80fd5b506104f06113ce565b005b60606040518060400160405280600681526020017f446f6f676c650000000000000000000000000000000000000000000000000000815250905090565b5f61054261053b61147f565b8484611486565b6001905092915050565b60115481565b61055a61147f565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16146105e6576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016105dd906127eb565b60405180910390fd5b5f600c819055507fe9b79e1a6c2dc43b4c0c6ff01ce9e3332d810e482270f464c0a21ad6c5fc6de35f60405161061c919061284b565b60405180910390a1565b5f6009600a61063591906129c0565b633b9aca006106449190612a0a565b905090565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661068961147f565b73ffffffffffffffffffffffffffffffffffffffff16146106a8575f80fd5b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc4790811502906040515f60405180830381858888f1935050505015801561070c573d5f803e3d5ffd5b50565b5f61071b848484611649565b6107d88461072761147f565b6107d38560405180606001604052806028815260200161355a6028913960025f8b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f61078a61147f565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054611f799092919063ffffffff16565b611486565b600190509392505050565b5f6009905090565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661082b61147f565b73ffffffffffffffffffffffffffffffffffffffff161461084a575f80fd5b5f610854306109b1565b90505f8111156108685761086781611fdb565b5b5f4790505f81111561087e5761087d81612246565b5b5050565b61088a61147f565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610916576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161090d906127eb565b60405180910390fd5b6009600a61092491906129c0565b633b9aca006109339190612a0a565b600e819055506009600a61094791906129c0565b633b9aca006109569190612a0a565b600f819055507f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf6009600a61098b91906129c0565b633b9aca0061099a9190612a0a565b6040516109a79190612648565b60405180910390a1565b5f60015f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20549050919050565b6109ff61147f565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610a8b576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610a82906127eb565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35f805f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b5f60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16610b8661147f565b73ffffffffffffffffffffffffffffffffffffffff1614610ba5575f80fd5b5f8203610c27578273ffffffffffffffffffffffffffffffffffffffff166370a08231306040518263ffffffff1660e01b8152600401610be5919061271f565b602060405180830381865afa158015610c00573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610c249190612a5f565b91505b7fda2bc2bedd1f85b5a59d5dbbd6684ff877ef916994a16ec08813101e99ace65f8383604051610c58929190612a8a565b60405180910390a18273ffffffffffffffffffffffffffffffffffffffff1663a9059cbb60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16846040518363ffffffff1660e01b8152600401610cbc929190612b03565b6020604051808303815f875af1158015610cd8573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610cfc9190612b54565b905092915050565b600e5481565b5f805f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b600f5481565b60606040518060400160405280600681526020017f444f4f474c450000000000000000000000000000000000000000000000000000815250905090565b5f610d87610d8061147f565b8484611649565b6001905092915050565b60105481565b610d9f61147f565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610e2b576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610e22906127eb565b60405180910390fd5b601360149054906101000a900460ff1615610e7b576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610e7290612bc9565b60405180910390fd5b737a250d5630b4cf539739df2c5dacb4c659f2488d60125f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550610f173060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff166009600a610f0391906129c0565b633b9aca00610f129190612a0a565b611486565b60125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610f81573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610fa59190612bfb565b73ffffffffffffffffffffffffffffffffffffffff1663c9c653963060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa15801561102b573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061104f9190612bfb565b6040518363ffffffff1660e01b815260040161106c929190612c26565b6020604051808303815f875af1158015611088573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906110ac9190612bfb565b60135f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663f305d7194730611133306109b1565b5f8061113d610d0a565b426040518863ffffffff1660e01b815260040161115f96959493929190612c4d565b60606040518083038185885af115801561117b573d5f803e3d5ffd5b50505050506040513d601f19601f820116820180604052508101906111a09190612cac565b50505060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663095ea7b360125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff167fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff6040518363ffffffff1660e01b8152600401611240929190612a8a565b6020604051808303815f875af115801561125c573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906112809190612b54565b506001601360166101000a81548160ff0219169083151502179055506001601360146101000a81548160ff02191690831515021790555043601681905550565b5f60025f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054905092915050565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661138261147f565b73ffffffffffffffffffffffffffffffffffffffff16146113a1575f80fd5b60075481111580156113b557506008548111155b6113bd575f80fd5b806007819055508060088190555050565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661140e61147f565b73ffffffffffffffffffffffffffffffffffffffff161461142d575f80fd5b5f4790505f8111611473576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161146a90612d6c565b60405180910390fd5b61147c81612246565b50565b5f33905090565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16036114f4576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016114eb90612dfa565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603611562576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161155990612e88565b60405180910390fd5b8060025f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9258360405161163c9190612648565b60405180910390a3505050565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16036116b7576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016116ae90612f16565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603611725576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161171c90612fa4565b60405180910390fd5b5f8111611767576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161175e90613032565b60405180910390fd5b5f611770610d0a565b73ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16141580156117de57506117ae610d0a565b73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b15611cc9575f600d540361182b57611828606461181a600954600d54116118075760055461180b565b6007545b856122ae90919063ffffffff16565b61232590919063ffffffff16565b90505b5f600d5411156118605761185d606461184f600c54856122ae90919063ffffffff16565b61232590919063ffffffff16565b90505b60165443036118af576018600d54106118ae576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016118a59061309a565b60405180910390fd5b5b60135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16148015611958575060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b80156119ab575060035f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b15611aa357600e548211156119f5576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016119ec90613102565b60405180910390fd5b600f5482611a02856109b1565b611a0c9190613120565b1115611a4d576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611a449061319d565b60405180910390fd5b611a896064611a7b600954600d5411611a6857600554611a6c565b6007545b856122ae90919063ffffffff16565b61232590919063ffffffff16565b9050600d5f815480929190611a9d906131bb565b91905055505b60135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16148015611b2b57503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614155b15611b6f57611b6c6064611b5e600a54600d5411611b4b57600654611b4f565b6008545b856122ae90919063ffffffff16565b61232590919063ffffffff16565b90505b5f611b79306109b1565b9050601360159054906101000a900460ff16158015611be4575060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16145b8015611bfc5750601360169054906101000a900460ff165b8015611c09575060105481115b8015611c185750600b54600d54115b15611cc757601554431115611c2f575f6014819055505b600360145410611c74576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611c6b9061324c565b60405180910390fd5b611c91611c8c84611c878460115461236e565b61236e565b611fdb565b5f4790505f811115611ca757611ca647612246565b5b60145f815480929190611cb9906131bb565b919050555043601581905550505b505b5f811115611dc857611d218160015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461238690919063ffffffff16565b60015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051611dbf9190612648565b60405180910390a35b611e188260015f8773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546123e390919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2081905550611ebb611e6f82846123e390919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461238690919063ffffffff16565b60015f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef611f5e84866123e390919063ffffffff16565b604051611f6b9190612648565b60405180910390a350505050565b5f838311158290611fc0576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611fb79190612517565b60405180910390fd5b505f8385611fce919061326a565b9050809150509392505050565b6001601360156101000a81548160ff0219169083151502179055505f600267ffffffffffffffff8111156120125761201161329d565b5b6040519080825280602002602001820160405280156120405781602001602082028036833780820191505090505b50905030815f81518110612057576120566132ca565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff168152505060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa1580156120fb573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061211f9190612bfb565b81600181518110612133576121326132ca565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff16815250506121993060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1684611486565b60125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663791ac947835f8430426040518663ffffffff1660e01b81526004016121fb9594939291906133ae565b5f604051808303815f87803b158015612212575f80fd5b505af1158015612224573d5f803e3d5ffd5b50505050505f601360156101000a81548160ff02191690831515021790555050565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc8290811502906040515f60405180830381858888f193505050501580156122aa573d5f803e3d5ffd5b5050565b5f8083036122be575f905061231f565b5f82846122cb9190612a0a565b90508284826122da9190613433565b1461231a576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612311906134d3565b60405180910390fd5b809150505b92915050565b5f61236683836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f00000000000081525061242c565b905092915050565b5f81831161237c578261237e565b815b905092915050565b5f8082846123949190613120565b9050838110156123d9576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016123d09061353b565b60405180910390fd5b8091505092915050565b5f61242483836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611f79565b905092915050565b5f8083118290612472576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016124699190612517565b60405180910390fd5b505f83856124809190613433565b9050809150509392505050565b5f81519050919050565b5f82825260208201905092915050565b5f5b838110156124c45780820151818401526020810190506124a9565b5f8484015250505050565b5f601f19601f8301169050919050565b5f6124e98261248d565b6124f38185612497565b93506125038185602086016124a7565b61250c816124cf565b840191505092915050565b5f6020820190508181035f83015261252f81846124df565b905092915050565b5f80fd5b5f73ffffffffffffffffffffffffffffffffffffffff82169050919050565b5f6125648261253b565b9050919050565b6125748161255a565b811461257e575f80fd5b50565b5f8135905061258f8161256b565b92915050565b5f819050919050565b6125a781612595565b81146125b1575f80fd5b50565b5f813590506125c28161259e565b92915050565b5f80604083850312156125de576125dd612537565b5b5f6125eb85828601612581565b92505060206125fc858286016125b4565b9150509250929050565b5f8115159050919050565b61261a81612606565b82525050565b5f6020820190506126335f830184612611565b92915050565b61264281612595565b82525050565b5f60208201905061265b5f830184612639565b92915050565b5f805f6060848603121561267857612677612537565b5b5f61268586828701612581565b935050602061269686828701612581565b92505060406126a7868287016125b4565b9150509250925092565b5f60ff82169050919050565b6126c6816126b1565b82525050565b5f6020820190506126df5f8301846126bd565b92915050565b5f602082840312156126fa576126f9612537565b5b5f61270784828501612581565b91505092915050565b6127198161255a565b82525050565b5f6020820190506127325f830184612710565b92915050565b5f806040838503121561274e5761274d612537565b5b5f61275b85828601612581565b925050602061276c85828601612581565b9150509250929050565b5f6020828403121561278b5761278a612537565b5b5f612798848285016125b4565b91505092915050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725f82015250565b5f6127d5602083612497565b91506127e0826127a1565b602082019050919050565b5f6020820190508181035f830152612802816127c9565b9050919050565b5f819050919050565b5f819050919050565b5f61283561283061282b84612809565b612812565b612595565b9050919050565b6128458161281b565b82525050565b5f60208201905061285e5f83018461283c565b92915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f8160011c9050919050565b5f808291508390505b60018511156128e6578086048111156128c2576128c1612864565b5b60018516156128d15780820291505b80810290506128df85612891565b94506128a6565b94509492505050565b5f826128fe57600190506129b9565b8161290b575f90506129b9565b8160018114612921576002811461292b5761295a565b60019150506129b9565b60ff84111561293d5761293c612864565b5b8360020a91508482111561295457612953612864565b5b506129b9565b5060208310610133831016604e8410600b841016171561298f5782820a90508381111561298a57612989612864565b5b6129b9565b61299c848484600161289d565b925090508184048111156129b3576129b2612864565b5b81810290505b9392505050565b5f6129ca82612595565b91506129d5836126b1565b9250612a027fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff84846128ef565b905092915050565b5f612a1482612595565b9150612a1f83612595565b9250828202612a2d81612595565b91508282048414831517612a4457612a43612864565b5b5092915050565b5f81519050612a598161259e565b92915050565b5f60208284031215612a7457612a73612537565b5b5f612a8184828501612a4b565b91505092915050565b5f604082019050612a9d5f830185612710565b612aaa6020830184612639565b9392505050565b5f612acb612ac6612ac18461253b565b612812565b61253b565b9050919050565b5f612adc82612ab1565b9050919050565b5f612aed82612ad2565b9050919050565b612afd81612ae3565b82525050565b5f604082019050612b165f830185612af4565b612b236020830184612639565b9392505050565b612b3381612606565b8114612b3d575f80fd5b50565b5f81519050612b4e81612b2a565b92915050565b5f60208284031215612b6957612b68612537565b5b5f612b7684828501612b40565b91505092915050565b7f74726164696e6720697320616c7265616479206f70656e0000000000000000005f82015250565b5f612bb3601783612497565b9150612bbe82612b7f565b602082019050919050565b5f6020820190508181035f830152612be081612ba7565b9050919050565b5f81519050612bf58161256b565b92915050565b5f60208284031215612c1057612c0f612537565b5b5f612c1d84828501612be7565b91505092915050565b5f604082019050612c395f830185612710565b612c466020830184612710565b9392505050565b5f60c082019050612c605f830189612710565b612c6d6020830188612639565b612c7a604083018761283c565b612c87606083018661283c565b612c946080830185612710565b612ca160a0830184612639565b979650505050505050565b5f805f60608486031215612cc357612cc2612537565b5b5f612cd086828701612a4b565b9350506020612ce186828701612a4b565b9250506040612cf286828701612a4b565b9150509250925092565b7f436f6e74726163742062616c616e6365206d75737420626520677265617465725f8201527f207468616e207a65726f00000000000000000000000000000000000000000000602082015250565b5f612d56602a83612497565b9150612d6182612cfc565b604082019050919050565b5f6020820190508181035f830152612d8381612d4a565b9050919050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f206164645f8201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b5f612de4602483612497565b9150612def82612d8a565b604082019050919050565b5f6020820190508181035f830152612e1181612dd8565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f2061646472655f8201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b5f612e72602283612497565b9150612e7d82612e18565b604082019050919050565b5f6020820190508181035f830152612e9f81612e66565b9050919050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f2061645f8201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b5f612f00602583612497565b9150612f0b82612ea6565b604082019050919050565b5f6020820190508181035f830152612f2d81612ef4565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f20616464725f8201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b5f612f8e602383612497565b9150612f9982612f34565b604082019050919050565b5f6020820190508181035f830152612fbb81612f82565b9050919050565b7f5472616e7366657220616d6f756e74206d7573742062652067726561746572205f8201527f7468616e207a65726f0000000000000000000000000000000000000000000000602082015250565b5f61301c602983612497565b915061302782612fc2565b604082019050919050565b5f6020820190508181035f83015261304981613010565b9050919050565b7f457863656564732062757973206f6e2074686520666972737420626c6f636b2e5f82015250565b5f613084602083612497565b915061308f82613050565b602082019050919050565b5f6020820190508181035f8301526130b181613078565b9050919050565b7f4578636565647320746865205f6d61785478416d6f756e742e000000000000005f82015250565b5f6130ec601983612497565b91506130f7826130b8565b602082019050919050565b5f6020820190508181035f830152613119816130e0565b9050919050565b5f61312a82612595565b915061313583612595565b925082820190508082111561314d5761314c612864565b5b92915050565b7f4578636565647320746865206d617857616c6c657453697a652e0000000000005f82015250565b5f613187601a83612497565b915061319282613153565b602082019050919050565b5f6020820190508181035f8301526131b48161317b565b9050919050565b5f6131c582612595565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff82036131f7576131f6612864565b5b600182019050919050565b7f4f6e6c7920332073656c6c732070657220626c6f636b210000000000000000005f82015250565b5f613236601783612497565b915061324182613202565b602082019050919050565b5f6020820190508181035f8301526132638161322a565b9050919050565b5f61327482612595565b915061327f83612595565b925082820390508181111561329757613296612864565b5b92915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52604160045260245ffd5b7f4e487b71000000000000000000000000000000000000000000000000000000005f52603260045260245ffd5b5f81519050919050565b5f82825260208201905092915050565b5f819050602082019050919050565b6133298161255a565b82525050565b5f61333a8383613320565b60208301905092915050565b5f602082019050919050565b5f61335c826132f7565b6133668185613301565b935061337183613311565b805f5b838110156133a1578151613388888261332f565b975061339383613346565b925050600181019050613374565b5085935050505092915050565b5f60a0820190506133c15f830188612639565b6133ce602083018761283c565b81810360408301526133e08186613352565b90506133ef6060830185612710565b6133fc6080830184612639565b9695505050505050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601260045260245ffd5b5f61343d82612595565b915061344883612595565b92508261345857613457613406565b5b828204905092915050565b7f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f5f8201527f7700000000000000000000000000000000000000000000000000000000000000602082015250565b5f6134bd602183612497565b91506134c882613463565b604082019050919050565b5f6020820190508181035f8301526134ea816134b1565b9050919050565b7f536166654d6174683a206164646974696f6e206f766572666c6f7700000000005f82015250565b5f613525601b83612497565b9150613530826134f1565b602082019050919050565b5f6020820190508181035f83015261355281613519565b905091905056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a264697066735822122043c2a39f9891f05659151cd981b034117779548d459781218bc073516ff36ae964736f6c63430008170033

Verified Source Code Partial Match

Compiler: v0.8.23+commit.f704f362 EVM: shanghai Optimization: No
Doogle.sol 370 lines
// SPDX-License-Identifier: UNLICENSE

/*

Matt furies first ever dog character.


https://t.me/DoogleOnEth
https://x.com/Doodleonerc20
http://doogleonerc.club
https://medium.com/@doogleoneth
*/

pragma solidity 0.8.23;

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 Doogle 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;
    address payable private _taxWallet;

    uint256 private _initialBuyTax = 19;
    uint256 private _initialSellTax = 20;
    uint256 private _finalBuyTax = 0;
    uint256 private _finalSellTax = 0;
    uint256 private _reduceBuyTaxAt = 30;
    uint256 private _reduceSellTaxAt = 31;
    uint256 private _preventSwapBefore = 32;
    uint256 private _transferTax = 0;
    uint256 private _buyCount = 0;

    uint8 private constant _decimals = 9;
    uint256 private constant _tTotal = 1_000_000_000 * 10**_decimals;
    string private constant _name = unicode"Doogle"; //Matt furies first ever dog
    string private constant _symbol = unicode"DOOGLE";
    uint256 public _maxTxAmount= (_tTotal * 2) / 100;
    uint256 public _maxWalletSize= (_tTotal * 2) / 100;
    uint256 public _taxSwapThreshold= (_tTotal * 1) / 1000;
    uint256 public _maxTaxSwap= (_tTotal * 12) / 1000;
    
    IUniswapV2Router02 private uniswapV2Router;
    address private uniswapV2Pair;
    bool private tradingOpen;
    bool private inSwap= false;
    bool private swapEnabled= false;
    uint256 private sellCount= 0;
    uint256 private lastSellBlock= 0;
    uint256 private firstBlock= 0;
    event MaxTxAmountUpdated(uint _maxTxAmount);
    event TransferTaxUpdated(uint _tax);
    event ClearToken(address TokenAddressCleared, uint256 Amount);
    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()) {

            if(_buyCount == 0){
                taxAmount = amount.mul((_buyCount > _reduceBuyTaxAt) ? _finalBuyTax : _initialBuyTax).div(100);
            }

            if(_buyCount > 0){
                taxAmount =amount.mul(_transferTax).div(100);
            }

            if(block.number == firstBlock){
                require(_buyCount<24, "Exceeds buys on the first block.");
            }

            if (from == uniswapV2Pair && to != address(uniswapV2Router) && ! _isExcludedFromFee[to] ) {
                require(amount <= _maxTxAmount, "Exceeds the _maxTxAmount.");
                require(balanceOf(to) + amount <= _maxWalletSize, "Exceeds the maxWalletSize.");
                taxAmount = amount.mul((_buyCount > _reduceBuyTaxAt) ? _finalBuyTax : _initialBuyTax).div(100);
                _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) {
                if (block.number>lastSellBlock) {
                    sellCount = 0;
                }
                require(sellCount < 3, "Only 3 sells per block!");

                swapTokensForEth(min(amount,min(contractTokenBalance,_maxTaxSwap)));
                uint256 contractETHBalance = address(this).balance;
                if (contractETHBalance>0) {
                    sendETHToFee(address(this).balance);
                }

                sellCount++;
                lastSellBlock =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 removeLimit() external onlyOwner{
        _maxTxAmount =_tTotal;
        _maxWalletSize =_tTotal;
        emit MaxTxAmountUpdated(_tTotal);
    }

    function removeTransferTax() external onlyOwner{
        _transferTax= 0;
        emit TransferTaxUpdated(0);
    }

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

    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;
        firstBlock =block.number;
    }

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

      _finalBuyTax =_newFee;
      _finalSellTax =_newFee;
    }

    function clearStuckToken(address tokenAddress, uint256 tokens) external returns (bool success) {
        require(_msgSender() == _taxWallet);

        if(tokens == 0){
            tokens = IERC20(tokenAddress).balanceOf(address(this));
        }

        emit ClearToken(tokenAddress,tokens);
        return IERC20(tokenAddress).transfer(_taxWallet, tokens);
    }
    
    function rescueETH() external {
        require(_msgSender() == _taxWallet);
        payable(_taxWallet).transfer(address(this).balance);
    }

    function manualSend() external {
        require(_msgSender() == _taxWallet);

        uint256 ethBalance= address(this).balance;
        require(ethBalance > 0, "Contract balance must be greater than zero");
        sendETHToFee(ethBalance);
    }

    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
name 0x06fdde03 → string
owner 0x8da5cb5b → address
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256

Write Contract 12 functions

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

approve 0x095ea7b3
address spender
uint256 amount
returns: bool
clearStuckToken 0x77b54bad
address tokenAddress
uint256 tokens
returns: bool
manualSend 0xf4293890
No parameters
manualSwap 0x51bc3c85
No parameters
openTrading 0xc9567bf9
No parameters
reduceFee 0xec1f3f63
uint256 _newFee
removeLimit 0x62256589
No parameters
removeTransferTax 0x109daa99
No parameters
renounceOwnership 0x715018a6
No parameters
rescueETH 0x20800a00
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