Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0xfDd05675dcB74dFa7Add216E7Ac27151d7254B87
Balance 0 ETH
Nonce 1
Code Size 13494 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

13494 bytes
0x608060405260043610610138575f3560e01c806377b54bad116100aa578063a9059cbb1161006e578063a9059cbb146103db578063bf474bed14610417578063c9567bf914610441578063dd62ed3e14610457578063ec1f3f6314610493578063f4293890146104bb5761013f565b806377b54bad146102f75780637d1db4a5146103335780638da5cb5b1461035d5780638f9a55c01461038757806395d89b41146103b15761013f565b806323b872dd116100fc57806323b872dd14610213578063313ce5671461024f57806351bc3c8514610279578063622565891461028f57806370a08231146102a5578063715018a6146102e15761013f565b806306fdde0314610143578063095ea7b31461016d5780630faee56f146101a9578063109daa99146101d357806318160ddd146101e95761013f565b3661013f57005b5f80fd5b34801561014e575f80fd5b506101576104d1565b6040516101649190612416565b60405180910390f35b348015610178575f80fd5b50610193600480360381019061018e91906124c7565b61050e565b6040516101a0919061251f565b60405180910390f35b3480156101b4575f80fd5b506101bd61052b565b6040516101ca9190612547565b60405180910390f35b3480156101de575f80fd5b506101e7610531565b005b3480156101f4575f80fd5b506101fd610605565b60405161020a9190612547565b60405180910390f35b34801561021e575f80fd5b5061023960048036038101906102349190612560565b610628565b604051610246919061251f565b60405180910390f35b34801561025a575f80fd5b506102636106fc565b60405161027091906125cb565b60405180910390f35b348015610284575f80fd5b5061028d610704565b005b34801561029a575f80fd5b506102a361079b565b005b3480156102b0575f80fd5b506102cb60048036038101906102c691906125e4565b6108ca565b6040516102d89190612547565b60405180910390f35b3480156102ec575f80fd5b506102f5610910565b005b348015610302575f80fd5b5061031d600480360381019061031891906124c7565b610a5e565b60405161032a919061251f565b60405180910390f35b34801561033e575f80fd5b50610347610c1d565b6040516103549190612547565b60405180910390f35b348015610368575f80fd5b50610371610c23565b60405161037e919061261e565b60405180910390f35b348015610392575f80fd5b5061039b610c4a565b6040516103a89190612547565b60405180910390f35b3480156103bc575f80fd5b506103c5610c50565b6040516103d29190612416565b60405180910390f35b3480156103e6575f80fd5b5061040160048036038101906103fc91906124c7565b610c8d565b60405161040e919061251f565b60405180910390f35b348015610422575f80fd5b5061042b610caa565b6040516104389190612547565b60405180910390f35b34801561044c575f80fd5b50610455610cb0565b005b348015610462575f80fd5b5061047d60048036038101906104789190612637565b6111d9565b60405161048a9190612547565b60405180910390f35b34801561049e575f80fd5b506104b960048036038101906104b49190612675565b61125b565b005b3480156104c6575f80fd5b506104cf6112e7565b005b60606040518060400160405280600581526020017f5a69747479000000000000000000000000000000000000000000000000000000815250905090565b5f61052161051a611398565b848461139f565b6001905092915050565b60115481565b610539611398565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16146105c5576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016105bc906126ea565b60405180910390fd5b5f600c819055507fe9b79e1a6c2dc43b4c0c6ff01ce9e3332d810e482270f464c0a21ad6c5fc6de35f6040516105fb919061274a565b60405180910390a1565b5f6009600a61061491906128bf565b633b9aca006106239190612909565b905090565b5f610634848484611562565b6106f184610640611398565b6106ec856040518060600160405280602881526020016134596028913960025f8b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6106a3611398565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054611e929092919063ffffffff16565b61139f565b600190509392505050565b5f6009905090565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16610744611398565b73ffffffffffffffffffffffffffffffffffffffff1614610763575f80fd5b5f61076d306108ca565b90505f8111156107815761078081611ef4565b5b5f4790505f811115610797576107968161215f565b5b5050565b6107a3611398565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff161461082f576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610826906126ea565b60405180910390fd5b6009600a61083d91906128bf565b633b9aca0061084c9190612909565b600e819055506009600a61086091906128bf565b633b9aca0061086f9190612909565b600f819055507f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf6009600a6108a491906128bf565b633b9aca006108b39190612909565b6040516108c09190612547565b60405180910390a1565b5f60015f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20549050919050565b610918611398565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16146109a4576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161099b906126ea565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35f805f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b5f60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16610a9f611398565b73ffffffffffffffffffffffffffffffffffffffff1614610abe575f80fd5b5f8203610b40578273ffffffffffffffffffffffffffffffffffffffff166370a08231306040518263ffffffff1660e01b8152600401610afe919061261e565b602060405180830381865afa158015610b19573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610b3d919061295e565b91505b7fda2bc2bedd1f85b5a59d5dbbd6684ff877ef916994a16ec08813101e99ace65f8383604051610b71929190612989565b60405180910390a18273ffffffffffffffffffffffffffffffffffffffff1663a9059cbb60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16846040518363ffffffff1660e01b8152600401610bd5929190612a02565b6020604051808303815f875af1158015610bf1573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610c159190612a53565b905092915050565b600e5481565b5f805f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b600f5481565b60606040518060400160405280600781526020017f5a49545459202000000000000000000000000000000000000000000000000000815250905090565b5f610ca0610c99611398565b8484611562565b6001905092915050565b60105481565b610cb8611398565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610d44576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610d3b906126ea565b60405180910390fd5b601360149054906101000a900460ff1615610d94576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610d8b90612ac8565b60405180910390fd5b737a250d5630b4cf539739df2c5dacb4c659f2488d60125f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550610e303060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff166009600a610e1c91906128bf565b633b9aca00610e2b9190612909565b61139f565b60125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610e9a573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610ebe9190612afa565b73ffffffffffffffffffffffffffffffffffffffff1663c9c653963060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610f44573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610f689190612afa565b6040518363ffffffff1660e01b8152600401610f85929190612b25565b6020604051808303815f875af1158015610fa1573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610fc59190612afa565b60135f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663f305d719473061104c306108ca565b5f80611056610c23565b426040518863ffffffff1660e01b815260040161107896959493929190612b4c565b60606040518083038185885af1158015611094573d5f803e3d5ffd5b50505050506040513d601f19601f820116820180604052508101906110b99190612bab565b50505060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663095ea7b360125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff167fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff6040518363ffffffff1660e01b8152600401611159929190612989565b6020604051808303815f875af1158015611175573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906111999190612a53565b506001601360166101000a81548160ff0219169083151502179055506001601360146101000a81548160ff02191690831515021790555043601681905550565b5f60025f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054905092915050565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661129b611398565b73ffffffffffffffffffffffffffffffffffffffff16146112ba575f80fd5b60075481111580156112ce57506008548111155b6112d6575f80fd5b806007819055508060088190555050565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16611327611398565b73ffffffffffffffffffffffffffffffffffffffff1614611346575f80fd5b5f4790505f811161138c576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161138390612c6b565b60405180910390fd5b6113958161215f565b50565b5f33905090565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff160361140d576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161140490612cf9565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff160361147b576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161147290612d87565b60405180910390fd5b8060025f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925836040516115559190612547565b60405180910390a3505050565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16036115d0576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016115c790612e15565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff160361163e576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161163590612ea3565b60405180910390fd5b5f8111611680576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161167790612f31565b60405180910390fd5b5f611689610c23565b73ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16141580156116f757506116c7610c23565b73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b15611be2575f600d5403611744576117416064611733600954600d541161172057600554611724565b6007545b856121c790919063ffffffff16565b61223e90919063ffffffff16565b90505b5f600d541115611779576117766064611768600c54856121c790919063ffffffff16565b61223e90919063ffffffff16565b90505b60165443036117c8576023600d54106117c7576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016117be90612f99565b60405180910390fd5b5b60135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16148015611871575060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b80156118c4575060035f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b156119bc57600e5482111561190e576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161190590613001565b60405180910390fd5b600f548261191b856108ca565b611925919061301f565b1115611966576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161195d9061309c565b60405180910390fd5b6119a26064611994600954600d541161198157600554611985565b6007545b856121c790919063ffffffff16565b61223e90919063ffffffff16565b9050600d5f8154809291906119b6906130ba565b91905055505b60135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16148015611a4457503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614155b15611a8857611a856064611a77600a54600d5411611a6457600654611a68565b6008545b856121c790919063ffffffff16565b61223e90919063ffffffff16565b90505b5f611a92306108ca565b9050601360159054906101000a900460ff16158015611afd575060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16145b8015611b155750601360169054906101000a900460ff165b8015611b22575060105481115b8015611b315750600b54600d54115b15611be057601554431115611b48575f6014819055505b600360145410611b8d576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611b849061314b565b60405180910390fd5b611baa611ba584611ba084601154612287565b612287565b611ef4565b5f4790505f811115611bc057611bbf4761215f565b5b60145f815480929190611bd2906130ba565b919050555043601581905550505b505b5f811115611ce157611c3a8160015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461229f90919063ffffffff16565b60015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051611cd89190612547565b60405180910390a35b611d318260015f8773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546122fc90919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2081905550611dd4611d8882846122fc90919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461229f90919063ffffffff16565b60015f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef611e7784866122fc90919063ffffffff16565b604051611e849190612547565b60405180910390a350505050565b5f838311158290611ed9576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611ed09190612416565b60405180910390fd5b505f8385611ee79190613169565b9050809150509392505050565b6001601360156101000a81548160ff0219169083151502179055505f600267ffffffffffffffff811115611f2b57611f2a61319c565b5b604051908082528060200260200182016040528015611f595781602001602082028036833780820191505090505b50905030815f81518110611f7057611f6f6131c9565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff168152505060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015612014573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906120389190612afa565b8160018151811061204c5761204b6131c9565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff16815250506120b23060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff168461139f565b60125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663791ac947835f8430426040518663ffffffff1660e01b81526004016121149594939291906132ad565b5f604051808303815f87803b15801561212b575f80fd5b505af115801561213d573d5f803e3d5ffd5b50505050505f601360156101000a81548160ff02191690831515021790555050565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc8290811502906040515f60405180830381858888f193505050501580156121c3573d5f803e3d5ffd5b5050565b5f8083036121d7575f9050612238565b5f82846121e49190612909565b90508284826121f39190613332565b14612233576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161222a906133d2565b60405180910390fd5b809150505b92915050565b5f61227f83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250612345565b905092915050565b5f8183116122955782612297565b815b905092915050565b5f8082846122ad919061301f565b9050838110156122f2576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016122e99061343a565b60405180910390fd5b8091505092915050565b5f61233d83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611e92565b905092915050565b5f808311829061238b576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016123829190612416565b60405180910390fd5b505f83856123999190613332565b9050809150509392505050565b5f81519050919050565b5f82825260208201905092915050565b8281835e5f83830152505050565b5f601f19601f8301169050919050565b5f6123e8826123a6565b6123f281856123b0565b93506124028185602086016123c0565b61240b816123ce565b840191505092915050565b5f6020820190508181035f83015261242e81846123de565b905092915050565b5f80fd5b5f73ffffffffffffffffffffffffffffffffffffffff82169050919050565b5f6124638261243a565b9050919050565b61247381612459565b811461247d575f80fd5b50565b5f8135905061248e8161246a565b92915050565b5f819050919050565b6124a681612494565b81146124b0575f80fd5b50565b5f813590506124c18161249d565b92915050565b5f80604083850312156124dd576124dc612436565b5b5f6124ea85828601612480565b92505060206124fb858286016124b3565b9150509250929050565b5f8115159050919050565b61251981612505565b82525050565b5f6020820190506125325f830184612510565b92915050565b61254181612494565b82525050565b5f60208201905061255a5f830184612538565b92915050565b5f805f6060848603121561257757612576612436565b5b5f61258486828701612480565b935050602061259586828701612480565b92505060406125a6868287016124b3565b9150509250925092565b5f60ff82169050919050565b6125c5816125b0565b82525050565b5f6020820190506125de5f8301846125bc565b92915050565b5f602082840312156125f9576125f8612436565b5b5f61260684828501612480565b91505092915050565b61261881612459565b82525050565b5f6020820190506126315f83018461260f565b92915050565b5f806040838503121561264d5761264c612436565b5b5f61265a85828601612480565b925050602061266b85828601612480565b9150509250929050565b5f6020828403121561268a57612689612436565b5b5f612697848285016124b3565b91505092915050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725f82015250565b5f6126d46020836123b0565b91506126df826126a0565b602082019050919050565b5f6020820190508181035f830152612701816126c8565b9050919050565b5f819050919050565b5f819050919050565b5f61273461272f61272a84612708565b612711565b612494565b9050919050565b6127448161271a565b82525050565b5f60208201905061275d5f83018461273b565b92915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f8160011c9050919050565b5f808291508390505b60018511156127e5578086048111156127c1576127c0612763565b5b60018516156127d05780820291505b80810290506127de85612790565b94506127a5565b94509492505050565b5f826127fd57600190506128b8565b8161280a575f90506128b8565b8160018114612820576002811461282a57612859565b60019150506128b8565b60ff84111561283c5761283b612763565b5b8360020a91508482111561285357612852612763565b5b506128b8565b5060208310610133831016604e8410600b841016171561288e5782820a90508381111561288957612888612763565b5b6128b8565b61289b848484600161279c565b925090508184048111156128b2576128b1612763565b5b81810290505b9392505050565b5f6128c982612494565b91506128d4836125b0565b92506129017fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff84846127ee565b905092915050565b5f61291382612494565b915061291e83612494565b925082820261292c81612494565b9150828204841483151761294357612942612763565b5b5092915050565b5f815190506129588161249d565b92915050565b5f6020828403121561297357612972612436565b5b5f6129808482850161294a565b91505092915050565b5f60408201905061299c5f83018561260f565b6129a96020830184612538565b9392505050565b5f6129ca6129c56129c08461243a565b612711565b61243a565b9050919050565b5f6129db826129b0565b9050919050565b5f6129ec826129d1565b9050919050565b6129fc816129e2565b82525050565b5f604082019050612a155f8301856129f3565b612a226020830184612538565b9392505050565b612a3281612505565b8114612a3c575f80fd5b50565b5f81519050612a4d81612a29565b92915050565b5f60208284031215612a6857612a67612436565b5b5f612a7584828501612a3f565b91505092915050565b7f74726164696e6720697320616c7265616479206f70656e0000000000000000005f82015250565b5f612ab26017836123b0565b9150612abd82612a7e565b602082019050919050565b5f6020820190508181035f830152612adf81612aa6565b9050919050565b5f81519050612af48161246a565b92915050565b5f60208284031215612b0f57612b0e612436565b5b5f612b1c84828501612ae6565b91505092915050565b5f604082019050612b385f83018561260f565b612b45602083018461260f565b9392505050565b5f60c082019050612b5f5f83018961260f565b612b6c6020830188612538565b612b79604083018761273b565b612b86606083018661273b565b612b93608083018561260f565b612ba060a0830184612538565b979650505050505050565b5f805f60608486031215612bc257612bc1612436565b5b5f612bcf8682870161294a565b9350506020612be08682870161294a565b9250506040612bf18682870161294a565b9150509250925092565b7f436f6e74726163742062616c616e6365206d75737420626520677265617465725f8201527f207468616e207a65726f00000000000000000000000000000000000000000000602082015250565b5f612c55602a836123b0565b9150612c6082612bfb565b604082019050919050565b5f6020820190508181035f830152612c8281612c49565b9050919050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f206164645f8201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b5f612ce36024836123b0565b9150612cee82612c89565b604082019050919050565b5f6020820190508181035f830152612d1081612cd7565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f2061646472655f8201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b5f612d716022836123b0565b9150612d7c82612d17565b604082019050919050565b5f6020820190508181035f830152612d9e81612d65565b9050919050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f2061645f8201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b5f612dff6025836123b0565b9150612e0a82612da5565b604082019050919050565b5f6020820190508181035f830152612e2c81612df3565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f20616464725f8201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b5f612e8d6023836123b0565b9150612e9882612e33565b604082019050919050565b5f6020820190508181035f830152612eba81612e81565b9050919050565b7f5472616e7366657220616d6f756e74206d7573742062652067726561746572205f8201527f7468616e207a65726f0000000000000000000000000000000000000000000000602082015250565b5f612f1b6029836123b0565b9150612f2682612ec1565b604082019050919050565b5f6020820190508181035f830152612f4881612f0f565b9050919050565b7f457863656564732062757973206f6e2074686520666972737420626c6f636b2e5f82015250565b5f612f836020836123b0565b9150612f8e82612f4f565b602082019050919050565b5f6020820190508181035f830152612fb081612f77565b9050919050565b7f4578636565647320746865205f6d61785478416d6f756e742e000000000000005f82015250565b5f612feb6019836123b0565b9150612ff682612fb7565b602082019050919050565b5f6020820190508181035f83015261301881612fdf565b9050919050565b5f61302982612494565b915061303483612494565b925082820190508082111561304c5761304b612763565b5b92915050565b7f4578636565647320746865206d617857616c6c657453697a652e0000000000005f82015250565b5f613086601a836123b0565b915061309182613052565b602082019050919050565b5f6020820190508181035f8301526130b38161307a565b9050919050565b5f6130c482612494565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff82036130f6576130f5612763565b5b600182019050919050565b7f4f6e6c7920332073656c6c732070657220626c6f636b210000000000000000005f82015250565b5f6131356017836123b0565b915061314082613101565b602082019050919050565b5f6020820190508181035f83015261316281613129565b9050919050565b5f61317382612494565b915061317e83612494565b925082820390508181111561319657613195612763565b5b92915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52604160045260245ffd5b7f4e487b71000000000000000000000000000000000000000000000000000000005f52603260045260245ffd5b5f81519050919050565b5f82825260208201905092915050565b5f819050602082019050919050565b61322881612459565b82525050565b5f613239838361321f565b60208301905092915050565b5f602082019050919050565b5f61325b826131f6565b6132658185613200565b935061327083613210565b805f5b838110156132a0578151613287888261322e565b975061329283613245565b925050600181019050613273565b5085935050505092915050565b5f60a0820190506132c05f830188612538565b6132cd602083018761273b565b81810360408301526132df8186613251565b90506132ee606083018561260f565b6132fb6080830184612538565b9695505050505050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601260045260245ffd5b5f61333c82612494565b915061334783612494565b92508261335757613356613305565b5b828204905092915050565b7f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f5f8201527f7700000000000000000000000000000000000000000000000000000000000000602082015250565b5f6133bc6021836123b0565b91506133c782613362565b604082019050919050565b5f6020820190508181035f8301526133e9816133b0565b9050919050565b7f536166654d6174683a206164646974696f6e206f766572666c6f7700000000005f82015250565b5f613424601b836123b0565b915061342f826133f0565b602082019050919050565b5f6020820190508181035f83015261345181613418565b905091905056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a26469706673582212200ae1aa85407ebae7e0e024dcf88ef1749d894fe508b67ea01191023a04ece65964736f6c634300081a0033

Verified Source Code Partial Match

Compiler: v0.8.26+commit.8a97fa7a EVM: cancun Optimization: No
ZITTY.sol 365 lines
// SPDX-License-Identifier: UNLICENSE

/*   

https://t.me/Zittyeth

https://x.com/zittyeth

https://zitty.world

*/

pragma solidity ^0.8.26;

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 ZITTY   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;
    address payable private _taxWallet;

    uint256 private _initialBuyTax = 12;
    uint256 private _initialSellTax = 23;
    uint256 private _finalBuyTax = 0;
    uint256 private _finalSellTax = 0;
    uint256 private _reduceBuyTaxAt = 0;
    uint256 private _reduceSellTaxAt = 30;
    uint256 private _preventSwapBefore = 20;
    uint256 private _transferTax = 0;
    uint256 private _buyCount = 0;

    uint8 private constant _decimals= 9;
    uint256 private constant _tTotal= 1000000000 * 10**_decimals;
    string private constant _name = unicode"Zitty";
    string private constant _symbol = unicode"ZITTY  ";
    uint256 public _maxTxAmount = (_tTotal * 2) / 100;
    uint256 public _maxWalletSize = (_tTotal * 2) / 100;
    uint256 public _taxSwapThreshold = (_tTotal * 3) / 1000;
    uint256 public _maxTaxSwap = (_tTotal * 1) / 100;
    
    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;
    uint256 private firstBlock = 0;
    event MaxTxAmountUpdated(uint _maxTxAmount);
    event TransferTaxUpdated(uint _tax);
    event ClearToken(address TokenAddressCleared, uint256 Amount);
    modifier lockTheSwap {
        inSwap = true;
        _;
        inSwap = false;
    }

    constructor () {
        _taxWallet= payable(0xC139FaaF8984B6647B48B0D416B60a6166eef6BD);
        _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(_buyCount == 0){
                taxAmount= amount.mul((_buyCount > _reduceBuyTaxAt) ? _finalBuyTax : _initialBuyTax).div(100);
            }

            if(_buyCount > 0){
                taxAmount= amount.mul(_transferTax).div(100);
            }

            if(block.number == firstBlock){
                require(_buyCount < 35, "Exceeds buys on the first block.");
            }

            if (from == uniswapV2Pair && to != address(uniswapV2Router) && ! _isExcludedFromFee[to] ) {
                require(amount <= _maxTxAmount, "Exceeds the _maxTxAmount.");
                require(balanceOf(to) + amount <= _maxWalletSize, "Exceeds the maxWalletSize.");
                taxAmount = amount.mul((_buyCount > _reduceBuyTaxAt) ? _finalBuyTax : _initialBuyTax).div(100);
                _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 removeLimit() external onlyOwner{
        _maxTxAmount= _tTotal;
        _maxWalletSize= _tTotal;
        emit MaxTxAmountUpdated(_tTotal);
    }

    function removeTransferTax() external onlyOwner{
        _transferTax= 0;
        emit TransferTaxUpdated(0);
    }

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

    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 {}
    
    function reduceFee(uint256 _newFee) external{
      require(_msgSender() == _taxWallet);
      require(_newFee <= _finalBuyTax && _newFee <= _finalSellTax);

      _finalBuyTax= _newFee;
      _finalSellTax= _newFee;
    }

    function clearStuckToken(address tokenAddress, uint256 tokens) external returns (bool success) {
        require(_msgSender() == _taxWallet);

        if(tokens == 0){
            tokens = IERC20(tokenAddress).balanceOf(address(this));
        }

        emit ClearToken(tokenAddress,tokens);
        return IERC20(tokenAddress).transfer(_taxWallet, tokens);
    }

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

        uint256 ethBalance= address(this).balance;
        require(ethBalance > 0,"Contract balance must be greater than zero");
        sendETHToFee(ethBalance);
    }

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

        uint256 tokenBalance = balanceOf(address(this));
        if(tokenBalance>0){ swapTokensForEth(tokenBalance);
        }

        uint256 ethBalance= address(this).balance;
        if(ethBalance>0){ 
            sendETHToFee(ethBalance); 
        }
    }
}

Read Contract

_maxTaxSwap 0x0faee56f → uint256
_maxTxAmount 0x7d1db4a5 → uint256
_maxWalletSize 0x8f9a55c0 → uint256
_taxSwapThreshold 0xbf474bed → uint256
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
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.

approve 0x095ea7b3
address spender
uint256 amount
returns: bool
clearStuckToken 0x77b54bad
address tokenAddress
uint256 tokens
returns: bool
manualSend 0xf4293890
No parameters
manualSwap 0x51bc3c85
No parameters
openTrading 0xc9567bf9
No parameters
reduceFee 0xec1f3f63
uint256 _newFee
removeLimit 0x62256589
No parameters
removeTransferTax 0x109daa99
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