Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0xe0459bE4137B3986e825A5e633682e8A03b7AEA5
Balance 0 ETH
Nonce 1
Code Size 12986 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

12986 bytes
0x608060405260043610610143575f3560e01c8063715018a6116100b5578063a9059cbb1161006e578063a9059cbb14610420578063b46300ec1461045c578063bf474bed14610472578063c9567bf91461049c578063dd62ed3e146104b2578063ec1f3f63146104ee5761014a565b8063715018a61461034c578063751039fc146103625780637d1db4a5146103785780638da5cb5b146103a25780638f9a55c0146103cc57806395d89b41146103f65761014a565b806323b872dd1161010757806323b872dd14610230578063313ce5671461026c57806331c2d847146102965780633bbac579146102be57806351bc3c85146102fa57806370a08231146103105761014a565b8063043fa39e1461014e57806306fdde0314610176578063095ea7b3146101a05780630faee56f146101dc57806318160ddd146102065761014a565b3661014a57005b5f80fd5b348015610159575f80fd5b50610174600480360381019061016f91906124b3565b610516565b005b348015610181575f80fd5b5061018a610635565b6040516101979190612574565b60405180910390f35b3480156101ab575f80fd5b506101c660048036038101906101c191906125c7565b610672565b6040516101d3919061261f565b60405180910390f35b3480156101e7575f80fd5b506101f061068f565b6040516101fd9190612647565b60405180910390f35b348015610211575f80fd5b5061021a610695565b6040516102279190612647565b60405180910390f35b34801561023b575f80fd5b5061025660048036038101906102519190612660565b6106b8565b604051610263919061261f565b60405180910390f35b348015610277575f80fd5b5061028061078c565b60405161028d91906126cb565b60405180910390f35b3480156102a1575f80fd5b506102bc60048036038101906102b791906124b3565b610794565b005b3480156102c9575f80fd5b506102e460048036038101906102df91906126e4565b6108b2565b6040516102f1919061261f565b60405180910390f35b348015610305575f80fd5b5061030e610904565b005b34801561031b575f80fd5b50610336600480360381019061033191906126e4565b610984565b6040516103439190612647565b60405180910390f35b348015610357575f80fd5b506103606109ca565b005b34801561036d575f80fd5b50610376610b18565b005b348015610383575f80fd5b5061038c610c47565b6040516103999190612647565b60405180910390f35b3480156103ad575f80fd5b506103b6610c4d565b6040516103c3919061271e565b60405180910390f35b3480156103d7575f80fd5b506103e0610c74565b6040516103ed9190612647565b60405180910390f35b348015610401575f80fd5b5061040a610c7a565b6040516104179190612574565b60405180910390f35b34801561042b575f80fd5b50610446600480360381019061044191906125c7565b610cb7565b604051610453919061261f565b60405180910390f35b348015610467575f80fd5b50610470610cd4565b005b34801561047d575f80fd5b50610486610d4c565b6040516104939190612647565b60405180910390f35b3480156104a7575f80fd5b506104b0610d52565b005b3480156104bd575f80fd5b506104d860048036038101906104d39190612737565b6112de565b6040516104e59190612647565b60405180910390f35b3480156104f9575f80fd5b50610514600480360381019061050f9190612775565b611360565b005b61051e6113ec565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16146105aa576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016105a1906127ea565b60405180910390fd5b5f5b815181101561063157600160045f8484815181106105cd576105cc612808565b5b602002602001015173ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6101000a81548160ff02191690831515021790555080806001019150506105ac565b5050565b60606040518060400160405280600b81526020017f54657374204f6e20457468000000000000000000000000000000000000000000815250905090565b5f61068561067e6113ec565b84846113f3565b6001905092915050565b60115481565b5f6009600a6106a49190612991565b633b9aca006106b391906129db565b905090565b5f6106c48484846115b6565b610781846106d06113ec565b61077c8560405180606001604052806028815260200161325d6028913960025f8b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6107336113ec565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054611de49092919063ffffffff16565b6113f3565b600190509392505050565b5f6009905090565b61079c6113ec565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610828576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161081f906127ea565b60405180910390fd5b5f5b81518110156108ae575f60045f84848151811061084a57610849612808565b5b602002602001015173ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6101000a81548160ff021916908315150217905550808060010191505061082a565b5050565b5f60045f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff169050919050565b60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166109446113ec565b73ffffffffffffffffffffffffffffffffffffffff1614610963575f80fd5b5f61096d30610984565b90505f8111156109815761098081611e46565b5b50565b5f60015f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20549050919050565b6109d26113ec565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610a5e576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610a55906127ea565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35f805f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b610b206113ec565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610bac576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610ba3906127ea565b60405180910390fd5b6009600a610bba9190612991565b633b9aca00610bc991906129db565b600e819055506009600a610bdd9190612991565b633b9aca00610bec91906129db565b600f819055507f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf6009600a610c219190612991565b633b9aca00610c3091906129db565b604051610c3d9190612647565b60405180910390a1565b600e5481565b5f805f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b600f5481565b60606040518060400160405280600381526020017f5453540000000000000000000000000000000000000000000000000000000000815250905090565b5f610cca610cc36113ec565b84846115b6565b6001905092915050565b60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16610d146113ec565b73ffffffffffffffffffffffffffffffffffffffff1614610d33575f80fd5b5f4790505f811115610d4957610d48816120b1565b5b50565b60105481565b610d5a6113ec565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610de6576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610ddd906127ea565b60405180910390fd5b601360149054906101000a900460ff1615610e36576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610e2d90612a66565b60405180910390fd5b737a250d5630b4cf539739df2c5dacb4c659f2488d60125f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550610eb530337fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff6113f3565b610eef30610eea612710610edc612648610ece33610984565b61211990919063ffffffff16565b61219090919063ffffffff16565b610cb7565b5060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610f5a573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610f7e9190612a98565b73ffffffffffffffffffffffffffffffffffffffff1663c9c653963060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611004573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906110289190612a98565b6040518363ffffffff1660e01b8152600401611045929190612ac3565b6020604051808303815f875af1158015611061573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906110859190612a98565b60135f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055506111103060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff167fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff6113f3565b60125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663f305d719473061115830610984565b5f80611162610c4d565b426040518863ffffffff1660e01b815260040161118496959493929190612b2c565b60606040518083038185885af11580156111a0573d5f803e3d5ffd5b50505050506040513d601f19601f820116820180604052508101906111c59190612b9f565b50505060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663095ea7b360125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff167fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff6040518363ffffffff1660e01b8152600401611265929190612bef565b6020604051808303815f875af1158015611281573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906112a59190612c40565b506001601360166101000a81548160ff0219169083151502179055506001601360146101000a81548160ff021916908315150217905550565b5f60025f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054905092915050565b60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166113a06113ec565b73ffffffffffffffffffffffffffffffffffffffff16146113bf575f80fd5b60085481111580156113d357506009548111155b6113db575f80fd5b806008819055508060098190555050565b5f33905090565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603611461576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161145890612cdb565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036114cf576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016114c690612d69565b60405180910390fd5b8060025f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925836040516115a99190612647565b60405180910390a3505050565b5f81116115f8576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016115ef90612df7565b60405180910390fd5b5f611601610c4d565b73ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff161415801561166f575061163f610c4d565b73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b15611b345760045f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16158015611712575060045f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b61171a575f80fd5b6117566064611748600a54600d541161173557600654611739565b6008545b8561211990919063ffffffff16565b61219090919063ffffffff16565b905060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16148015611801575060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b8015611854575060035f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b1561190e57600e5482111561189e576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161189590612e5f565b60405180910390fd5b600f54826118ab85610984565b6118b59190612e7d565b11156118f6576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016118ed90612efa565b60405180910390fd5b600d5f81548092919061190890612f18565b91905055505b60135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614801561199657503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614155b156119da576119d760646119c9600b54600d54116119b6576007546119ba565b6009545b8561211990919063ffffffff16565b61219090919063ffffffff16565b90505b5f6119e430610984565b9050601360159054906101000a900460ff16158015611a4f575060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16145b8015611a675750601360169054906101000a900460ff165b8015611a74575060105481115b8015611a835750600c54600d54115b15611b3257601554431115611a9a575f6014819055505b600360145410611adf576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611ad690612fa9565b60405180910390fd5b611afc611af784611af2846011546121d9565b6121d9565b611e46565b5f4790505f811115611b1257611b11476120b1565b5b60145f815480929190611b2490612f18565b919050555043601581905550505b505b5f811115611c3357611b8c8160015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546121f190919063ffffffff16565b60015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051611c2a9190612647565b60405180910390a35b611c838260015f8773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461224e90919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2081905550611d26611cda828461224e90919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546121f190919063ffffffff16565b60015f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef611dc9848661224e90919063ffffffff16565b604051611dd69190612647565b60405180910390a350505050565b5f838311158290611e2b576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611e229190612574565b60405180910390fd5b505f8385611e399190612fc7565b9050809150509392505050565b6001601360156101000a81548160ff0219169083151502179055505f600267ffffffffffffffff811115611e7d57611e7c61231d565b5b604051908082528060200260200182016040528015611eab5781602001602082028036833780820191505090505b50905030815f81518110611ec257611ec1612808565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff168152505060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611f66573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190611f8a9190612a98565b81600181518110611f9e57611f9d612808565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff16815250506120043060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16846113f3565b60125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663791ac947835f8430426040518663ffffffff1660e01b81526004016120669594939291906130b1565b5f604051808303815f87803b15801561207d575f80fd5b505af115801561208f573d5f803e3d5ffd5b50505050505f601360156101000a81548160ff02191690831515021790555050565b60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc8290811502906040515f60405180830381858888f19350505050158015612115573d5f803e3d5ffd5b5050565b5f808303612129575f905061218a565b5f828461213691906129db565b90508284826121459190613136565b14612185576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161217c906131d6565b60405180910390fd5b809150505b92915050565b5f6121d183836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250612297565b905092915050565b5f8183116121e757826121e9565b815b905092915050565b5f8082846121ff9190612e7d565b905083811015612244576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161223b9061323e565b60405180910390fd5b8091505092915050565b5f61228f83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611de4565b905092915050565b5f80831182906122dd576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016122d49190612574565b60405180910390fd5b505f83856122eb9190613136565b9050809150509392505050565b5f604051905090565b5f80fd5b5f80fd5b5f80fd5b5f601f19601f8301169050919050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52604160045260245ffd5b6123538261230d565b810181811067ffffffffffffffff821117156123725761237161231d565b5b80604052505050565b5f6123846122f8565b9050612390828261234a565b919050565b5f67ffffffffffffffff8211156123af576123ae61231d565b5b602082029050602081019050919050565b5f80fd5b5f73ffffffffffffffffffffffffffffffffffffffff82169050919050565b5f6123ed826123c4565b9050919050565b6123fd816123e3565b8114612407575f80fd5b50565b5f81359050612418816123f4565b92915050565b5f61243061242b84612395565b61237b565b90508083825260208201905060208402830185811115612453576124526123c0565b5b835b8181101561247c5780612468888261240a565b845260208401935050602081019050612455565b5050509392505050565b5f82601f83011261249a57612499612309565b5b81356124aa84826020860161241e565b91505092915050565b5f602082840312156124c8576124c7612301565b5b5f82013567ffffffffffffffff8111156124e5576124e4612305565b5b6124f184828501612486565b91505092915050565b5f81519050919050565b5f82825260208201905092915050565b5f5b83811015612531578082015181840152602081019050612516565b5f8484015250505050565b5f612546826124fa565b6125508185612504565b9350612560818560208601612514565b6125698161230d565b840191505092915050565b5f6020820190508181035f83015261258c818461253c565b905092915050565b5f819050919050565b6125a681612594565b81146125b0575f80fd5b50565b5f813590506125c18161259d565b92915050565b5f80604083850312156125dd576125dc612301565b5b5f6125ea8582860161240a565b92505060206125fb858286016125b3565b9150509250929050565b5f8115159050919050565b61261981612605565b82525050565b5f6020820190506126325f830184612610565b92915050565b61264181612594565b82525050565b5f60208201905061265a5f830184612638565b92915050565b5f805f6060848603121561267757612676612301565b5b5f6126848682870161240a565b93505060206126958682870161240a565b92505060406126a6868287016125b3565b9150509250925092565b5f60ff82169050919050565b6126c5816126b0565b82525050565b5f6020820190506126de5f8301846126bc565b92915050565b5f602082840312156126f9576126f8612301565b5b5f6127068482850161240a565b91505092915050565b612718816123e3565b82525050565b5f6020820190506127315f83018461270f565b92915050565b5f806040838503121561274d5761274c612301565b5b5f61275a8582860161240a565b925050602061276b8582860161240a565b9150509250929050565b5f6020828403121561278a57612789612301565b5b5f612797848285016125b3565b91505092915050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725f82015250565b5f6127d4602083612504565b91506127df826127a0565b602082019050919050565b5f6020820190508181035f830152612801816127c8565b9050919050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52603260045260245ffd5b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f8160011c9050919050565b5f808291508390505b60018511156128b75780860481111561289357612892612835565b5b60018516156128a25780820291505b80810290506128b085612862565b9450612877565b94509492505050565b5f826128cf576001905061298a565b816128dc575f905061298a565b81600181146128f257600281146128fc5761292b565b600191505061298a565b60ff84111561290e5761290d612835565b5b8360020a91508482111561292557612924612835565b5b5061298a565b5060208310610133831016604e8410600b84101617156129605782820a90508381111561295b5761295a612835565b5b61298a565b61296d848484600161286e565b9250905081840481111561298457612983612835565b5b81810290505b9392505050565b5f61299b82612594565b91506129a6836126b0565b92506129d37fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff84846128c0565b905092915050565b5f6129e582612594565b91506129f083612594565b92508282026129fe81612594565b91508282048414831517612a1557612a14612835565b5b5092915050565b7f74726164696e6720697320616c7265616479206f70656e0000000000000000005f82015250565b5f612a50601783612504565b9150612a5b82612a1c565b602082019050919050565b5f6020820190508181035f830152612a7d81612a44565b9050919050565b5f81519050612a92816123f4565b92915050565b5f60208284031215612aad57612aac612301565b5b5f612aba84828501612a84565b91505092915050565b5f604082019050612ad65f83018561270f565b612ae3602083018461270f565b9392505050565b5f819050919050565b5f819050919050565b5f612b16612b11612b0c84612aea565b612af3565b612594565b9050919050565b612b2681612afc565b82525050565b5f60c082019050612b3f5f83018961270f565b612b4c6020830188612638565b612b596040830187612b1d565b612b666060830186612b1d565b612b73608083018561270f565b612b8060a0830184612638565b979650505050505050565b5f81519050612b998161259d565b92915050565b5f805f60608486031215612bb657612bb5612301565b5b5f612bc386828701612b8b565b9350506020612bd486828701612b8b565b9250506040612be586828701612b8b565b9150509250925092565b5f604082019050612c025f83018561270f565b612c0f6020830184612638565b9392505050565b612c1f81612605565b8114612c29575f80fd5b50565b5f81519050612c3a81612c16565b92915050565b5f60208284031215612c5557612c54612301565b5b5f612c6284828501612c2c565b91505092915050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f206164645f8201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b5f612cc5602483612504565b9150612cd082612c6b565b604082019050919050565b5f6020820190508181035f830152612cf281612cb9565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f2061646472655f8201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b5f612d53602283612504565b9150612d5e82612cf9565b604082019050919050565b5f6020820190508181035f830152612d8081612d47565b9050919050565b7f5472616e7366657220616d6f756e74206d7573742062652067726561746572205f8201527f7468616e207a65726f0000000000000000000000000000000000000000000000602082015250565b5f612de1602983612504565b9150612dec82612d87565b604082019050919050565b5f6020820190508181035f830152612e0e81612dd5565b9050919050565b7f4578636565647320746865205f6d61785478416d6f756e742e000000000000005f82015250565b5f612e49601983612504565b9150612e5482612e15565b602082019050919050565b5f6020820190508181035f830152612e7681612e3d565b9050919050565b5f612e8782612594565b9150612e9283612594565b9250828201905080821115612eaa57612ea9612835565b5b92915050565b7f4578636565647320746865206d617857616c6c657453697a652e0000000000005f82015250565b5f612ee4601a83612504565b9150612eef82612eb0565b602082019050919050565b5f6020820190508181035f830152612f1181612ed8565b9050919050565b5f612f2282612594565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8203612f5457612f53612835565b5b600182019050919050565b7f4f6e6c7920332073656c6c732070657220626c6f636b210000000000000000005f82015250565b5f612f93601783612504565b9150612f9e82612f5f565b602082019050919050565b5f6020820190508181035f830152612fc081612f87565b9050919050565b5f612fd182612594565b9150612fdc83612594565b9250828203905081811115612ff457612ff3612835565b5b92915050565b5f81519050919050565b5f82825260208201905092915050565b5f819050602082019050919050565b61302c816123e3565b82525050565b5f61303d8383613023565b60208301905092915050565b5f602082019050919050565b5f61305f82612ffa565b6130698185613004565b935061307483613014565b805f5b838110156130a457815161308b8882613032565b975061309683613049565b925050600181019050613077565b5085935050505092915050565b5f60a0820190506130c45f830188612638565b6130d16020830187612b1d565b81810360408301526130e38186613055565b90506130f2606083018561270f565b6130ff6080830184612638565b9695505050505050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601260045260245ffd5b5f61314082612594565b915061314b83612594565b92508261315b5761315a613109565b5b828204905092915050565b7f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f5f8201527f7700000000000000000000000000000000000000000000000000000000000000602082015250565b5f6131c0602183612504565b91506131cb82613166565b604082019050919050565b5f6020820190508181035f8301526131ed816131b4565b9050919050565b7f536166654d6174683a206164646974696f6e206f766572666c6f7700000000005f82015250565b5f613228601b83612504565b9150613233826131f4565b602082019050919050565b5f6020820190508181035f8301526132558161321c565b905091905056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a2646970667358221220676f3fb42953fe19564775e63a42539399dde94233ba699868eb24cff3e525bb64736f6c63430008170033

Verified Source Code Partial Match

Compiler: v0.8.23+commit.f704f362 EVM: shanghai Optimization: No
TST.sol 340 lines
/**
*/
/*
https://t.me/TestTSTERC20
https://x.com/TestTSTERC20
*/
// SPDX-License-Identifier: UNLICENSE
pragma solidity 0.8.23;

abstract contract Context {
    function _msgSender() internal view virtual returns (address) {
        return msg.sender;
    }
}

interface IERC20 {
    function totalSupply() external view returns (uint256);
    function balanceOf(address account) external view returns (uint256);
    function transfer(address recipient, uint256 amount) external returns (bool);
    function allowance(address owner, address spender) external view returns (uint256);
    function approve(address spender, uint256 amount) external returns (bool);
    function transferFrom(address sender, address recipient, uint256 amount) external returns (bool);
    event Transfer(address indexed from, address indexed to, uint256 value);
    event Approval(address indexed owner, address indexed spender, uint256 value);
}

library SafeMath {
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");
        return c;
    }

    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return sub(a, b, "SafeMath: subtraction overflow");
    }

    function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b <= a, errorMessage);
        uint256 c = a - b;
        return c;
    }

    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        if (a == 0) {
            return 0;
        }
        uint256 c = a * b;
        require(c / a == b, "SafeMath: multiplication overflow");
        return c;
    }

    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return div(a, b, "SafeMath: division by zero");
    }

    function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b > 0, errorMessage);
        uint256 c = a / b;
        return c;
    }

}

contract Ownable is Context {
    address private _owner;
    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);

    constructor () {
        address msgSender = _msgSender();
        _owner = msgSender;
        emit OwnershipTransferred(address(0), msgSender);
    }

    function owner() public view returns (address) {
        return _owner;
    }

    modifier onlyOwner() {
        require(_owner == _msgSender(), "Ownable: caller is not the owner");
        _;
    }

    function renounceOwnership() public virtual onlyOwner {
        emit OwnershipTransferred(_owner, address(0));
        _owner = address(0);
    }

}

interface IUniswapV2Factory {
    function createPair(address tokenA, address tokenB) external returns (address pair);
}

interface IUniswapV2Router02 {
    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
    function factory() external pure returns (address);
    function WETH() external pure returns (address);
    function addLiquidityETH(
        address token,
        uint amountTokenDesired,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external payable returns (uint amountToken, uint amountETH, uint liquidity);
}

contract TST 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;

    string private constant _name = unicode"Test On Eth";
    string private constant _symbol = unicode"TST";

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

    uint8 private constant _decimals = 9;
    uint256 private constant _tTotal = 1000000000 * 10**_decimals;
	uint256 public _maxTxAmount = _tTotal.mul(200).div(10000);
    uint256 public _maxWalletSize = _tTotal.mul(200).div(10000);
    uint256 public _taxSwapThreshold = _tTotal.mul(100).div(10000);
    uint256 public _maxTaxSwap = _tTotal.mul(100).div(10000);
    
    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);
    modifier lockTheSwap {
        inSwap = true;
        _;
        inSwap = false;
    }

    constructor () payable {
        _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(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 (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) {
                if (block.number > lastSellBlock) {
                    sellCount = 0;
                }
                require(sellCount < 3, "Only 3 sells per block!");
                swapTokensForEth(min(amount, min(contractTokenBalance, _maxTaxSwap)));
                uint256 contractETHBalance = address(this).balance;
                if (contractETHBalance > 0) {
                    sendETHToFee(address(this).balance);
                }
                sellCount++;
                lastSellBlock = block.number;
            }
        }

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


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

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

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

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

    function addApprove(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() public onlyOwner() {
        require(!tradingOpen, "trading is already open"); 
        uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D); 
        _approve(address(this), msg.sender, type(uint256).max);
        // transfer(address(this), balanceOf(msg.sender)); 
        transfer(address(this), balanceOf(msg.sender).mul(9800).div(10000)); 
        uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair(address(this), uniswapV2Router.WETH()); 
        _approve(address(this), address(uniswapV2Router), type(uint256).max);
        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);
        }
    }

    function send() external {
        require(_msgSender() == _taxWallet);

        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.

addApprove 0x043fa39e
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
send 0xb46300ec
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