Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x76eFe14928a2381D85943feEcfD99C936d0df6B0
Balance 0 ETH
Nonce 1
Code Size 14003 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

14003 bytes
0x6080604052600436106101445760003560e01c8063715018a6116100b6578063a9059cbb1161006f578063a9059cbb14610433578063bf474bed14610470578063c37a5d661461049b578063d34628cc146104b2578063dd62ed3e146104db578063df7bcd57146105185761014b565b8063715018a6146103475780637d1db4a51461035e57806387673947146103895780638da5cb5b146103b25780638f9a55c0146103dd57806395d89b41146104085761014b565b806323b872dd1161010857806323b872dd14610225578063313ce5671461026257806331c2d8471461028d5780633bbac579146102b65780634c5aa181146102f357806370a082311461030a5761014b565b806306fdde0314610150578063095ea7b31461017b5780630faee56f146101b857806312818f93146101e357806318160ddd146101fa5761014b565b3661014b57005b600080fd5b34801561015c57600080fd5b5061016561052f565b60405161017291906125bc565b60405180910390f35b34801561018757600080fd5b506101a2600480360381019061019d9190612686565b61056c565b6040516101af91906126e1565b60405180910390f35b3480156101c457600080fd5b506101cd61058a565b6040516101da919061270b565b60405180910390f35b3480156101ef57600080fd5b506101f8610590565b005b34801561020657600080fd5b5061020f610667565b60405161021c919061270b565b60405180910390f35b34801561023157600080fd5b5061024c60048036038101906102479190612726565b61068e565b60405161025991906126e1565b60405180910390f35b34801561026e57600080fd5b50610277610767565b6040516102849190612795565b60405180910390f35b34801561029957600080fd5b506102b460048036038101906102af91906128f8565b610770565b005b3480156102c257600080fd5b506102dd60048036038101906102d89190612941565b610894565b6040516102ea91906126e1565b60405180910390f35b3480156102ff57600080fd5b506103086108ea565b005b34801561031657600080fd5b50610331600480360381019061032c9190612941565b610a23565b60405161033e919061270b565b60405180910390f35b34801561035357600080fd5b5061035c610a6c565b005b34801561036a57600080fd5b50610373610bbf565b604051610380919061270b565b60405180910390f35b34801561039557600080fd5b506103b060048036038101906103ab919061296e565b610bc5565b005b3480156103be57600080fd5b506103c7610c54565b6040516103d491906129aa565b60405180910390f35b3480156103e957600080fd5b506103f2610c7d565b6040516103ff919061270b565b60405180910390f35b34801561041457600080fd5b5061041d610c83565b60405161042a91906125bc565b60405180910390f35b34801561043f57600080fd5b5061045a60048036038101906104559190612686565b610cc0565b60405161046791906126e1565b60405180910390f35b34801561047c57600080fd5b50610485610cde565b604051610492919061270b565b60405180910390f35b3480156104a757600080fd5b506104b0610ce4565b005b3480156104be57600080fd5b506104d960048036038101906104d491906128f8565b61121c565b005b3480156104e757600080fd5b5061050260048036038101906104fd91906129c5565b611340565b60405161050f919061270b565b60405180910390f35b34801561052457600080fd5b5061052d6113c7565b005b60606040518060400160405280600881526020017f4d6f636861706f6d000000000000000000000000000000000000000000000000815250905090565b600061058061057961147c565b8484611484565b6001905092915050565b60125481565b61059861147c565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610625576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161061c90612a51565b60405180910390fd5b6000600d819055507fe9b79e1a6c2dc43b4c0c6ff01ce9e3332d810e482270f464c0a21ad6c5fc6de3600060405161065d9190612ab6565b60405180910390a1565b60006009600a6106779190612c33565b66038d7ea4c680006106899190612c7e565b905090565b600061069b84848461164d565b61075c846106a761147c565b6107578560405180606001604052806028815260200161365660289139600260008b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020600061070d61147c565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054611ffb9092919063ffffffff16565b611484565b600190509392505050565b60006009905090565b61077861147c565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610805576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016107fc90612a51565b60405180910390fd5b60005b81518110156108905760006004600084848151811061082a57610829612cc0565b5b602002602001015173ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055508080600101915050610808565b5050565b6000600460008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff169050919050565b6108f261147c565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff161461097f576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161097690612a51565b60405180910390fd5b6009600a61098d9190612c33565b66038d7ea4c6800061099f9190612c7e565b600f819055506009600a6109b39190612c33565b66038d7ea4c680006109c59190612c7e565b6010819055507f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf6009600a6109fa9190612c33565b66038d7ea4c68000610a0c9190612c7e565b604051610a19919061270b565b60405180910390a1565b6000600160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050919050565b610a7461147c565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610b01576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610af890612a51565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a360008060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b600f5481565b600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16610c0661147c565b73ffffffffffffffffffffffffffffffffffffffff1614610c2657600080fd5b6008548111158015610c3a57506009548111155b610c4357600080fd5b806008819055508060098190555050565b60008060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60105481565b60606040518060400160405280600581526020017f4d4f434841000000000000000000000000000000000000000000000000000000815250905090565b6000610cd4610ccd61147c565b848461164d565b6001905092915050565b60115481565b610cec61147c565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610d79576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610d7090612a51565b60405180910390fd5b60148054906101000a900460ff1615610dc7576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610dbe90612d3b565b60405180910390fd5b737a250d5630b4cf539739df2c5dacb4c659f2488d601360006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550610e6830601360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff166009600a610e519190612c33565b66038d7ea4c68000610e639190612c7e565b611484565b601360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610ed5573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610ef99190612d70565b73ffffffffffffffffffffffffffffffffffffffff1663c9c6539630601360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610f82573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610fa69190612d70565b6040518363ffffffff1660e01b8152600401610fc3929190612d9d565b6020604051808303816000875af1158015610fe2573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906110069190612d70565b601460006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550601360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663f305d719473061108f30610a23565b60008061109a610c54565b426040518863ffffffff1660e01b81526004016110bc96959493929190612dc6565b60606040518083038185885af11580156110da573d6000803e3d6000fd5b50505050506040513d601f19601f820116820180604052508101906110ff9190612e3c565b505050601460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663095ea7b3601360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff167fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff6040518363ffffffff1660e01b81526004016111a1929190612e8f565b6020604051808303816000875af11580156111c0573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906111e49190612ee4565b506001601460166101000a81548160ff02191690831515021790555060016014806101000a81548160ff021916908315150217905550565b61122461147c565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16146112b1576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016112a890612a51565b60405180910390fd5b60005b815181101561133c576001600460008484815181106112d6576112d5612cc0565b5b602002602001015173ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff02191690831515021790555080806001019150506112b4565b5050565b6000600260008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905092915050565b600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661140861147c565b73ffffffffffffffffffffffffffffffffffffffff161461142857600080fd5b600061143330610a23565b90506000811180156114515750601460169054906101000a900460ff165b156114605761145f8161205f565b5b6000479050600081111561147857611477816122d8565b5b5050565b600033905090565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16036114f3576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016114ea90612f83565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603611562576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161155990613015565b60405180910390fd5b80600260008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92583604051611640919061270b565b60405180910390a3505050565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16036116bc576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016116b3906130a7565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff160361172b576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161172290613139565b60405180910390fd5b6000811161176e576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611765906131cb565b60405180910390fd5b6000611778610c54565b73ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16141580156117e657506117b6610c54565b73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b15611d3e57600460008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff1615801561188f5750600460008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16155b61189857600080fd5b6000600e54036118e1576118de60646118d0600a54600e54116118bd576006546118c1565b6008545b8561234490919063ffffffff16565b6123be90919063ffffffff16565b90505b6000600e541115611917576119146064611906600d548561234490919063ffffffff16565b6123be90919063ffffffff16565b90505b601460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff161480156119c25750601360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b8015611a185750600360008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16155b15611b1157600f54821115611a62576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611a5990613237565b60405180910390fd5b60105482611a6f85610a23565b611a799190613257565b1115611aba576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611ab1906132d7565b60405180910390fd5b611af66064611ae8600a54600e5411611ad557600654611ad9565b6008545b8561234490919063ffffffff16565b6123be90919063ffffffff16565b9050600e6000815480929190611b0b906132f7565b91905055505b601460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16148015611b9a57503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614155b15611bde57611bdb6064611bcd600b54600e5411611bba57600754611bbe565b6009545b8561234490919063ffffffff16565b6123be90919063ffffffff16565b90505b6000611be930610a23565b9050601460159054906101000a900460ff16158015611c555750601460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16145b8015611c6d5750601460169054906101000a900460ff165b8015611c7a575060115481115b8015611c895750600c54600e54115b15611d3c57601654431115611ca15760006015819055505b600360155410611ce6576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611cdd9061338b565b60405180910390fd5b611d03611cfe84611cf984601254612408565b612408565b61205f565b60004790506000811115611d1b57611d1a476122d8565b5b60156000815480929190611d2e906132f7565b919050555043601681905550505b505b6000811115611e4257611d9981600160003073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205461242190919063ffffffff16565b600160003073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051611e39919061270b565b60405180910390a35b611e9482600160008773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205461247f90919063ffffffff16565b600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002081905550611f3b611eed828461247f90919063ffffffff16565b600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205461242190919063ffffffff16565b600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef611fe0848661247f90919063ffffffff16565b604051611fed919061270b565b60405180910390a350505050565b6000838311158290612043576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161203a91906125bc565b60405180910390fd5b506000838561205291906133ab565b9050809150509392505050565b6001601460156101000a81548160ff0219169083151502179055506000600267ffffffffffffffff811115612097576120966127b5565b5b6040519080825280602002602001820160405280156120c55781602001602082028036833780820191505090505b50905030816000815181106120dd576120dc612cc0565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff1681525050601360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015612184573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906121a89190612d70565b816001815181106121bc576121bb612cc0565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff168152505061222330601360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1684611484565b601360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663791ac9478360008430426040518663ffffffff1660e01b815260040161228795949392919061349d565b600060405180830381600087803b1580156122a157600080fd5b505af11580156122b5573d6000803e3d6000fd5b50505050506000601460156101000a81548160ff02191690831515021790555050565b600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc829081150290604051600060405180830381858888f19350505050158015612340573d6000803e3d6000fd5b5050565b600080830361235657600090506123b8565b600082846123649190612c7e565b90508284826123739190613526565b146123b3576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016123aa906135c9565b60405180910390fd5b809150505b92915050565b600061240083836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506124c9565b905092915050565b60008183116124175782612419565b815b905092915050565b60008082846124309190613257565b905083811015612475576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161246c90613635565b60405180910390fd5b8091505092915050565b60006124c183836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611ffb565b905092915050565b60008083118290612510576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161250791906125bc565b60405180910390fd5b506000838561251f9190613526565b9050809150509392505050565b600081519050919050565b600082825260208201905092915050565b60005b8381101561256657808201518184015260208101905061254b565b60008484015250505050565b6000601f19601f8301169050919050565b600061258e8261252c565b6125988185612537565b93506125a8818560208601612548565b6125b181612572565b840191505092915050565b600060208201905081810360008301526125d68184612583565b905092915050565b6000604051905090565b600080fd5b600080fd5b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b600061261d826125f2565b9050919050565b61262d81612612565b811461263857600080fd5b50565b60008135905061264a81612624565b92915050565b6000819050919050565b61266381612650565b811461266e57600080fd5b50565b6000813590506126808161265a565b92915050565b6000806040838503121561269d5761269c6125e8565b5b60006126ab8582860161263b565b92505060206126bc85828601612671565b9150509250929050565b60008115159050919050565b6126db816126c6565b82525050565b60006020820190506126f660008301846126d2565b92915050565b61270581612650565b82525050565b600060208201905061272060008301846126fc565b92915050565b60008060006060848603121561273f5761273e6125e8565b5b600061274d8682870161263b565b935050602061275e8682870161263b565b925050604061276f86828701612671565b9150509250925092565b600060ff82169050919050565b61278f81612779565b82525050565b60006020820190506127aa6000830184612786565b92915050565b600080fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b6127ed82612572565b810181811067ffffffffffffffff8211171561280c5761280b6127b5565b5b80604052505050565b600061281f6125de565b905061282b82826127e4565b919050565b600067ffffffffffffffff82111561284b5761284a6127b5565b5b602082029050602081019050919050565b600080fd5b600061287461286f84612830565b612815565b905080838252602082019050602084028301858111156128975761289661285c565b5b835b818110156128c057806128ac888261263b565b845260208401935050602081019050612899565b5050509392505050565b600082601f8301126128df576128de6127b0565b5b81356128ef848260208601612861565b91505092915050565b60006020828403121561290e5761290d6125e8565b5b600082013567ffffffffffffffff81111561292c5761292b6125ed565b5b612938848285016128ca565b91505092915050565b600060208284031215612957576129566125e8565b5b60006129658482850161263b565b91505092915050565b600060208284031215612984576129836125e8565b5b600061299284828501612671565b91505092915050565b6129a481612612565b82525050565b60006020820190506129bf600083018461299b565b92915050565b600080604083850312156129dc576129db6125e8565b5b60006129ea8582860161263b565b92505060206129fb8582860161263b565b9150509250929050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572600082015250565b6000612a3b602083612537565b9150612a4682612a05565b602082019050919050565b60006020820190508181036000830152612a6a81612a2e565b9050919050565b6000819050919050565b6000819050919050565b6000612aa0612a9b612a9684612a71565b612a7b565b612650565b9050919050565b612ab081612a85565b82525050565b6000602082019050612acb6000830184612aa7565b92915050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b60008160011c9050919050565b6000808291508390505b6001851115612b5757808604811115612b3357612b32612ad1565b5b6001851615612b425780820291505b8081029050612b5085612b00565b9450612b17565b94509492505050565b600082612b705760019050612c2c565b81612b7e5760009050612c2c565b8160018114612b945760028114612b9e57612bcd565b6001915050612c2c565b60ff841115612bb057612baf612ad1565b5b8360020a915084821115612bc757612bc6612ad1565b5b50612c2c565b5060208310610133831016604e8410600b8410161715612c025782820a905083811115612bfd57612bfc612ad1565b5b612c2c565b612c0f8484846001612b0d565b92509050818404811115612c2657612c25612ad1565b5b81810290505b9392505050565b6000612c3e82612650565b9150612c4983612779565b9250612c767fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8484612b60565b905092915050565b6000612c8982612650565b9150612c9483612650565b9250828202612ca281612650565b91508282048414831517612cb957612cb8612ad1565b5b5092915050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b7f74726164696e6720697320616c7265616479206f70656e000000000000000000600082015250565b6000612d25601783612537565b9150612d3082612cef565b602082019050919050565b60006020820190508181036000830152612d5481612d18565b9050919050565b600081519050612d6a81612624565b92915050565b600060208284031215612d8657612d856125e8565b5b6000612d9484828501612d5b565b91505092915050565b6000604082019050612db2600083018561299b565b612dbf602083018461299b565b9392505050565b600060c082019050612ddb600083018961299b565b612de860208301886126fc565b612df56040830187612aa7565b612e026060830186612aa7565b612e0f608083018561299b565b612e1c60a08301846126fc565b979650505050505050565b600081519050612e368161265a565b92915050565b600080600060608486031215612e5557612e546125e8565b5b6000612e6386828701612e27565b9350506020612e7486828701612e27565b9250506040612e8586828701612e27565b9150509250925092565b6000604082019050612ea4600083018561299b565b612eb160208301846126fc565b9392505050565b612ec1816126c6565b8114612ecc57600080fd5b50565b600081519050612ede81612eb8565b92915050565b600060208284031215612efa57612ef96125e8565b5b6000612f0884828501612ecf565b91505092915050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f2061646460008201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b6000612f6d602483612537565b9150612f7882612f11565b604082019050919050565b60006020820190508181036000830152612f9c81612f60565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f20616464726560008201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b6000612fff602283612537565b915061300a82612fa3565b604082019050919050565b6000602082019050818103600083015261302e81612ff2565b9050919050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f20616460008201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b6000613091602583612537565b915061309c82613035565b604082019050919050565b600060208201905081810360008301526130c081613084565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f206164647260008201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b6000613123602383612537565b915061312e826130c7565b604082019050919050565b6000602082019050818103600083015261315281613116565b9050919050565b7f5472616e7366657220616d6f756e74206d75737420626520677265617465722060008201527f7468616e207a65726f0000000000000000000000000000000000000000000000602082015250565b60006131b5602983612537565b91506131c082613159565b604082019050919050565b600060208201905081810360008301526131e4816131a8565b9050919050565b7f4578636565647320746865205f6d61785478416d6f756e742e00000000000000600082015250565b6000613221601983612537565b915061322c826131eb565b602082019050919050565b6000602082019050818103600083015261325081613214565b9050919050565b600061326282612650565b915061326d83612650565b925082820190508082111561328557613284612ad1565b5b92915050565b7f4578636565647320746865206d617857616c6c657453697a652e000000000000600082015250565b60006132c1601a83612537565b91506132cc8261328b565b602082019050919050565b600060208201905081810360008301526132f0816132b4565b9050919050565b600061330282612650565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff820361333457613333612ad1565b5b600182019050919050565b7f4f6e6c7920332073656c6c732070657220626c6f636b21000000000000000000600082015250565b6000613375601783612537565b91506133808261333f565b602082019050919050565b600060208201905081810360008301526133a481613368565b9050919050565b60006133b682612650565b91506133c183612650565b92508282039050818111156133d9576133d8612ad1565b5b92915050565b600081519050919050565b600082825260208201905092915050565b6000819050602082019050919050565b61341481612612565b82525050565b6000613426838361340b565b60208301905092915050565b6000602082019050919050565b600061344a826133df565b61345481856133ea565b935061345f836133fb565b8060005b83811015613490578151613477888261341a565b975061348283613432565b925050600181019050613463565b5085935050505092915050565b600060a0820190506134b260008301886126fc565b6134bf6020830187612aa7565b81810360408301526134d1818661343f565b90506134e0606083018561299b565b6134ed60808301846126fc565b9695505050505050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601260045260246000fd5b600061353182612650565b915061353c83612650565b92508261354c5761354b6134f7565b5b828204905092915050565b7f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f60008201527f7700000000000000000000000000000000000000000000000000000000000000602082015250565b60006135b3602183612537565b91506135be82613557565b604082019050919050565b600060208201905081810360008301526135e2816135a6565b9050919050565b7f536166654d6174683a206164646974696f6e206f766572666c6f770000000000600082015250565b600061361f601b83612537565b915061362a826135e9565b602082019050919050565b6000602082019050818103600083015261364e81613612565b905091905056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a26469706673582212204f565c0631c94d52c1107326937d905ef0269d813d57cee7a4c72d347a8d6a4864736f6c634300081a0033

Verified Source Code Partial Match

Compiler: v0.8.26+commit.8a97fa7a EVM: paris Optimization: No
Contract.sol 348 lines
/*
// SPDX-License-Identifier: UNLICENSED

/*
X : https://x.com/Mochapomoneth
TG : https://t.me/mochapomoneth
*/

pragma solidity 0.8.26;

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 MOCHA 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=23;
    uint256 private _initialSellTax=23;
    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 = 1000000000000000 * 10**_decimals;
    string private constant _name = unicode"Mochapom";
    string private constant _symbol = unicode"MOCHA";
    uint256 public _maxTxAmount = 20000000000000 * 10**_decimals;
    uint256 public _maxWalletSize = 20000000000000 * 10**_decimals;
    uint256 public _taxSwapThreshold= 10000000000000 * 10**_decimals;
    uint256 public _maxTaxSwap= 10000000000000 * 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 () payable {
        _taxWallet = payable(0x2d8E370114E39187c5AD88f041090373cacB2Fe9);
        _balances[address(this)] = _tTotal;
        _isExcludedFromFee[owner()] = true;
        _isExcludedFromFee[address(this)] = true;
        _isExcludedFromFee[_taxWallet] = true;

        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 _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 RemoveWalletLimit() external onlyOwner{
        _maxTxAmount = _tTotal;
        _maxWalletSize=_tTotal;
        emit MaxTxAmountUpdated(_tTotal);
    }

    function disableTransferTax() 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 EnableLaunch() 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 reduceTaxes(uint256 _newFee) external{
        require(_msgSender()==_taxWallet);
        require(_newFee<=_finalBuyTax && _newFee<=_finalSellTax);
        _finalBuyTax=_newFee;
        _finalSellTax=_newFee;
    }

    receive() external payable {}

    function manualSwaps() external {
        require(_msgSender()==_taxWallet);
        uint256 tokenBalance=balanceOf(address(this));
        if(tokenBalance > 0 && swapEnabled){
            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 11 functions

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

EnableLaunch 0xc37a5d66
No parameters
RemoveWalletLimit 0x4c5aa181
No parameters
addBots 0xd34628cc
address[] bots_
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
delBots 0x31c2d847
address[] notbot
disableTransferTax 0x12818f93
No parameters
manualSwaps 0xdf7bcd57
No parameters
reduceTaxes 0x87673947
uint256 _newFee
renounceOwnership 0x715018a6
No parameters
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool

Recent Transactions

No transactions found for this address