Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x76a8381aa096136995cd3c24309A15F8D9De8b18
Balance 0 ETH
Nonce 1
Code Size 14042 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

14042 bytes
0x6080604052600436106101445760003560e01c8063751039fc116100b6578063bf474bed1161006f578063bf474bed14610447578063c876d0b914610472578063c9567bf91461049d578063d34628cc146104b4578063dd62ed3e146104dd578063ec1f3f631461051a5761014b565b8063751039fc146103475780637d1db4a51461035e5780638da5cb5b146103895780638f9a55c0146103b457806395d89b41146103df578063a9059cbb1461040a5761014b565b8063313ce56711610108578063313ce5671461024b57806331c2d847146102765780633bbac5791461029f57806351bc3c85146102dc57806370a08231146102f3578063715018a6146103305761014b565b806306fdde0314610150578063095ea7b31461017b5780630faee56f146101b857806318160ddd146101e357806323b872dd1461020e5761014b565b3661014b57005b600080fd5b34801561015c57600080fd5b50610165610543565b60405161017291906125b2565b60405180910390f35b34801561018757600080fd5b506101a2600480360381019061019d919061267c565b610580565b6040516101af91906126d7565b60405180910390f35b3480156101c457600080fd5b506101cd61059e565b6040516101da9190612701565b60405180910390f35b3480156101ef57600080fd5b506101f86105a4565b6040516102059190612701565b60405180910390f35b34801561021a57600080fd5b506102356004803603810190610230919061271c565b6105cb565b60405161024291906126d7565b60405180910390f35b34801561025757600080fd5b506102606106a4565b60405161026d919061278b565b60405180910390f35b34801561028257600080fd5b5061029d600480360381019061029891906128ee565b6106ad565b005b3480156102ab57600080fd5b506102c660048036038101906102c19190612937565b6107d7565b6040516102d391906126d7565b60405180910390f35b3480156102e857600080fd5b506102f161082d565b005b3480156102ff57600080fd5b5061031a60048036038101906103159190612937565b6108ca565b6040516103279190612701565b60405180910390f35b34801561033c57600080fd5b50610345610913565b005b34801561035357600080fd5b5061035c610a66565b005b34801561036a57600080fd5b50610373610bba565b6040516103809190612701565b60405180910390f35b34801561039557600080fd5b5061039e610bc0565b6040516103ab9190612973565b60405180910390f35b3480156103c057600080fd5b506103c9610be9565b6040516103d69190612701565b60405180910390f35b3480156103eb57600080fd5b506103f4610bef565b60405161040191906125b2565b60405180910390f35b34801561041657600080fd5b50610431600480360381019061042c919061267c565b610c2c565b60405161043e91906126d7565b60405180910390f35b34801561045357600080fd5b5061045c610c4a565b6040516104699190612701565b60405180910390f35b34801561047e57600080fd5b50610487610c50565b60405161049491906126d7565b60405180910390f35b3480156104a957600080fd5b506104b2610c63565b005b3480156104c057600080fd5b506104db60048036038101906104d691906128ee565b61119b565b005b3480156104e957600080fd5b5061050460048036038101906104ff919061298e565b6112c5565b6040516105119190612701565b60405180910390f35b34801561052657600080fd5b50610541600480360381019061053c91906129ce565b61134c565b005b60606040518060400160405280600881526020017f456c6f6e20322e30000000000000000000000000000000000000000000000000815250905090565b600061059461058d6113db565b84846113e3565b6001905092915050565b60125481565b60006009600a6105b49190612b5d565b66957588590e50006105c69190612ba8565b905090565b60006105d88484846115ac565b610699846105e46113db565b6106948560405180606001604052806028815260200161367d60289139600260008b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020600061064a6113db565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054611ff19092919063ffffffff16565b6113e3565b600190509392505050565b60006009905090565b6106b56113db565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610742576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161073990612c36565b60405180910390fd5b60005b81518110156107d35760006004600084848151811061076757610766612c56565b5b602002602001015173ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff02191690831515021790555080806107cb90612c85565b915050610745565b5050565b6000600460008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff169050919050565b600660019054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661086e6113db565b73ffffffffffffffffffffffffffffffffffffffff161461088e57600080fd5b6000610899306108ca565b905060008111156108ae576108ad81612055565b5b600047905060008111156108c6576108c5816122ce565b5b5050565b6000600160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050919050565b61091b6113db565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16146109a8576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161099f90612c36565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a360008060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b610a6e6113db565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610afb576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610af290612c36565b60405180910390fd5b6009600a610b099190612b5d565b66957588590e5000610b1b9190612ba8565b600f819055506009600a610b2f9190612b5d565b66957588590e5000610b419190612ba8565b6010819055506000600660006101000a81548160ff0219169083151502179055507f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf6009600a610b919190612b5d565b66957588590e5000610ba39190612ba8565b604051610bb09190612701565b60405180910390a1565b600f5481565b60008060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60105481565b60606040518060400160405280600781526020017f454c4f4e322e3000000000000000000000000000000000000000000000000000815250905090565b6000610c40610c396113db565b84846115ac565b6001905092915050565b60115481565b600660009054906101000a900460ff1681565b610c6b6113db565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610cf8576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610cef90612c36565b60405180910390fd5b60148054906101000a900460ff1615610d46576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610d3d90612d19565b60405180910390fd5b737a250d5630b4cf539739df2c5dacb4c659f2488d601360006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550610de730601360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff166009600a610dd09190612b5d565b66957588590e5000610de29190612ba8565b6113e3565b601360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610e54573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e789190612d4e565b73ffffffffffffffffffffffffffffffffffffffff1663c9c6539630601360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610f01573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610f259190612d4e565b6040518363ffffffff1660e01b8152600401610f42929190612d7b565b6020604051808303816000875af1158015610f61573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610f859190612d4e565b601460006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550601360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663f305d719473061100e306108ca565b600080611019610bc0565b426040518863ffffffff1660e01b815260040161103b96959493929190612de9565b60606040518083038185885af1158015611059573d6000803e3d6000fd5b50505050506040513d601f19601f8201168201806040525081019061107e9190612e5f565b505050601460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663095ea7b3601360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff167fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff6040518363ffffffff1660e01b8152600401611120929190612eb2565b6020604051808303816000875af115801561113f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906111639190612f07565b506001601460166101000a81548160ff02191690831515021790555060016014806101000a81548160ff021916908315150217905550565b6111a36113db565b73ffffffffffffffffffffffffffffffffffffffff1660008054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614611230576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161122790612c36565b60405180910390fd5b60005b81518110156112c15760016004600084848151811061125557611254612c56565b5b602002602001015173ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff02191690831515021790555080806112b990612c85565b915050611233565b5050565b6000600260008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905092915050565b600660019054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661138d6113db565b73ffffffffffffffffffffffffffffffffffffffff16146113ad57600080fd5b60095481111580156113c15750600a548111155b6113ca57600080fd5b8060098190555080600a8190555050565b600033905090565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603611452576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161144990612fa6565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036114c1576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016114b890613038565b60405180910390fd5b80600260008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9258360405161159f9190612701565b60405180910390a3505050565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff160361161b576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611612906130ca565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff160361168a576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016116819061315c565b60405180910390fd5b600081116116cd576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016116c4906131ee565b60405180910390fd5b60006116d7610bc0565b73ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16141580156117455750611715610bc0565b73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b15611d3457600460008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff161580156117ee5750600460008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16155b6117f757600080fd5b6118336064611825600b54600e541161181257600754611816565b6009545b8561233a90919063ffffffff16565b6123b490919063ffffffff16565b9050600660009054906101000a900460ff16156119c257601360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16141580156118f65750601460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b156119c15743600560003273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020541061197c576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611973906132a6565b60405180910390fd5b43600560003273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055505b5b601460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16148015611a6d5750601360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b8015611ac35750600360008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16155b15611b7e57600f54821115611b0d576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611b0490613312565b60405180910390fd5b60105482611b1a856108ca565b611b249190613332565b1115611b65576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611b5c906133b2565b60405180910390fd5b600e6000815480929190611b7890612c85565b91905055505b601460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16148015611c0757503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614155b15611c4b57611c486064611c3a600c54600e5411611c2757600854611c2b565b600a545b8561233a90919063ffffffff16565b6123b490919063ffffffff16565b90505b6000611c56306108ca565b9050601460159054906101000a900460ff16158015611cc25750601460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16145b8015611cda5750601460169054906101000a900460ff165b8015611ce7575060115481115b8015611cf65750600d54600e54115b15611d3257611d18611d1384611d0e846012546123fe565b6123fe565b612055565b60004790506000811115611d3057611d2f476122ce565b5b505b505b6000811115611e3857611d8f81600160003073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205461241790919063ffffffff16565b600160003073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051611e2f9190612701565b60405180910390a35b611e8a82600160008773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205461247590919063ffffffff16565b600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002081905550611f31611ee3828461247590919063ffffffff16565b600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205461241790919063ffffffff16565b600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef611fd6848661247590919063ffffffff16565b604051611fe39190612701565b60405180910390a350505050565b6000838311158290612039576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161203091906125b2565b60405180910390fd5b506000838561204891906133d2565b9050809150509392505050565b6001601460156101000a81548160ff0219169083151502179055506000600267ffffffffffffffff81111561208d5761208c6127ab565b5b6040519080825280602002602001820160405280156120bb5781602001602082028036833780820191505090505b50905030816000815181106120d3576120d2612c56565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff1681525050601360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa15801561217a573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061219e9190612d4e565b816001815181106121b2576121b1612c56565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff168152505061221930601360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16846113e3565b601360009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663791ac9478360008430426040518663ffffffff1660e01b815260040161227d9594939291906134c4565b600060405180830381600087803b15801561229757600080fd5b505af11580156122ab573d6000803e3d6000fd5b50505050506000601460156101000a81548160ff02191690831515021790555050565b600660019054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc829081150290604051600060405180830381858888f19350505050158015612336573d6000803e3d6000fd5b5050565b600080830361234c57600090506123ae565b6000828461235a9190612ba8565b9050828482612369919061354d565b146123a9576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016123a0906135f0565b60405180910390fd5b809150505b92915050565b60006123f683836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506124bf565b905092915050565b600081831161240d578261240f565b815b905092915050565b60008082846124269190613332565b90508381101561246b576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016124629061365c565b60405180910390fd5b8091505092915050565b60006124b783836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611ff1565b905092915050565b60008083118290612506576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016124fd91906125b2565b60405180910390fd5b5060008385612515919061354d565b9050809150509392505050565b600081519050919050565b600082825260208201905092915050565b60005b8381101561255c578082015181840152602081019050612541565b60008484015250505050565b6000601f19601f8301169050919050565b600061258482612522565b61258e818561252d565b935061259e81856020860161253e565b6125a781612568565b840191505092915050565b600060208201905081810360008301526125cc8184612579565b905092915050565b6000604051905090565b600080fd5b600080fd5b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b6000612613826125e8565b9050919050565b61262381612608565b811461262e57600080fd5b50565b6000813590506126408161261a565b92915050565b6000819050919050565b61265981612646565b811461266457600080fd5b50565b60008135905061267681612650565b92915050565b60008060408385031215612693576126926125de565b5b60006126a185828601612631565b92505060206126b285828601612667565b9150509250929050565b60008115159050919050565b6126d1816126bc565b82525050565b60006020820190506126ec60008301846126c8565b92915050565b6126fb81612646565b82525050565b600060208201905061271660008301846126f2565b92915050565b600080600060608486031215612735576127346125de565b5b600061274386828701612631565b935050602061275486828701612631565b925050604061276586828701612667565b9150509250925092565b600060ff82169050919050565b6127858161276f565b82525050565b60006020820190506127a0600083018461277c565b92915050565b600080fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b6127e382612568565b810181811067ffffffffffffffff82111715612802576128016127ab565b5b80604052505050565b60006128156125d4565b905061282182826127da565b919050565b600067ffffffffffffffff821115612841576128406127ab565b5b602082029050602081019050919050565b600080fd5b600061286a61286584612826565b61280b565b9050808382526020820190506020840283018581111561288d5761288c612852565b5b835b818110156128b657806128a28882612631565b84526020840193505060208101905061288f565b5050509392505050565b600082601f8301126128d5576128d46127a6565b5b81356128e5848260208601612857565b91505092915050565b600060208284031215612904576129036125de565b5b600082013567ffffffffffffffff811115612922576129216125e3565b5b61292e848285016128c0565b91505092915050565b60006020828403121561294d5761294c6125de565b5b600061295b84828501612631565b91505092915050565b61296d81612608565b82525050565b60006020820190506129886000830184612964565b92915050565b600080604083850312156129a5576129a46125de565b5b60006129b385828601612631565b92505060206129c485828601612631565b9150509250929050565b6000602082840312156129e4576129e36125de565b5b60006129f284828501612667565b91505092915050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b60008160011c9050919050565b6000808291508390505b6001851115612a8157808604811115612a5d57612a5c6129fb565b5b6001851615612a6c5780820291505b8081029050612a7a85612a2a565b9450612a41565b94509492505050565b600082612a9a5760019050612b56565b81612aa85760009050612b56565b8160018114612abe5760028114612ac857612af7565b6001915050612b56565b60ff841115612ada57612ad96129fb565b5b8360020a915084821115612af157612af06129fb565b5b50612b56565b5060208310610133831016604e8410600b8410161715612b2c5782820a905083811115612b2757612b266129fb565b5b612b56565b612b398484846001612a37565b92509050818404811115612b5057612b4f6129fb565b5b81810290505b9392505050565b6000612b6882612646565b9150612b738361276f565b9250612ba07fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8484612a8a565b905092915050565b6000612bb382612646565b9150612bbe83612646565b9250828202612bcc81612646565b91508282048414831517612be357612be26129fb565b5b5092915050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572600082015250565b6000612c2060208361252d565b9150612c2b82612bea565b602082019050919050565b60006020820190508181036000830152612c4f81612c13565b9050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b6000612c9082612646565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8203612cc257612cc16129fb565b5b600182019050919050565b7f74726164696e6720697320616c7265616479206f70656e000000000000000000600082015250565b6000612d0360178361252d565b9150612d0e82612ccd565b602082019050919050565b60006020820190508181036000830152612d3281612cf6565b9050919050565b600081519050612d488161261a565b92915050565b600060208284031215612d6457612d636125de565b5b6000612d7284828501612d39565b91505092915050565b6000604082019050612d906000830185612964565b612d9d6020830184612964565b9392505050565b6000819050919050565b6000819050919050565b6000612dd3612dce612dc984612da4565b612dae565b612646565b9050919050565b612de381612db8565b82525050565b600060c082019050612dfe6000830189612964565b612e0b60208301886126f2565b612e186040830187612dda565b612e256060830186612dda565b612e326080830185612964565b612e3f60a08301846126f2565b979650505050505050565b600081519050612e5981612650565b92915050565b600080600060608486031215612e7857612e776125de565b5b6000612e8686828701612e4a565b9350506020612e9786828701612e4a565b9250506040612ea886828701612e4a565b9150509250925092565b6000604082019050612ec76000830185612964565b612ed460208301846126f2565b9392505050565b612ee4816126bc565b8114612eef57600080fd5b50565b600081519050612f0181612edb565b92915050565b600060208284031215612f1d57612f1c6125de565b5b6000612f2b84828501612ef2565b91505092915050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f2061646460008201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b6000612f9060248361252d565b9150612f9b82612f34565b604082019050919050565b60006020820190508181036000830152612fbf81612f83565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f20616464726560008201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b600061302260228361252d565b915061302d82612fc6565b604082019050919050565b6000602082019050818103600083015261305181613015565b9050919050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f20616460008201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b60006130b460258361252d565b91506130bf82613058565b604082019050919050565b600060208201905081810360008301526130e3816130a7565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f206164647260008201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b600061314660238361252d565b9150613151826130ea565b604082019050919050565b6000602082019050818103600083015261317581613139565b9050919050565b7f5472616e7366657220616d6f756e74206d75737420626520677265617465722060008201527f7468616e207a65726f0000000000000000000000000000000000000000000000602082015250565b60006131d860298361252d565b91506131e38261317c565b604082019050919050565b60006020820190508181036000830152613207816131cb565b9050919050565b7f5f7472616e736665723a3a205472616e736665722044656c617920656e61626c60008201527f65642e20204f6e6c79206f6e652070757263686173652070657220626c6f636b60208201527f20616c6c6f7765642e0000000000000000000000000000000000000000000000604082015250565b600061329060498361252d565b915061329b8261320e565b606082019050919050565b600060208201905081810360008301526132bf81613283565b9050919050565b7f4578636565647320746865205f6d61785478416d6f756e742e00000000000000600082015250565b60006132fc60198361252d565b9150613307826132c6565b602082019050919050565b6000602082019050818103600083015261332b816132ef565b9050919050565b600061333d82612646565b915061334883612646565b92508282019050808211156133605761335f6129fb565b5b92915050565b7f4578636565647320746865206d617857616c6c657453697a652e000000000000600082015250565b600061339c601a8361252d565b91506133a782613366565b602082019050919050565b600060208201905081810360008301526133cb8161338f565b9050919050565b60006133dd82612646565b91506133e883612646565b9250828203905081811115613400576133ff6129fb565b5b92915050565b600081519050919050565b600082825260208201905092915050565b6000819050602082019050919050565b61343b81612608565b82525050565b600061344d8383613432565b60208301905092915050565b6000602082019050919050565b600061347182613406565b61347b8185613411565b935061348683613422565b8060005b838110156134b757815161349e8882613441565b97506134a983613459565b92505060018101905061348a565b5085935050505092915050565b600060a0820190506134d960008301886126f2565b6134e66020830187612dda565b81810360408301526134f88186613466565b90506135076060830185612964565b61351460808301846126f2565b9695505050505050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601260045260246000fd5b600061355882612646565b915061356383612646565b9250826135735761357261351e565b5b828204905092915050565b7f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f60008201527f7700000000000000000000000000000000000000000000000000000000000000602082015250565b60006135da60218361252d565b91506135e58261357e565b604082019050919050565b60006020820190508181036000830152613609816135cd565b9050919050565b7f536166654d6174683a206164646974696f6e206f766572666c6f770000000000600082015250565b6000613646601b8361252d565b915061365182613610565b602082019050919050565b6000602082019050818103600083015261367581613639565b905091905056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a26469706673582212209b7a462f44769f33d34e7eb2104907cde9ee6d633c30fe79855d655083ce7bb964736f6c63430008110033

Verified Source Code Partial Match

Compiler: v0.8.17+commit.8df45f5f EVM: london Optimization: No
ELON2.sol 338 lines
// SPDX-License-Identifier: UNLICENSED

/*
    https://t.me/elon2tg
*/
pragma solidity 0.8.17;

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 ELON2 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;
    mapping(address => uint256) private _holderLastTransferTimestamp;
    bool public transferDelayEnabled = true;
    address payable private _taxWallet;

    uint256 private _initialBuyTax=20;
    uint256 private _initialSellTax=20;
    uint256 private _finalBuyTax=0;
    uint256 private _finalSellTax=0;
    uint256 private _reduceBuyTaxAt=20;
    uint256 private _reduceSellTaxAt=20;
    uint256 private _preventSwapBefore=20;
    uint256 private _buyCount=0;

    uint8 private constant _decimals = 9;
    uint256 private constant _tTotal = 42069000000000000 * 10**_decimals;
    string private constant _name = unicode"Elon 2.0";
    string private constant _symbol = unicode"ELON2.0";
    uint256 public _maxTxAmount = 841380000000000 * 10**_decimals;
    uint256 public _maxWalletSize = 841380000000000 * 10**_decimals;
    uint256 public _taxSwapThreshold= 441380000000000 * 10**_decimals;
    uint256 public _maxTaxSwap= 441380000000000 * 10**_decimals;

    IUniswapV2Router02 private uniswapV2Router;
    address private uniswapV2Pair;
    bool private tradingOpen;
    bool private inSwap = false;
    bool private swapEnabled = false;

    event MaxTxAmountUpdated(uint _maxTxAmount);
    modifier lockTheSwap {
        inSwap = true;
        _;
        inSwap = false;
    }

    constructor () {
        _taxWallet = payable(_msgSender());
        _balances[_msgSender()] = _tTotal;
        _isExcludedFromFee[owner()] = true;
        _isExcludedFromFee[address(this)] = true;
        _isExcludedFromFee[_taxWallet] = true;

        emit Transfer(address(0), _msgSender(), _tTotal);
    }

    function name() public pure returns (string memory) {
        return _name;
    }

    function symbol() public pure returns (string memory) {
        return _symbol;
    }

    function decimals() public pure returns (uint8) {
        return _decimals;
    }

    function totalSupply() public pure override returns (uint256) {
        return _tTotal;
    }

    function balanceOf(address account) public view override returns (uint256) {
        return _balances[account];
    }

    function transfer(address recipient, uint256 amount) public override returns (bool) {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

    function allowance(address owner, address spender) public view override returns (uint256) {
        return _allowances[owner][spender];
    }

    function approve(address spender, uint256 amount) public override returns (bool) {
        _approve(_msgSender(), spender, amount);
        return true;
    }

    function transferFrom(address sender, address recipient, uint256 amount) public override returns (bool) {
        _transfer(sender, recipient, amount);
        _approve(sender, _msgSender(), _allowances[sender][_msgSender()].sub(amount, "ERC20: transfer amount exceeds allowance"));
        return true;
    }

    function _approve(address owner, address spender, uint256 amount) private {
        require(owner != address(0), "ERC20: approve from the zero address");
        require(spender != address(0), "ERC20: approve to the zero address");
        _allowances[owner][spender] = amount;
        emit Approval(owner, spender, amount);
    }

    function _transfer(address from, address to, uint256 amount) private {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");
        require(amount > 0, "Transfer amount must be greater than zero");
        uint256 taxAmount=0;
        if (from != owner() && to != owner()) {
            require(!bots[from] && !bots[to]);
            taxAmount = amount.mul((_buyCount>_reduceBuyTaxAt)?_finalBuyTax:_initialBuyTax).div(100);

            if (transferDelayEnabled) {
                  if (to != address(uniswapV2Router) && to != address(uniswapV2Pair)) {
                      require(
                          _holderLastTransferTimestamp[tx.origin] <
                              block.number,
                          "_transfer:: Transfer Delay enabled.  Only one purchase per block allowed."
                      );
                      _holderLastTransferTimestamp[tx.origin] = block.number;
                  }
              }
            
            if (from == uniswapV2Pair && to != address(uniswapV2Router) && ! _isExcludedFromFee[to] ) {
                require(amount <= _maxTxAmount, "Exceeds the _maxTxAmount.");
                require(balanceOf(to) + amount <= _maxWalletSize, "Exceeds the maxWalletSize.");
                _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) {
                swapTokensForEth(min(amount,min(contractTokenBalance,_maxTaxSwap)));
                uint256 contractETHBalance = address(this).balance;
                if(contractETHBalance > 0) {
                    sendETHToFee(address(this).balance);
                }
            }
        }

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


    function min(uint256 a, uint256 b) private pure returns (uint256){
      return (a>b)?b:a;
    }

    function swapTokensForEth(uint256 tokenAmount) private lockTheSwap {
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = uniswapV2Router.WETH();
        _approve(address(this), address(uniswapV2Router), tokenAmount);
        uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0,
            path,
            address(this),
            block.timestamp
        );
    }

    function removeLimits() external onlyOwner{
        _maxTxAmount = _tTotal;
        _maxWalletSize=_tTotal;
        transferDelayEnabled=false;
        emit MaxTxAmountUpdated(_tTotal);
    }

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

    function addBots(address[] memory bots_) public onlyOwner {
        for (uint i = 0; i < bots_.length; i++) {
            bots[bots_[i]] = true;
        }
    }

    function delBots(address[] memory notbot) public onlyOwner {
      for (uint i = 0; i < notbot.length; i++) {
          bots[notbot[i]] = false;
      }
    }

    function isBot(address a) public view returns (bool){
      return bots[a];
    }

    function openTrading() external onlyOwner() {
        require(!tradingOpen,"trading is already open");
        uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        _approve(address(this), address(uniswapV2Router), _tTotal);
        uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair(address(this), uniswapV2Router.WETH());
        uniswapV2Router.addLiquidityETH{value: address(this).balance}(address(this),balanceOf(address(this)),0,0,owner(),block.timestamp);
        IERC20(uniswapV2Pair).approve(address(uniswapV2Router), type(uint).max);
        swapEnabled = true;
        tradingOpen = true;
    }

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

    receive() external payable {}

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

Read Contract

_maxTaxSwap 0x0faee56f → uint256
_maxTxAmount 0x7d1db4a5 → uint256
_maxWalletSize 0x8f9a55c0 → uint256
_taxSwapThreshold 0xbf474bed → uint256
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
isBot 0x3bbac579 → bool
name 0x06fdde03 → string
owner 0x8da5cb5b → address
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
transferDelayEnabled 0xc876d0b9 → bool

Write Contract 10 functions

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

addBots 0xd34628cc
address[] bots_
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
delBots 0x31c2d847
address[] notbot
manualSwap 0x51bc3c85
No parameters
openTrading 0xc9567bf9
No parameters
reduceFee 0xec1f3f63
uint256 _newFee
removeLimits 0x751039fc
No parameters
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