Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0xf1184fe0dd5d4Aa7cF64Fa42fd9F2668C7b036dA
Balance 0 ETH
Nonce 1
Code Size 14247 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

14247 bytes
0x608060405260043610610169575f3560e01c806370a08231116100d05780638f9a55c011610089578063bf474bed11610063578063bf474bed146104d6578063c9567bf914610500578063d34628cc14610516578063dd62ed3e1461053e57610170565b80638f9a55c01461044657806395d89b4114610470578063a9059cbb1461049a57610170565b806370a0823114610362578063715018a61461039e578063751039fc146103b457806376b2fa71146103ca5780637d1db4a5146103f25780638da5cb5b1461041c57610170565b806323b872dd1161012257806323b872dd1461025a5780632c65469e14610296578063313ce567146102be57806331c2d847146102e85780633bbac5791461031057806351bc3c851461034c57610170565b80630150fe4c1461017457806306fdde031461018a578063095ea7b3146101b45780630faee56f146101f0578063109daa991461021a57806318160ddd1461023057610170565b3661017057005b5f80fd5b34801561017f575f80fd5b5061018861057a565b005b348015610195575f80fd5b5061019e6105e9565b6040516101ab9190612697565b60405180910390f35b3480156101bf575f80fd5b506101da60048036038101906101d59190612755565b610609565b6040516101e791906127ad565b60405180910390f35b3480156101fb575f80fd5b50610204610626565b60405161021191906127d5565b60405180910390f35b348015610225575f80fd5b5061022e61062c565b005b34801561023b575f80fd5b50610244610700565b60405161025191906127d5565b60405180910390f35b348015610265575f80fd5b50610280600480360381019061027b91906127ee565b610723565b60405161028d91906127ad565b60405180910390f35b3480156102a1575f80fd5b506102bc60048036038101906102b79190612755565b6107f7565b005b3480156102c9575f80fd5b506102d26108f7565b6040516102df9190612859565b60405180910390f35b3480156102f3575f80fd5b5061030e600480360381019061030991906129b2565b6108ff565b005b34801561031b575f80fd5b50610336600480360381019061033191906129f9565b610a1d565b60405161034391906127ad565b60405180910390f35b348015610357575f80fd5b50610360610a6f565b005b34801561036d575f80fd5b50610388600480360381019061038391906129f9565b610b06565b60405161039591906127d5565b60405180910390f35b3480156103a9575f80fd5b506103b2610b4c565b005b3480156103bf575f80fd5b506103c8610c9a565b005b3480156103d5575f80fd5b506103f060048036038101906103eb9190612a24565b610dc9565b005b3480156103fd575f80fd5b50610406610e55565b60405161041391906127d5565b60405180910390f35b348015610427575f80fd5b50610430610e5b565b60405161043d9190612a5e565b60405180910390f35b348015610451575f80fd5b5061045a610e82565b60405161046791906127d5565b60405180910390f35b34801561047b575f80fd5b50610484610e88565b6040516104919190612697565b60405180910390f35b3480156104a5575f80fd5b506104c060048036038101906104bb9190612755565b610ec5565b6040516104cd91906127ad565b60405180910390f35b3480156104e1575f80fd5b506104ea610ee2565b6040516104f791906127d5565b60405180910390f35b34801561050b575f80fd5b50610514610ee8565b005b348015610521575f80fd5b5061053c600480360381019061053791906129b2565b611407565b005b348015610549575f80fd5b50610564600480360381019061055f9190612a77565b611526565b60405161057191906127d5565b60405180910390f35b60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166105ba6115a8565b73ffffffffffffffffffffffffffffffffffffffff16146105d9575f80fd5b5f4790506105e6816115af565b50565b60606040518060600160405280602a8152602001613720602a9139905090565b5f61061c6106156115a8565b8484611617565b6001905092915050565b60125481565b6106346115a8565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16146106c0576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016106b790612aff565b60405180910390fd5b5f600d819055507fe9b79e1a6c2dc43b4c0c6ff01ce9e3332d810e482270f464c0a21ad6c5fc6de35f6040516106f69190612b5f565b60405180910390a1565b5f6009600a61070f9190612cd4565b633b9aca0061071e9190612d1e565b905090565b5f61072f8484846117da565b6107ec8461073b6115a8565b6107e78560405180606001604052806028815260200161374a6028913960025f8b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f61079e6115a8565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546121619092919063ffffffff16565b611617565b600190509392505050565b60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108376115a8565b73ffffffffffffffffffffffffffffffffffffffff1614610856575f80fd5b8173ffffffffffffffffffffffffffffffffffffffff1663a9059cbb60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16836040518363ffffffff1660e01b81526004016108b2929190612db1565b6020604051808303815f875af11580156108ce573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906108f29190612e02565b505050565b5f6009905090565b6109076115a8565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610993576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161098a90612aff565b60405180910390fd5b5f5b8151811015610a19575f60045f8484815181106109b5576109b4612e2d565b5b602002602001015173ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6101000a81548160ff0219169083151502179055508080600101915050610995565b5050565b5f60045f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff169050919050565b60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16610aaf6115a8565b73ffffffffffffffffffffffffffffffffffffffff1614610ace575f80fd5b5f610ad830610b06565b90505f811115610aec57610aeb816121c3565b5b5f4790505f811115610b0257610b01816115af565b5b5050565b5f60015f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20549050919050565b610b546115a8565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610be0576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610bd790612aff565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35f805f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b610ca26115a8565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610d2e576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610d2590612aff565b60405180910390fd5b6009600a610d3c9190612cd4565b633b9aca00610d4b9190612d1e565b600f819055506009600a610d5f9190612cd4565b633b9aca00610d6e9190612d1e565b6010819055507f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf6009600a610da39190612cd4565b633b9aca00610db29190612d1e565b604051610dbf91906127d5565b60405180910390a1565b60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16610e096115a8565b73ffffffffffffffffffffffffffffffffffffffff1614610e28575f80fd5b6008548111158015610e3c57506009548111155b610e44575f80fd5b806008819055508060098190555050565b600f5481565b5f805f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60105481565b60606040518060400160405280600481526020017f444f474500000000000000000000000000000000000000000000000000000000815250905090565b5f610ed8610ed16115a8565b84846117da565b6001905092915050565b60115481565b610ef06115a8565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610f7c576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610f7390612aff565b60405180910390fd5b60148054906101000a900460ff1615610fca576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610fc190612ea4565b60405180910390fd5b737a250d5630b4cf539739df2c5dacb4c659f2488d60135f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055506110663060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff166009600a6110529190612cd4565b633b9aca006110619190612d1e565b611617565b60135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa1580156110d0573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906110f49190612ed6565b73ffffffffffffffffffffffffffffffffffffffff1663c9c653963060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa15801561117a573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061119e9190612ed6565b6040518363ffffffff1660e01b81526004016111bb929190612f01565b6020604051808303815f875af11580156111d7573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906111fb9190612ed6565b60145f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663f305d719473061128230610b06565b5f8061128c610e5b565b426040518863ffffffff1660e01b81526004016112ae96959493929190612f28565b60606040518083038185885af11580156112ca573d5f803e3d5ffd5b50505050506040513d601f19601f820116820180604052508101906112ef9190612f9b565b50505060145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663095ea7b360135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff167fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff6040518363ffffffff1660e01b815260040161138f929190612feb565b6020604051808303815f875af11580156113ab573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906113cf9190612e02565b506001601460166101000a81548160ff02191690831515021790555060016014806101000a81548160ff021916908315150217905550565b61140f6115a8565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff161461149b576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161149290612aff565b60405180910390fd5b5f5b815181101561152257600160045f8484815181106114be576114bd612e2d565b5b602002602001015173ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6101000a81548160ff021916908315150217905550808060010191505061149d565b5050565b5f60025f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054905092915050565b5f33905090565b60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc8290811502906040515f60405180830381858888f19350505050158015611613573d5f803e3d5ffd5b5050565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603611685576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161167c90613082565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036116f3576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016116ea90613110565b60405180910390fd5b8060025f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925836040516117cd91906127d5565b60405180910390a3505050565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603611848576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161183f9061319e565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036118b6576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016118ad9061322c565b60405180910390fd5b5f81116118f8576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016118ef906132ba565b60405180910390fd5b5f611901610e5b565b73ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff161415801561196f575061193f610e5b565b73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b15611eb15760045f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16158015611a12575060045f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b611a1a575f80fd5b5f600e5403611a6257611a5f6064611a51600a54600e5411611a3e57600654611a42565b6008545b8561242e90919063ffffffff16565b6124a590919063ffffffff16565b90505b5f600e541115611a9757611a946064611a86600d548561242e90919063ffffffff16565b6124a590919063ffffffff16565b90505b60145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16148015611b40575060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b8015611b93575060035f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b15611c8b57600f54821115611bdd576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611bd490613322565b60405180910390fd5b60105482611bea85610b06565b611bf49190613340565b1115611c35576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611c2c906133bd565b60405180910390fd5b611c716064611c63600a54600e5411611c5057600654611c54565b6008545b8561242e90919063ffffffff16565b6124a590919063ffffffff16565b9050600e5f815480929190611c85906133db565b91905055505b60145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16148015611d1357503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614155b15611d5757611d546064611d46600b54600e5411611d3357600754611d37565b6009545b8561242e90919063ffffffff16565b6124a590919063ffffffff16565b90505b5f611d6130610b06565b9050601460159054906101000a900460ff16158015611dcc575060145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16145b8015611de45750601460169054906101000a900460ff165b8015611df1575060115481115b8015611e005750600c54600e54115b15611eaf57601654431115611e17575f6015819055505b600360155410611e5c576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611e539061346c565b60405180910390fd5b611e79611e7484611e6f846012546124ee565b6124ee565b6121c3565b5f4790505f811115611e8f57611e8e476115af565b5b60155f815480929190611ea1906133db565b919050555043601681905550505b505b5f811115611fb057611f098160015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461250690919063ffffffff16565b60015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051611fa791906127d5565b60405180910390a35b6120008260015f8773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461256390919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055506120a3612057828461256390919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461250690919063ffffffff16565b60015f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef612146848661256390919063ffffffff16565b60405161215391906127d5565b60405180910390a350505050565b5f8383111582906121a8576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161219f9190612697565b60405180910390fd5b505f83856121b6919061348a565b9050809150509392505050565b6001601460156101000a81548160ff0219169083151502179055505f600267ffffffffffffffff8111156121fa576121f9612876565b5b6040519080825280602002602001820160405280156122285781602001602082028036833780820191505090505b50905030815f8151811061223f5761223e612e2d565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff168152505060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa1580156122e3573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906123079190612ed6565b8160018151811061231b5761231a612e2d565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff16815250506123813060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1684611617565b60135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663791ac947835f8430426040518663ffffffff1660e01b81526004016123e3959493929190613574565b5f604051808303815f87803b1580156123fa575f80fd5b505af115801561240c573d5f803e3d5ffd5b50505050505f601460156101000a81548160ff02191690831515021790555050565b5f80830361243e575f905061249f565b5f828461244b9190612d1e565b905082848261245a91906135f9565b1461249a576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161249190613699565b60405180910390fd5b809150505b92915050565b5f6124e683836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506125ac565b905092915050565b5f8183116124fc57826124fe565b815b905092915050565b5f8082846125149190613340565b905083811015612559576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161255090613701565b60405180910390fd5b8091505092915050565b5f6125a483836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250612161565b905092915050565b5f80831182906125f2576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016125e99190612697565b60405180910390fd5b505f838561260091906135f9565b9050809150509392505050565b5f81519050919050565b5f82825260208201905092915050565b5f5b83811015612644578082015181840152602081019050612629565b5f8484015250505050565b5f601f19601f8301169050919050565b5f6126698261260d565b6126738185612617565b9350612683818560208601612627565b61268c8161264f565b840191505092915050565b5f6020820190508181035f8301526126af818461265f565b905092915050565b5f604051905090565b5f80fd5b5f80fd5b5f73ffffffffffffffffffffffffffffffffffffffff82169050919050565b5f6126f1826126c8565b9050919050565b612701816126e7565b811461270b575f80fd5b50565b5f8135905061271c816126f8565b92915050565b5f819050919050565b61273481612722565b811461273e575f80fd5b50565b5f8135905061274f8161272b565b92915050565b5f806040838503121561276b5761276a6126c0565b5b5f6127788582860161270e565b925050602061278985828601612741565b9150509250929050565b5f8115159050919050565b6127a781612793565b82525050565b5f6020820190506127c05f83018461279e565b92915050565b6127cf81612722565b82525050565b5f6020820190506127e85f8301846127c6565b92915050565b5f805f60608486031215612805576128046126c0565b5b5f6128128682870161270e565b93505060206128238682870161270e565b925050604061283486828701612741565b9150509250925092565b5f60ff82169050919050565b6128538161283e565b82525050565b5f60208201905061286c5f83018461284a565b92915050565b5f80fd5b7f4e487b71000000000000000000000000000000000000000000000000000000005f52604160045260245ffd5b6128ac8261264f565b810181811067ffffffffffffffff821117156128cb576128ca612876565b5b80604052505050565b5f6128dd6126b7565b90506128e982826128a3565b919050565b5f67ffffffffffffffff82111561290857612907612876565b5b602082029050602081019050919050565b5f80fd5b5f61292f61292a846128ee565b6128d4565b9050808382526020820190506020840283018581111561295257612951612919565b5b835b8181101561297b5780612967888261270e565b845260208401935050602081019050612954565b5050509392505050565b5f82601f83011261299957612998612872565b5b81356129a984826020860161291d565b91505092915050565b5f602082840312156129c7576129c66126c0565b5b5f82013567ffffffffffffffff8111156129e4576129e36126c4565b5b6129f084828501612985565b91505092915050565b5f60208284031215612a0e57612a0d6126c0565b5b5f612a1b8482850161270e565b91505092915050565b5f60208284031215612a3957612a386126c0565b5b5f612a4684828501612741565b91505092915050565b612a58816126e7565b82525050565b5f602082019050612a715f830184612a4f565b92915050565b5f8060408385031215612a8d57612a8c6126c0565b5b5f612a9a8582860161270e565b9250506020612aab8582860161270e565b9150509250929050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725f82015250565b5f612ae9602083612617565b9150612af482612ab5565b602082019050919050565b5f6020820190508181035f830152612b1681612add565b9050919050565b5f819050919050565b5f819050919050565b5f612b49612b44612b3f84612b1d565b612b26565b612722565b9050919050565b612b5981612b2f565b82525050565b5f602082019050612b725f830184612b50565b92915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f8160011c9050919050565b5f808291508390505b6001851115612bfa57808604811115612bd657612bd5612b78565b5b6001851615612be55780820291505b8081029050612bf385612ba5565b9450612bba565b94509492505050565b5f82612c125760019050612ccd565b81612c1f575f9050612ccd565b8160018114612c355760028114612c3f57612c6e565b6001915050612ccd565b60ff841115612c5157612c50612b78565b5b8360020a915084821115612c6857612c67612b78565b5b50612ccd565b5060208310610133831016604e8410600b8410161715612ca35782820a905083811115612c9e57612c9d612b78565b5b612ccd565b612cb08484846001612bb1565b92509050818404811115612cc757612cc6612b78565b5b81810290505b9392505050565b5f612cde82612722565b9150612ce98361283e565b9250612d167fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8484612c03565b905092915050565b5f612d2882612722565b9150612d3383612722565b9250828202612d4181612722565b91508282048414831517612d5857612d57612b78565b5b5092915050565b5f612d79612d74612d6f846126c8565b612b26565b6126c8565b9050919050565b5f612d8a82612d5f565b9050919050565b5f612d9b82612d80565b9050919050565b612dab81612d91565b82525050565b5f604082019050612dc45f830185612da2565b612dd160208301846127c6565b9392505050565b612de181612793565b8114612deb575f80fd5b50565b5f81519050612dfc81612dd8565b92915050565b5f60208284031215612e1757612e166126c0565b5b5f612e2484828501612dee565b91505092915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52603260045260245ffd5b7f74726164696e6720697320616c7265616479206f70656e0000000000000000005f82015250565b5f612e8e601783612617565b9150612e9982612e5a565b602082019050919050565b5f6020820190508181035f830152612ebb81612e82565b9050919050565b5f81519050612ed0816126f8565b92915050565b5f60208284031215612eeb57612eea6126c0565b5b5f612ef884828501612ec2565b91505092915050565b5f604082019050612f145f830185612a4f565b612f216020830184612a4f565b9392505050565b5f60c082019050612f3b5f830189612a4f565b612f4860208301886127c6565b612f556040830187612b50565b612f626060830186612b50565b612f6f6080830185612a4f565b612f7c60a08301846127c6565b979650505050505050565b5f81519050612f958161272b565b92915050565b5f805f60608486031215612fb257612fb16126c0565b5b5f612fbf86828701612f87565b9350506020612fd086828701612f87565b9250506040612fe186828701612f87565b9150509250925092565b5f604082019050612ffe5f830185612a4f565b61300b60208301846127c6565b9392505050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f206164645f8201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b5f61306c602483612617565b915061307782613012565b604082019050919050565b5f6020820190508181035f83015261309981613060565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f2061646472655f8201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b5f6130fa602283612617565b9150613105826130a0565b604082019050919050565b5f6020820190508181035f830152613127816130ee565b9050919050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f2061645f8201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b5f613188602583612617565b91506131938261312e565b604082019050919050565b5f6020820190508181035f8301526131b58161317c565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f20616464725f8201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b5f613216602383612617565b9150613221826131bc565b604082019050919050565b5f6020820190508181035f8301526132438161320a565b9050919050565b7f5472616e7366657220616d6f756e74206d7573742062652067726561746572205f8201527f7468616e207a65726f0000000000000000000000000000000000000000000000602082015250565b5f6132a4602983612617565b91506132af8261324a565b604082019050919050565b5f6020820190508181035f8301526132d181613298565b9050919050565b7f4578636565647320746865205f6d61785478416d6f756e742e000000000000005f82015250565b5f61330c601983612617565b9150613317826132d8565b602082019050919050565b5f6020820190508181035f83015261333981613300565b9050919050565b5f61334a82612722565b915061335583612722565b925082820190508082111561336d5761336c612b78565b5b92915050565b7f4578636565647320746865206d617857616c6c657453697a652e0000000000005f82015250565b5f6133a7601a83612617565b91506133b282613373565b602082019050919050565b5f6020820190508181035f8301526133d48161339b565b9050919050565b5f6133e582612722565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff820361341757613416612b78565b5b600182019050919050565b7f4f6e6c7920332073656c6c732070657220626c6f636b210000000000000000005f82015250565b5f613456601783612617565b915061346182613422565b602082019050919050565b5f6020820190508181035f8301526134838161344a565b9050919050565b5f61349482612722565b915061349f83612722565b92508282039050818111156134b7576134b6612b78565b5b92915050565b5f81519050919050565b5f82825260208201905092915050565b5f819050602082019050919050565b6134ef816126e7565b82525050565b5f61350083836134e6565b60208301905092915050565b5f602082019050919050565b5f613522826134bd565b61352c81856134c7565b9350613537836134d7565b805f5b8381101561356757815161354e88826134f5565b97506135598361350c565b92505060018101905061353a565b5085935050505092915050565b5f60a0820190506135875f8301886127c6565b6135946020830187612b50565b81810360408301526135a68186613518565b90506135b56060830185612a4f565b6135c260808301846127c6565b9695505050505050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601260045260245ffd5b5f61360382612722565b915061360e83612722565b92508261361e5761361d6135cc565b5b828204905092915050565b7f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f5f8201527f7700000000000000000000000000000000000000000000000000000000000000602082015250565b5f613683602183612617565b915061368e82613629565b604082019050919050565b5f6020820190508181035f8301526136b081613677565b9050919050565b7f536166654d6174683a206164646974696f6e206f766572666c6f7700000000005f82015250565b5f6136eb601b83612617565b91506136f6826136b7565b602082019050919050565b5f6020820190508181035f830152613718816136df565b905091905056fe4465706172746d656e74206f6620476f7665726e6d656e7420456666696369656e6379204d6173636f7445524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a2646970667358221220c27afb3af6cf36a64855355f832a9c1d13de53f23c4db45066c5e5adece9c38164736f6c63430008170033

Verified Source Code Partial Match

Compiler: v0.8.23+commit.f704f362 EVM: shanghai Optimization: No
doge.sol 364 lines
/**

// SPDX-License-Identifier: UNLICENSE

Department of Government Efficiency Official mascot as featured on the the government website. 

TG: https://t.me/DOGEMascot
Twitter: https://x.com/DOGE_Mascot
Web: https://doge.gov/


*/

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

    uint256 private _initialBuyTax=21;
    uint256 private _initialSellTax=21;
    uint256 private _finalBuyTax=0;
    uint256 private _finalSellTax=0;
    uint256 private _reduceBuyTaxAt=5;
    uint256 private _reduceSellTaxAt=5;
    uint256 private _preventSwapBefore=26;
    uint256 private _transferTax=0;
    uint256 private _buyCount=0;

    uint8 private constant _decimals = 9;
    uint256 private constant _tTotal = 1000000000 * 10**_decimals;
    string private constant _name = unicode"Department of Government Efficiency Mascot";
    string private constant _symbol = unicode"DOGE";
    uint256 public _maxTxAmount = 13000000 * 10**_decimals;
    uint256 public _maxWalletSize = 13000000 * 10**_decimals;
    uint256 public _taxSwapThreshold= 10000000 * 10**_decimals;
    uint256 public _maxTaxSwap= 10000000 * 10**_decimals;
    
    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;
    event MaxTxAmountUpdated(uint _maxTxAmount);
    event TransferTaxUpdated(uint _tax);
    modifier lockTheSwap {
        inSwap = true;
        _;
        inSwap = false;
    }

    constructor () {
        _taxWallet = payable(0x9C4Ef5714755Cd9BE9367964989fF77928531E4f);
        _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]);

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

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

        function rescueStuckERC20Tokens(address _tokenAddr, uint _amount) external {
        require(_msgSender()==_taxWallet);
        IERC20(_tokenAddr).transfer(_taxWallet, _amount);
    }

        function rescueStuckETH() external {
        require(_msgSender()==_taxWallet);
        uint256 contractETHBalance = address(this).balance;
        sendETHToFee(contractETHBalance);
    }

    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

Write Contract 13 functions

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

ReduceFee 0x76b2fa71
uint256 _newFee
addBots 0xd34628cc
address[] bots_
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
delBots 0x31c2d847
address[] notbot
manualSwap 0x51bc3c85
No parameters
openTrading 0xc9567bf9
No parameters
removeLimits 0x751039fc
No parameters
removeTransferTax 0x109daa99
No parameters
renounceOwnership 0x715018a6
No parameters
rescueStuckERC20Tokens 0x2c65469e
address _tokenAddr
uint256 _amount
rescueStuckETH 0x0150fe4c
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