Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0xC94fa0D2eBE019f4e1B7BdD043A2A7406660Eb02
Balance 0 ETH
Nonce 1
Code Size 13114 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

13114 bytes
0x608060405260043610610138575f3560e01c806370a08231116100aa578063a9059cbb1161006e578063a9059cbb146103ff578063b15be2f51461043b578063bf474bed14610451578063c876d0b91461047b578063c9567bf9146104a5578063dd62ed3e146104bb5761013f565b806370a082311461031b5780637d1db4a5146103575780638da5cb5b146103815780638f9a55c0146103ab57806395d89b41146103d55761013f565b806323b872dd116100fc57806323b872dd14610225578063313ce567146102615780633b23ff7e1461028b5780633bbac579146102b357806351bc3c85146102ef57806356cd40e7146103055761013f565b806306fdde0314610143578063095ea7b31461016d5780630faee56f146101a957806318160ddd146101d35780631838e6bf146101fd5761013f565b3661013f57005b5f80fd5b34801561014e575f80fd5b506101576104f7565b60405161016491906123ab565b60405180910390f35b348015610178575f80fd5b50610193600480360381019061018e919061245c565b610534565b6040516101a091906124b4565b60405180910390f35b3480156101b4575f80fd5b506101bd610551565b6040516101ca91906124dc565b60405180910390f35b3480156101de575f80fd5b506101e7610557565b6040516101f491906124dc565b60405180910390f35b348015610208575f80fd5b50610223600480360381019061021e919061252b565b61057c565b005b348015610230575f80fd5b5061024b60048036038101906102469190612556565b61062e565b60405161025891906124b4565b60405180910390f35b34801561026c575f80fd5b50610275610702565b60405161028291906125b5565b60405180910390f35b348015610296575f80fd5b506102b160048036038101906102ac91906125f8565b61070a565b005b3480156102be575f80fd5b506102d960048036038101906102d49190612636565b6107f6565b6040516102e691906124b4565b60405180910390f35b3480156102fa575f80fd5b50610303610848565b005b348015610310575f80fd5b506103196108e0565b005b348015610326575f80fd5b50610341600480360381019061033c9190612636565b610a2e565b60405161034e91906124dc565b60405180910390f35b348015610362575f80fd5b5061036b610a74565b60405161037891906124dc565b60405180910390f35b34801561038c575f80fd5b50610395610a7a565b6040516103a29190612670565b60405180910390f35b3480156103b6575f80fd5b506103bf610aa1565b6040516103cc91906124dc565b60405180910390f35b3480156103e0575f80fd5b506103e9610aa7565b6040516103f691906123ab565b60405180910390f35b34801561040a575f80fd5b506104256004803603810190610420919061245c565b610ae4565b60405161043291906124b4565b60405180910390f35b348015610446575f80fd5b5061044f610b01565b005b34801561045c575f80fd5b50610465610c4f565b60405161047291906124dc565b60405180910390f35b348015610486575f80fd5b5061048f610c55565b60405161049c91906124b4565b60405180910390f35b3480156104b0575f80fd5b506104b9610c67565b005b3480156104c6575f80fd5b506104e160048036038101906104dc9190612689565b611188565b6040516104ee91906124dc565b60405180910390f35b60606040518060400160405280600481526020017f426f6e6b00000000000000000000000000000000000000000000000000000000815250905090565b5f61054761054061120a565b8484611211565b6001905092915050565b60125481565b5f6008600a6105669190612823565b655af3107a4000610577919061286d565b905090565b61058461120a565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610610576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610607906128f8565b60405180910390fd5b80601460176101000a81548160ff021916908360ff16021790555050565b5f61063a8484846113d4565b6106f78461064661120a565b6106f2856040518060600160405280602881526020016132dd6028913960025f8b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6106a961120a565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054611ddf9092919063ffffffff16565b611211565b600190509392505050565b5f6008905090565b61071261120a565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff161461079e576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610795906128f8565b60405180910390fd5b8060045f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6101000a81548160ff0219169083151502179055505050565b5f60045f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff169050919050565b600660019054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661088961120a565b73ffffffffffffffffffffffffffffffffffffffff16146108a8575f80fd5b5f6108b230610a2e565b90505f8111156108c6576108c581611e41565b5b5f4790505f8111156108dc576108db816120c8565b5b5050565b6108e861120a565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610974576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161096b906128f8565b60405180910390fd5b6008600a6109829190612823565b655af3107a4000610993919061286d565b600f819055506008600a6109a79190612823565b655af3107a40006109b8919061286d565b6010819055505f60065f6101000a81548160ff0219169083151502179055507f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf6008600a610a069190612823565b655af3107a4000610a17919061286d565b604051610a2491906124dc565b60405180910390a1565b5f60015f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20549050919050565b600f5481565b5f805f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60105481565b60606040518060400160405280600481526020017f426f6e6b00000000000000000000000000000000000000000000000000000000815250905090565b5f610af7610af061120a565b84846113d4565b6001905092915050565b610b0961120a565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610b95576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610b8c906128f8565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35f805f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b60115481565b60065f9054906101000a900460ff1681565b610c6f61120a565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610cfb576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610cf2906128f8565b60405180910390fd5b60148054906101000a900460ff1615610d49576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610d4090612960565b60405180910390fd5b737a250d5630b4cf539739df2c5dacb4c659f2488d60135f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550610de73060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff166008600a610dd19190612823565b655af3107a4000610de2919061286d565b611211565b60135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610e51573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610e759190612992565b73ffffffffffffffffffffffffffffffffffffffff1663c9c653963060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610efb573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610f1f9190612992565b6040518363ffffffff1660e01b8152600401610f3c9291906129bd565b6020604051808303815f875af1158015610f58573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610f7c9190612992565b60145f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663f305d719473061100330610a2e565b5f8061100d610a7a565b426040518863ffffffff1660e01b815260040161102f96959493929190612a26565b60606040518083038185885af115801561104b573d5f803e3d5ffd5b50505050506040513d601f19601f820116820180604052508101906110709190612a99565b50505060145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663095ea7b360135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff167fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff6040518363ffffffff1660e01b8152600401611110929190612ae9565b6020604051808303815f875af115801561112c573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906111509190612b24565b506001601460166101000a81548160ff02191690831515021790555060016014806101000a81548160ff021916908315150217905550565b5f60025f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054905092915050565b5f33905090565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff160361127f576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161127690612bbf565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036112ed576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016112e490612c4d565b60405180910390fd5b8060025f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925836040516113c791906124dc565b60405180910390a3505050565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603611442576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161143990612cdb565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036114b0576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016114a790612d69565b60405180910390fd5b5f81116114f2576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016114e990612df7565b60405180910390fd5b5f6114fb610a7a565b73ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16141580156115695750611539610a7a565b73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b15611b2f5760065f9054906101000a900460ff16156116f45760135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff161415801561162c575060145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b156116f3574360055f3273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054106116b0576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016116a790612e85565b60405180910390fd5b4360055f3273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055505b5b60145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614801561179d575060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b80156117f0575060035f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b156118c957600f5482111561183a576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161183190612eed565b60405180910390fd5b6010548261184785610a2e565b6118519190612f0b565b1115611892576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161188990612f88565b60405180910390fd5b600d54600e5410156118b1576118a783612131565b156118b0575f80fd5b5b600e5f8154809291906118c390612fa6565b91905055505b61190560646118f7600b54600e54116118e4576007546118e8565b6009545b8561214290919063ffffffff16565b6121b990919063ffffffff16565b905060145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614801561198f57503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614155b15611a1857600f548211156119d9576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016119d090612eed565b60405180910390fd5b611a156064611a07600c54600e54116119f4576008546119f8565b600a545b8561214290919063ffffffff16565b6121b990919063ffffffff16565b90505b5f611a2230610a2e565b9050601460159054906101000a900460ff16158015611a8d575060145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16145b8015611aa55750601460169054906101000a900460ff165b8015611ab2575060115481115b8015611ac15750600d54600e54115b8015611aec575043601460179054906101000a900460ff1660ff16601554611ae99190612f0b565b11155b15611b2d57611b0e611b0984611b0484601254612202565b612202565b611e41565b5f4790505f811115611b2457611b23476120c8565b5b43601581905550505b505b5f811115611c2e57611b878160015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461221a90919063ffffffff16565b60015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051611c2591906124dc565b60405180910390a35b611c7e8260015f8773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461227790919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2081905550611d21611cd5828461227790919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461221a90919063ffffffff16565b60015f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef611dc4848661227790919063ffffffff16565b604051611dd191906124dc565b60405180910390a350505050565b5f838311158290611e26576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611e1d91906123ab565b60405180910390fd5b505f8385611e349190612fed565b9050809150509392505050565b6001601460156101000a81548160ff0219169083151502179055505f8103156120ab5760148054906101000a900460ff16156120ab575f600267ffffffffffffffff811115611e9357611e92613020565b5b604051908082528060200260200182016040528015611ec15781602001602082028036833780820191505090505b50905030815f81518110611ed857611ed761304d565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff168152505060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611f7c573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190611fa09190612992565b81600181518110611fb457611fb361304d565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff168152505061201a3060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1684611211565b60135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663791ac947835f8430426040518663ffffffff1660e01b815260040161207c959493929190613131565b5f604051808303815f87803b158015612093575f80fd5b505af11580156120a5573d5f803e3d5ffd5b50505050505b5f601460156101000a81548160ff02191690831515021790555050565b600660019054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc8290811502906040515f60405180830381858888f1935050505015801561212d573d5f803e3d5ffd5b5050565b5f80823b90505f8111915050919050565b5f808303612152575f90506121b3565b5f828461215f919061286d565b905082848261216e91906131b6565b146121ae576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016121a590613256565b60405180910390fd5b809150505b92915050565b5f6121fa83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506122c0565b905092915050565b5f8183116122105782612212565b815b905092915050565b5f8082846122289190612f0b565b90508381101561226d576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612264906132be565b60405180910390fd5b8091505092915050565b5f6122b883836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611ddf565b905092915050565b5f8083118290612306576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016122fd91906123ab565b60405180910390fd5b505f838561231491906131b6565b9050809150509392505050565b5f81519050919050565b5f82825260208201905092915050565b5f5b8381101561235857808201518184015260208101905061233d565b5f8484015250505050565b5f601f19601f8301169050919050565b5f61237d82612321565b612387818561232b565b935061239781856020860161233b565b6123a081612363565b840191505092915050565b5f6020820190508181035f8301526123c38184612373565b905092915050565b5f80fd5b5f73ffffffffffffffffffffffffffffffffffffffff82169050919050565b5f6123f8826123cf565b9050919050565b612408816123ee565b8114612412575f80fd5b50565b5f81359050612423816123ff565b92915050565b5f819050919050565b61243b81612429565b8114612445575f80fd5b50565b5f8135905061245681612432565b92915050565b5f8060408385031215612472576124716123cb565b5b5f61247f85828601612415565b925050602061249085828601612448565b9150509250929050565b5f8115159050919050565b6124ae8161249a565b82525050565b5f6020820190506124c75f8301846124a5565b92915050565b6124d681612429565b82525050565b5f6020820190506124ef5f8301846124cd565b92915050565b5f60ff82169050919050565b61250a816124f5565b8114612514575f80fd5b50565b5f8135905061252581612501565b92915050565b5f602082840312156125405761253f6123cb565b5b5f61254d84828501612517565b91505092915050565b5f805f6060848603121561256d5761256c6123cb565b5b5f61257a86828701612415565b935050602061258b86828701612415565b925050604061259c86828701612448565b9150509250925092565b6125af816124f5565b82525050565b5f6020820190506125c85f8301846125a6565b92915050565b6125d78161249a565b81146125e1575f80fd5b50565b5f813590506125f2816125ce565b92915050565b5f806040838503121561260e5761260d6123cb565b5b5f61261b85828601612415565b925050602061262c858286016125e4565b9150509250929050565b5f6020828403121561264b5761264a6123cb565b5b5f61265884828501612415565b91505092915050565b61266a816123ee565b82525050565b5f6020820190506126835f830184612661565b92915050565b5f806040838503121561269f5761269e6123cb565b5b5f6126ac85828601612415565b92505060206126bd85828601612415565b9150509250929050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f8160011c9050919050565b5f808291508390505b600185111561274957808604811115612725576127246126c7565b5b60018516156127345780820291505b8081029050612742856126f4565b9450612709565b94509492505050565b5f82612761576001905061281c565b8161276e575f905061281c565b8160018114612784576002811461278e576127bd565b600191505061281c565b60ff8411156127a05761279f6126c7565b5b8360020a9150848211156127b7576127b66126c7565b5b5061281c565b5060208310610133831016604e8410600b84101617156127f25782820a9050838111156127ed576127ec6126c7565b5b61281c565b6127ff8484846001612700565b92509050818404811115612816576128156126c7565b5b81810290505b9392505050565b5f61282d82612429565b9150612838836124f5565b92506128657fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8484612752565b905092915050565b5f61287782612429565b915061288283612429565b925082820261289081612429565b915082820484148315176128a7576128a66126c7565b5b5092915050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725f82015250565b5f6128e260208361232b565b91506128ed826128ae565b602082019050919050565b5f6020820190508181035f83015261290f816128d6565b9050919050565b7f74726164696e6720697320616c7265616479206f70656e0000000000000000005f82015250565b5f61294a60178361232b565b915061295582612916565b602082019050919050565b5f6020820190508181035f8301526129778161293e565b9050919050565b5f8151905061298c816123ff565b92915050565b5f602082840312156129a7576129a66123cb565b5b5f6129b48482850161297e565b91505092915050565b5f6040820190506129d05f830185612661565b6129dd6020830184612661565b9392505050565b5f819050919050565b5f819050919050565b5f612a10612a0b612a06846129e4565b6129ed565b612429565b9050919050565b612a20816129f6565b82525050565b5f60c082019050612a395f830189612661565b612a4660208301886124cd565b612a536040830187612a17565b612a606060830186612a17565b612a6d6080830185612661565b612a7a60a08301846124cd565b979650505050505050565b5f81519050612a9381612432565b92915050565b5f805f60608486031215612ab057612aaf6123cb565b5b5f612abd86828701612a85565b9350506020612ace86828701612a85565b9250506040612adf86828701612a85565b9150509250925092565b5f604082019050612afc5f830185612661565b612b0960208301846124cd565b9392505050565b5f81519050612b1e816125ce565b92915050565b5f60208284031215612b3957612b386123cb565b5b5f612b4684828501612b10565b91505092915050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f206164645f8201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b5f612ba960248361232b565b9150612bb482612b4f565b604082019050919050565b5f6020820190508181035f830152612bd681612b9d565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f2061646472655f8201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b5f612c3760228361232b565b9150612c4282612bdd565b604082019050919050565b5f6020820190508181035f830152612c6481612c2b565b9050919050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f2061645f8201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b5f612cc560258361232b565b9150612cd082612c6b565b604082019050919050565b5f6020820190508181035f830152612cf281612cb9565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f20616464725f8201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b5f612d5360238361232b565b9150612d5e82612cf9565b604082019050919050565b5f6020820190508181035f830152612d8081612d47565b9050919050565b7f5472616e7366657220616d6f756e74206d7573742062652067726561746572205f8201527f7468616e207a65726f0000000000000000000000000000000000000000000000602082015250565b5f612de160298361232b565b9150612dec82612d87565b604082019050919050565b5f6020820190508181035f830152612e0e81612dd5565b9050919050565b7f4f6e6c79206f6e65207472616e736665722070657220626c6f636b20616c6c6f5f8201527f7765642e00000000000000000000000000000000000000000000000000000000602082015250565b5f612e6f60248361232b565b9150612e7a82612e15565b604082019050919050565b5f6020820190508181035f830152612e9c81612e63565b9050919050565b7f4578636565647320746865205f6d61785478416d6f756e742e000000000000005f82015250565b5f612ed760198361232b565b9150612ee282612ea3565b602082019050919050565b5f6020820190508181035f830152612f0481612ecb565b9050919050565b5f612f1582612429565b9150612f2083612429565b9250828201905080821115612f3857612f376126c7565b5b92915050565b7f4578636565647320746865206d617857616c6c657453697a652e0000000000005f82015250565b5f612f72601a8361232b565b9150612f7d82612f3e565b602082019050919050565b5f6020820190508181035f830152612f9f81612f66565b9050919050565b5f612fb082612429565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8203612fe257612fe16126c7565b5b600182019050919050565b5f612ff782612429565b915061300283612429565b925082820390508181111561301a576130196126c7565b5b92915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52604160045260245ffd5b7f4e487b71000000000000000000000000000000000000000000000000000000005f52603260045260245ffd5b5f81519050919050565b5f82825260208201905092915050565b5f819050602082019050919050565b6130ac816123ee565b82525050565b5f6130bd83836130a3565b60208301905092915050565b5f602082019050919050565b5f6130df8261307a565b6130e98185613084565b93506130f483613094565b805f5b8381101561312457815161310b88826130b2565b9750613116836130c9565b9250506001810190506130f7565b5085935050505092915050565b5f60a0820190506131445f8301886124cd565b6131516020830187612a17565b818103604083015261316381866130d5565b90506131726060830185612661565b61317f60808301846124cd565b9695505050505050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601260045260245ffd5b5f6131c082612429565b91506131cb83612429565b9250826131db576131da613189565b5b828204905092915050565b7f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f5f8201527f7700000000000000000000000000000000000000000000000000000000000000602082015250565b5f61324060218361232b565b915061324b826131e6565b604082019050919050565b5f6020820190508181035f83015261326d81613234565b9050919050565b7f536166654d6174683a206164646974696f6e206f766572666c6f7700000000005f82015250565b5f6132a8601b8361232b565b91506132b382613274565b602082019050919050565b5f6020820190508181035f8301526132d58161329c565b905091905056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a2646970667358221220c6bc1e7d2450142654cb7a6d5dcd35502fe546ae480347066ab06dd9fee4300464736f6c63430008140033

Verified Source Code Partial Match

Compiler: v0.8.20+commit.a1b79de6 EVM: shanghai Optimization: No
Bonk.sol 343 lines
// SPDX-License-Identifier: MIT
/**

https://t.me/BonkOnETH
**/
pragma solidity 0.8.20;

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 renounce() 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 Bonk 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 = false;
    address payable private _taxWallet;

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

    uint8 private constant _decimals = 8;
    uint256 private constant _tTotal = 100000000000000 * 10**_decimals;
    string private constant _name = "Bonk";
    string private constant _symbol = unicode"Bonk";
    uint256 public _maxTxAmount =   2000000000000 * 10**_decimals;
    uint256 public _maxWalletSize = 2000000000000 * 10**_decimals;
    uint256 public _taxSwapThreshold = 1000 * 10**_decimals;
    uint256 public _maxTaxSwap= 10000 * 10**_decimals;

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

    // Buffer 
    uint8 blockBuffer = 1;
    uint256 lastBlockSold;
    

    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()) {
            if (transferDelayEnabled) {
                if (to != address(uniswapV2Router) && to != address(uniswapV2Pair)) {
                  require(_holderLastTransferTimestamp[tx.origin] < block.number,"Only one transfer 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.");
                if(_buyCount<_preventSwapBefore){
                  require(!isContract(to));
                }
                _buyCount++;
            }


            taxAmount = amount.mul((_buyCount>_reduceBuyTaxAt)?_finalBuyTax:_initialBuyTax).div(100);
            if(to == uniswapV2Pair && from!= address(this) ){
                require(amount <= _maxTxAmount, "Exceeds the _maxTxAmount.");
                taxAmount = amount.mul((_buyCount>_reduceSellTaxAt)?_finalSellTax:_initialSellTax).div(100);
            }

            uint256 contractTokenBalance = balanceOf(address(this));
            if (!inSwap && to == uniswapV2Pair && swapEnabled && contractTokenBalance>_taxSwapThreshold && _buyCount>_preventSwapBefore && lastBlockSold + blockBuffer <= block.number ) {
                swapTokensForEth(min(amount,min(contractTokenBalance,_maxTaxSwap)));
                uint256 contractETHBalance = address(this).balance;
                
                if(contractETHBalance > 0) {
                    sendETHToFee(address(this).balance);
                }

                lastBlockSold = 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 {
        if(tokenAmount==0){return;}
        if(!tradingOpen){return;}
        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 setWhoIsBot(address account, bool state) external onlyOwner{
        bots[account] = state;
    }

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

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

    receive() external payable {}

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

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

    function setBlockBuffer(uint8 _amount) external onlyOwner {
        blockBuffer = _amount;
    }
}

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 9 functions

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

RemoveLimits 0x56cd40e7
No parameters
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
manualSwap 0x51bc3c85
No parameters
openTrading 0xc9567bf9
No parameters
renounce 0xb15be2f5
No parameters
setBlockBuffer 0x1838e6bf
uint8 _amount
setWhoIsBot 0x3b23ff7e
address account
bool state
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