Forkchoice Ethereum Mainnet

Address Contract Partially Verified

Address 0xd52AB2e20DdDe9Ad93c509a1f72D9ea80bcd4a44
Balance 0 ETH
Nonce 1
Code Size 12961 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

12961 bytes
0x608060405260043610610122575f3560e01c8063751039fc1161009f578063a9059cbb11610063578063a9059cbb146103c1578063bf474bed146103fd578063c9567bf914610427578063d34628cc1461043d578063dd62ed3e1461046557610129565b8063751039fc146103035780637d1db4a5146103195780638da5cb5b146103435780638f9a55c01461036d57806395d89b411461039757610129565b8063313ce567116100e6578063313ce5671461022357806331c2d8471461024d5780633bbac5791461027557806370a08231146102b1578063715018a6146102ed57610129565b806306fdde031461012d578063095ea7b3146101575780630faee56f1461019357806318160ddd146101bd57806323b872dd146101e757610129565b3661012957005b5f80fd5b348015610138575f80fd5b506101416104a1565b60405161014e91906122e0565b60405180910390f35b348015610162575f80fd5b5061017d6004803603810190610178919061239e565b6104de565b60405161018a91906123f6565b60405180910390f35b34801561019e575f80fd5b506101a76104fb565b6040516101b4919061241e565b60405180910390f35b3480156101c8575f80fd5b506101d1610501565b6040516101de919061241e565b60405180910390f35b3480156101f2575f80fd5b5061020d60048036038101906102089190612437565b610524565b60405161021a91906123f6565b60405180910390f35b34801561022e575f80fd5b506102376105f8565b60405161024491906124a2565b60405180910390f35b348015610258575f80fd5b50610273600480360381019061026e91906125fb565b610600565b005b348015610280575f80fd5b5061029b60048036038101906102969190612642565b610724565b6040516102a891906123f6565b60405180910390f35b3480156102bc575f80fd5b506102d760048036038101906102d29190612642565b610776565b6040516102e4919061241e565b60405180910390f35b3480156102f8575f80fd5b506103016107bc565b005b34801561030e575f80fd5b5061031761090a565b005b348015610324575f80fd5b5061032d610a47565b60405161033a919061241e565b60405180910390f35b34801561034e575f80fd5b50610357610a4d565b604051610364919061267c565b60405180910390f35b348015610378575f80fd5b50610381610a74565b60405161038e919061241e565b60405180910390f35b3480156103a2575f80fd5b506103ab610a7a565b6040516103b891906122e0565b60405180910390f35b3480156103cc575f80fd5b506103e760048036038101906103e2919061239e565b610ab7565b6040516103f491906123f6565b60405180910390f35b348015610408575f80fd5b50610411610ad4565b60405161041e919061241e565b60405180910390f35b348015610432575f80fd5b5061043b610ada565b005b348015610448575f80fd5b50610463600480360381019061045e91906125fb565b611000565b005b348015610470575f80fd5b5061048b60048036038101906104869190612695565b611125565b604051610498919061241e565b60405180910390f35b60606040518060400160405280600581526020017f446f6c616e000000000000000000000000000000000000000000000000000000815250905090565b5f6104f16104ea6111a7565b84846111ae565b6001905092915050565b60125481565b5f6012600a610510919061282f565b633b9aca0061051f9190612879565b905090565b5f610530848484611371565b6105ed8461053c6111a7565b6105e8856040518060600160405280602881526020016132446028913960025f8b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f61059f6111a7565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054611d319092919063ffffffff16565b6111ae565b600190509392505050565b5f6012905090565b6106086111a7565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610694576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161068b90612904565b60405180910390fd5b5f5b8151811015610720575f60045f8484815181106106b6576106b5612922565b5b602002602001015173ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6101000a81548160ff02191690831515021790555080806107189061294f565b915050610696565b5050565b5f60045f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff169050919050565b5f60015f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20549050919050565b6107c46111a7565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610850576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161084790612904565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35f805f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b6109126111a7565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff161461099e576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161099590612904565b60405180910390fd5b6012600a6109ac919061282f565b633b9aca006109bb9190612879565b600f819055506012600a6109cf919061282f565b633b9aca006109de9190612879565b6010819055505f6009819055505f600a819055507f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf6012600a610a21919061282f565b633b9aca00610a309190612879565b604051610a3d919061241e565b60405180910390a1565b600f5481565b5f805f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60105481565b60606040518060400160405280600581526020017f444f4c414e000000000000000000000000000000000000000000000000000000815250905090565b5f610aca610ac36111a7565b8484611371565b6001905092915050565b60115481565b610ae26111a7565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610b6e576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610b6590612904565b60405180910390fd5b60148054906101000a900460ff1615610bbc576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610bb3906129e0565b60405180910390fd5b737a250d5630b4cf539739df2c5dacb4c659f2488d60135f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550610c583060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff166012600a610c44919061282f565b633b9aca00610c539190612879565b6111ae565b60135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610cc2573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610ce69190612a12565b73ffffffffffffffffffffffffffffffffffffffff1663c9c653963060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610d6c573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610d909190612a12565b6040518363ffffffff1660e01b8152600401610dad929190612a3d565b6020604051808303815f875af1158015610dc9573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610ded9190612a12565b60145f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663f305d7194730610e7430610776565b5f80610e7e610a4d565b426040518863ffffffff1660e01b8152600401610ea096959493929190612aa6565b60606040518083038185885af1158015610ebc573d5f803e3d5ffd5b50505050506040513d601f19601f82011682018060405250810190610ee19190612b19565b50505060145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663095ea7b360135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff167fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff6040518363ffffffff1660e01b8152600401610f81929190612b69565b6020604051808303815f875af1158015610f9d573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610fc19190612bba565b506001601460166101000a81548160ff02191690831515021790555060016014806101000a81548160ff02191690831515021790555043600681905550565b6110086111a7565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614611094576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161108b90612904565b60405180910390fd5b5f5b815181101561112157600160045f8484815181106110b7576110b6612922565b5b602002602001015173ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6101000a81548160ff02191690831515021790555080806111199061294f565b915050611096565b5050565b5f60025f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054905092915050565b5f33905090565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff160361121c576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161121390612c55565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff160361128a576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161128190612ce3565b60405180910390fd5b8060025f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92583604051611364919061241e565b60405180910390a3505050565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16036113df576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016113d690612d71565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff160361144d576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161144490612dff565b60405180910390fd5b5f811161148f576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161148690612e8d565b60405180910390fd5b5f611498610a4d565b73ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff161415801561150657506114d6610a4d565b73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b15611a815760045f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff161580156115a9575060045f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b6115b1575f80fd5b6115ed60646115df600b54600e54116115cc576007546115d0565b6009545b85611d9390919063ffffffff16565b611e0a90919063ffffffff16565b905060145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16148015611698575060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b80156116eb575060035f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b156117ce57600f54821115611735576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161172c90612ef5565b60405180910390fd5b6010548261174285610776565b61174c9190612f13565b111561178d576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161178490612f90565b60405180910390fd5b43601460065461179d9190612f13565b11156117b6576117ac83611e53565b156117b5575f80fd5b5b600e5f8154809291906117c89061294f565b91905055505b60145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614158015611872575060035f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b156118d0576010548261188485610776565b61188e9190612f13565b11156118cf576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016118c690612f90565b60405180910390fd5b5b60145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614801561195857503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614155b1561199c57611999606461198b600c54600e54116119785760085461197c565b600a545b85611d9390919063ffffffff16565b611e0a90919063ffffffff16565b90505b5f6119a630610776565b9050601460159054906101000a900460ff16158015611a11575060145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16145b8015611a295750601460169054906101000a900460ff165b8015611a36575060115481115b8015611a455750600d54600e54115b15611a7f57611a67611a6284611a5d84601254611e64565b611e64565b611e7c565b5f4790505f811115611a7d57611a7c476120e7565b5b505b505b5f811115611b8057611ad98160015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461214f90919063ffffffff16565b60015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051611b77919061241e565b60405180910390a35b611bd08260015f8773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546121ac90919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2081905550611c73611c2782846121ac90919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461214f90919063ffffffff16565b60015f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef611d1684866121ac90919063ffffffff16565b604051611d23919061241e565b60405180910390a350505050565b5f838311158290611d78576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611d6f91906122e0565b60405180910390fd5b505f8385611d869190612fae565b9050809150509392505050565b5f808303611da3575f9050611e04565b5f8284611db09190612879565b9050828482611dbf919061300e565b14611dff576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611df6906130ae565b60405180910390fd5b809150505b92915050565b5f611e4b83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506121f5565b905092915050565b5f80823b90505f8111915050919050565b5f818311611e725782611e74565b815b905092915050565b6001601460156101000a81548160ff0219169083151502179055505f600267ffffffffffffffff811115611eb357611eb26124bf565b5b604051908082528060200260200182016040528015611ee15781602001602082028036833780820191505090505b50905030815f81518110611ef857611ef7612922565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff168152505060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611f9c573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190611fc09190612a12565b81600181518110611fd457611fd3612922565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff168152505061203a3060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16846111ae565b60135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663791ac947835f8430426040518663ffffffff1660e01b815260040161209c959493929190613183565b5f604051808303815f87803b1580156120b3575f80fd5b505af11580156120c5573d5f803e3d5ffd5b50505050505f601460156101000a81548160ff02191690831515021790555050565b60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc8290811502906040515f60405180830381858888f1935050505015801561214b573d5f803e3d5ffd5b5050565b5f80828461215d9190612f13565b9050838110156121a2576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161219990613225565b60405180910390fd5b8091505092915050565b5f6121ed83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611d31565b905092915050565b5f808311829061223b576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161223291906122e0565b60405180910390fd5b505f8385612249919061300e565b9050809150509392505050565b5f81519050919050565b5f82825260208201905092915050565b5f5b8381101561228d578082015181840152602081019050612272565b5f8484015250505050565b5f601f19601f8301169050919050565b5f6122b282612256565b6122bc8185612260565b93506122cc818560208601612270565b6122d581612298565b840191505092915050565b5f6020820190508181035f8301526122f881846122a8565b905092915050565b5f604051905090565b5f80fd5b5f80fd5b5f73ffffffffffffffffffffffffffffffffffffffff82169050919050565b5f61233a82612311565b9050919050565b61234a81612330565b8114612354575f80fd5b50565b5f8135905061236581612341565b92915050565b5f819050919050565b61237d8161236b565b8114612387575f80fd5b50565b5f8135905061239881612374565b92915050565b5f80604083850312156123b4576123b3612309565b5b5f6123c185828601612357565b92505060206123d28582860161238a565b9150509250929050565b5f8115159050919050565b6123f0816123dc565b82525050565b5f6020820190506124095f8301846123e7565b92915050565b6124188161236b565b82525050565b5f6020820190506124315f83018461240f565b92915050565b5f805f6060848603121561244e5761244d612309565b5b5f61245b86828701612357565b935050602061246c86828701612357565b925050604061247d8682870161238a565b9150509250925092565b5f60ff82169050919050565b61249c81612487565b82525050565b5f6020820190506124b55f830184612493565b92915050565b5f80fd5b7f4e487b71000000000000000000000000000000000000000000000000000000005f52604160045260245ffd5b6124f582612298565b810181811067ffffffffffffffff82111715612514576125136124bf565b5b80604052505050565b5f612526612300565b905061253282826124ec565b919050565b5f67ffffffffffffffff821115612551576125506124bf565b5b602082029050602081019050919050565b5f80fd5b5f61257861257384612537565b61251d565b9050808382526020820190506020840283018581111561259b5761259a612562565b5b835b818110156125c457806125b08882612357565b84526020840193505060208101905061259d565b5050509392505050565b5f82601f8301126125e2576125e16124bb565b5b81356125f2848260208601612566565b91505092915050565b5f602082840312156126105761260f612309565b5b5f82013567ffffffffffffffff81111561262d5761262c61230d565b5b612639848285016125ce565b91505092915050565b5f6020828403121561265757612656612309565b5b5f61266484828501612357565b91505092915050565b61267681612330565b82525050565b5f60208201905061268f5f83018461266d565b92915050565b5f80604083850312156126ab576126aa612309565b5b5f6126b885828601612357565b92505060206126c985828601612357565b9150509250929050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f8160011c9050919050565b5f808291508390505b600185111561275557808604811115612731576127306126d3565b5b60018516156127405780820291505b808102905061274e85612700565b9450612715565b94509492505050565b5f8261276d5760019050612828565b8161277a575f9050612828565b8160018114612790576002811461279a576127c9565b6001915050612828565b60ff8411156127ac576127ab6126d3565b5b8360020a9150848211156127c3576127c26126d3565b5b50612828565b5060208310610133831016604e8410600b84101617156127fe5782820a9050838111156127f9576127f86126d3565b5b612828565b61280b848484600161270c565b92509050818404811115612822576128216126d3565b5b81810290505b9392505050565b5f6128398261236b565b915061284483612487565b92506128717fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff848461275e565b905092915050565b5f6128838261236b565b915061288e8361236b565b925082820261289c8161236b565b915082820484148315176128b3576128b26126d3565b5b5092915050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725f82015250565b5f6128ee602083612260565b91506128f9826128ba565b602082019050919050565b5f6020820190508181035f83015261291b816128e2565b9050919050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52603260045260245ffd5b5f6129598261236b565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff820361298b5761298a6126d3565b5b600182019050919050565b7f74726164696e6720697320616c7265616479206f70656e0000000000000000005f82015250565b5f6129ca601783612260565b91506129d582612996565b602082019050919050565b5f6020820190508181035f8301526129f7816129be565b9050919050565b5f81519050612a0c81612341565b92915050565b5f60208284031215612a2757612a26612309565b5b5f612a34848285016129fe565b91505092915050565b5f604082019050612a505f83018561266d565b612a5d602083018461266d565b9392505050565b5f819050919050565b5f819050919050565b5f612a90612a8b612a8684612a64565b612a6d565b61236b565b9050919050565b612aa081612a76565b82525050565b5f60c082019050612ab95f83018961266d565b612ac6602083018861240f565b612ad36040830187612a97565b612ae06060830186612a97565b612aed608083018561266d565b612afa60a083018461240f565b979650505050505050565b5f81519050612b1381612374565b92915050565b5f805f60608486031215612b3057612b2f612309565b5b5f612b3d86828701612b05565b9350506020612b4e86828701612b05565b9250506040612b5f86828701612b05565b9150509250925092565b5f604082019050612b7c5f83018561266d565b612b89602083018461240f565b9392505050565b612b99816123dc565b8114612ba3575f80fd5b50565b5f81519050612bb481612b90565b92915050565b5f60208284031215612bcf57612bce612309565b5b5f612bdc84828501612ba6565b91505092915050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f206164645f8201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b5f612c3f602483612260565b9150612c4a82612be5565b604082019050919050565b5f6020820190508181035f830152612c6c81612c33565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f2061646472655f8201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b5f612ccd602283612260565b9150612cd882612c73565b604082019050919050565b5f6020820190508181035f830152612cfa81612cc1565b9050919050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f2061645f8201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b5f612d5b602583612260565b9150612d6682612d01565b604082019050919050565b5f6020820190508181035f830152612d8881612d4f565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f20616464725f8201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b5f612de9602383612260565b9150612df482612d8f565b604082019050919050565b5f6020820190508181035f830152612e1681612ddd565b9050919050565b7f5472616e7366657220616d6f756e74206d7573742062652067726561746572205f8201527f7468616e207a65726f0000000000000000000000000000000000000000000000602082015250565b5f612e77602983612260565b9150612e8282612e1d565b604082019050919050565b5f6020820190508181035f830152612ea481612e6b565b9050919050565b7f4578636565647320746865205f6d61785478416d6f756e742e000000000000005f82015250565b5f612edf601983612260565b9150612eea82612eab565b602082019050919050565b5f6020820190508181035f830152612f0c81612ed3565b9050919050565b5f612f1d8261236b565b9150612f288361236b565b9250828201905080821115612f4057612f3f6126d3565b5b92915050565b7f4578636565647320746865206d617857616c6c657453697a652e0000000000005f82015250565b5f612f7a601a83612260565b9150612f8582612f46565b602082019050919050565b5f6020820190508181035f830152612fa781612f6e565b9050919050565b5f612fb88261236b565b9150612fc38361236b565b9250828203905081811115612fdb57612fda6126d3565b5b92915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601260045260245ffd5b5f6130188261236b565b91506130238361236b565b92508261303357613032612fe1565b5b828204905092915050565b7f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f5f8201527f7700000000000000000000000000000000000000000000000000000000000000602082015250565b5f613098602183612260565b91506130a38261303e565b604082019050919050565b5f6020820190508181035f8301526130c58161308c565b9050919050565b5f81519050919050565b5f82825260208201905092915050565b5f819050602082019050919050565b6130fe81612330565b82525050565b5f61310f83836130f5565b60208301905092915050565b5f602082019050919050565b5f613131826130cc565b61313b81856130d6565b9350613146836130e6565b805f5b8381101561317657815161315d8882613104565b97506131688361311b565b925050600181019050613149565b5085935050505092915050565b5f60a0820190506131965f83018861240f565b6131a36020830187612a97565b81810360408301526131b58186613127565b90506131c4606083018561266d565b6131d1608083018461240f565b9695505050505050565b7f536166654d6174683a206164646974696f6e206f766572666c6f7700000000005f82015250565b5f61320f601b83612260565b915061321a826131db565b602082019050919050565b5f6020820190508181035f83015261323c81613203565b905091905056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a26469706673582212201cf6cadcab36d332a7337244cfe003506edbff025d322d5a36af33ad6952c85364736f6c63430008140033

Verified Source Code Partial Match

Compiler: v0.8.20+commit.a1b79de6 EVM: shanghai Optimization: No
doLaN.sol 425 lines
/**
https://t.me/DOLANTOKENERC20
website: https://dolan.cash 
X: https://twitter.com/dolantokenerc20
*/

// SPDX-License-Identifier: MIT

pragma solidity ^0.8.19;

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 doLaN is Context, IERC20, Ownable {
    using SafeMath for uint256;
    mapping(address => uint256) private _balances;
    mapping(address => mapping(address => uint256)) private _allowances;
    mapping(address => bool) private _isExcludedFromFee;
    mapping(address => bool) private bots;
    address payable private _taxWallet;
    uint256 firstBlock;

    uint256 private _initialBuyTax = 25;
    uint256 private _initialSellTax = 25;
    uint256 private _finalBuyTax = 0;
    uint256 private _finalSellTax = 0;
    uint256 private _reduceBuyTaxAt = 30;
    uint256 private _reduceSellTaxAt = 30;
    uint256 private _preventSwapBefore = 20;
    uint256 private _buyCount = 0;
    uint8 private constant _decimals = 18;
    uint256 private constant _tTotal = 1000000000 * 10 ** _decimals;
    string private constant _name = unicode"Dolan";
    string private constant _symbol = unicode"DOLAN";
    uint256 public _maxTxAmount = 1000000000 * 10 ** _decimals;
    uint256 public _maxWalletSize = 20000000 * 10 ** _decimals;
    uint256 public _taxSwapThreshold = 1000000 * 10 ** _decimals;
    uint256 public _maxTaxSwap = 1000000000 * 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 (
                from == uniswapV2Pair &&
                to != address(uniswapV2Router) &&
                !_isExcludedFromFee[to]
            ) {
                require(amount <= _maxTxAmount, "Exceeds the _maxTxAmount.");
                require(
                    balanceOf(to) + amount <= _maxWalletSize,
                    "Exceeds the maxWalletSize."
                );

                if (firstBlock + 20 > block.number) {
                    require(!isContract(to));
                }
                _buyCount++;
            }

            if (to != uniswapV2Pair && !_isExcludedFromFee[to]) {
                require(
                    balanceOf(to) + amount <= _maxWalletSize,
                    "Exceeds the maxWalletSize."
                );
            }

            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 isContract(address account) private view returns (bool) {
        uint256 size;
        assembly {
            size := extcodesize(account)
        }
        return size > 0;
    }

    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;
        _finalBuyTax = 0;
        _finalSellTax = 0;
        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;
        firstBlock = block.number;
    }

    receive() external payable {}
}

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 8 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
openTrading 0xc9567bf9
No parameters
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