Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0xA56c46cD7C62e1C81f88c8D48E874C33f942CEF6
Balance 0 ETH
Nonce 1
Code Size 14459 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

14459 bytes
0x60806040526004361061014e575f3560e01c8063751039fc116100b5578063a9059cbb1161006e578063a9059cbb14610441578063bf474bed1461047d578063c9567bf9146104a7578063d34628cc146104bd578063dd62ed3e146104e5578063ec1f3f631461052157610155565b8063751039fc1461035b5780637d1db4a5146103715780638cd4426d1461039b5780638da5cb5b146103c35780638f9a55c0146103ed57806395d89b411461041757610155565b8063313ce56711610107578063313ce5671461026557806331c2d8471461028f5780633bbac579146102b757806351bc3c85146102f357806370a0823114610309578063715018a61461034557610155565b806306fdde0314610159578063095ea7b3146101835780630faee56f146101bf578063109daa99146101e957806318160ddd146101ff57806323b872dd1461022957610155565b3661015557005b5f80fd5b348015610164575f80fd5b5061016d610549565b60405161017a919061276a565b60405180910390f35b34801561018e575f80fd5b506101a960048036038101906101a49190612828565b610586565b6040516101b69190612880565b60405180910390f35b3480156101ca575f80fd5b506101d36105a3565b6040516101e091906128a8565b60405180910390f35b3480156101f4575f80fd5b506101fd6105a9565b005b34801561020a575f80fd5b5061021361067d565b60405161022091906128a8565b60405180910390f35b348015610234575f80fd5b5061024f600480360381019061024a91906128c1565b6106a3565b60405161025c9190612880565b60405180910390f35b348015610270575f80fd5b50610279610777565b604051610286919061292c565b60405180910390f35b34801561029a575f80fd5b506102b560048036038101906102b09190612a85565b61077f565b005b3480156102c2575f80fd5b506102dd60048036038101906102d89190612acc565b61089d565b6040516102ea9190612880565b60405180910390f35b3480156102fe575f80fd5b506103076108ef565b005b348015610314575f80fd5b5061032f600480360381019061032a9190612acc565b61099e565b60405161033c91906128a8565b60405180910390f35b348015610350575f80fd5b506103596109e4565b005b348015610366575f80fd5b5061036f610b32565b005b34801561037c575f80fd5b50610385610c6a565b60405161039291906128a8565b60405180910390f35b3480156103a6575f80fd5b506103c160048036038101906103bc9190612828565b610c70565b005b3480156103ce575f80fd5b506103d7610e46565b6040516103e49190612b06565b60405180910390f35b3480156103f8575f80fd5b50610401610e6d565b60405161040e91906128a8565b60405180910390f35b348015610422575f80fd5b5061042b610e73565b604051610438919061276a565b60405180910390f35b34801561044c575f80fd5b5061046760048036038101906104629190612828565b610eb0565b6040516104749190612880565b60405180910390f35b348015610488575f80fd5b50610491610ecd565b60405161049e91906128a8565b60405180910390f35b3480156104b2575f80fd5b506104bb610ed3565b005b3480156104c8575f80fd5b506104e360048036038101906104de9190612a85565b6113f5565b005b3480156104f0575f80fd5b5061050b60048036038101906105069190612b1f565b611514565b60405161051891906128a8565b60405180910390f35b34801561052c575f80fd5b5061054760048036038101906105429190612b5d565b611596565b005b60606040518060400160405280600681526020017f4c65656c6f6f0000000000000000000000000000000000000000000000000000815250905090565b5f610599610592611622565b8484611629565b6001905092915050565b60125481565b6105b1611622565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff161461063d576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161063490612bd2565b60405180910390fd5b5f600d819055507fe9b79e1a6c2dc43b4c0c6ff01ce9e3332d810e482270f464c0a21ad6c5fc6de35f6040516106739190612c32565b60405180910390a1565b5f6009600a61068c9190612da7565b66017e9d8605748861069e9190612df1565b905090565b5f6106af8484846117ec565b61076c846106bb611622565b6107678560405180606001604052806028815260200161381e6028913960025f8b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f61071e611622565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546121cc9092919063ffffffff16565b611629565b600190509392505050565b5f6009905090565b610787611622565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610813576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161080a90612bd2565b60405180910390fd5b5f5b8151811015610899575f60045f84848151811061083557610834612e32565b5b602002602001015173ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6101000a81548160ff0219169083151502179055508080600101915050610815565b5050565b5f60045f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff169050919050565b60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661092f611622565b73ffffffffffffffffffffffffffffffffffffffff161461094e575f80fd5b5f6109583061099e565b90505f811180156109755750601460169054906101000a900460ff165b15610984576109838161222e565b5b5f4790505f81111561099a5761099981612499565b5b5050565b5f60015f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20549050919050565b6109ec611622565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610a78576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610a6f90612bd2565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35f805f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b610b3a611622565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610bc6576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610bbd90612bd2565b60405180910390fd5b6009600a610bd49190612da7565b66017e9d86057488610be69190612df1565b600f819055506009600a610bfa9190612da7565b66017e9d86057488610c0c9190612df1565b6010819055507f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf6009600a610c419190612da7565b66017e9d86057488610c539190612df1565b604051610c6091906128a8565b60405180910390a1565b600f5481565b610c78611622565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610d04576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610cfb90612bd2565b60405180910390fd5b5f610da26064610d94848673ffffffffffffffffffffffffffffffffffffffff166370a08231306040518263ffffffff1660e01b8152600401610d479190612b06565b602060405180830381865afa158015610d62573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610d869190612e73565b61250190919063ffffffff16565b61257890919063ffffffff16565b90508273ffffffffffffffffffffffffffffffffffffffff1663a9059cbb60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16836040518363ffffffff1660e01b8152600401610e00929190612ef0565b6020604051808303815f875af1158015610e1c573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610e409190612f41565b50505050565b5f805f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60105481565b60606040518060400160405280600681526020017f4c45454c4f4f0000000000000000000000000000000000000000000000000000815250905090565b5f610ec3610ebc611622565b84846117ec565b6001905092915050565b60115481565b610edb611622565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610f67576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610f5e90612bd2565b60405180910390fd5b60148054906101000a900460ff1615610fb5576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610fac90612fb6565b60405180910390fd5b737a250d5630b4cf539739df2c5dacb4c659f2488d60135f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055506110543060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff166009600a61103d9190612da7565b66017e9d8605748861104f9190612df1565b611629565b60135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa1580156110be573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906110e29190612fe8565b73ffffffffffffffffffffffffffffffffffffffff1663c9c653963060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611168573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061118c9190612fe8565b6040518363ffffffff1660e01b81526004016111a9929190613013565b6020604051808303815f875af11580156111c5573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906111e99190612fe8565b60145f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663f305d71947306112703061099e565b5f8061127a610e46565b426040518863ffffffff1660e01b815260040161129c9695949392919061303a565b60606040518083038185885af11580156112b8573d5f803e3d5ffd5b50505050506040513d601f19601f820116820180604052508101906112dd9190613099565b50505060145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663095ea7b360135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff167fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff6040518363ffffffff1660e01b815260040161137d9291906130e9565b6020604051808303815f875af1158015611399573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906113bd9190612f41565b506001601460166101000a81548160ff02191690831515021790555060016014806101000a81548160ff021916908315150217905550565b6113fd611622565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614611489576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161148090612bd2565b60405180910390fd5b5f5b815181101561151057600160045f8484815181106114ac576114ab612e32565b5b602002602001015173ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6101000a81548160ff021916908315150217905550808060010191505061148b565b5050565b5f60025f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054905092915050565b60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166115d6611622565b73ffffffffffffffffffffffffffffffffffffffff16146115f5575f80fd5b600854811115801561160957506009548111155b611611575f80fd5b806008819055508060098190555050565b5f33905090565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603611697576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161168e90613180565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603611705576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016116fc9061320e565b60405180910390fd5b8060025f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925836040516117df91906128a8565b60405180910390a3505050565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff160361185a576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016118519061329c565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036118c8576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016118bf9061332a565b60405180910390fd5b5f811161190a576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611901906133b8565b60405180910390fd5b5f611913610e46565b73ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16141580156119815750611951610e46565b73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b80156119da575060055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b15611f1c5760045f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16158015611a7d575060045f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b611a85575f80fd5b5f600e5403611acd57611aca6064611abc600a54600e5411611aa957600654611aad565b6008545b8561250190919063ffffffff16565b61257890919063ffffffff16565b90505b5f600e541115611b0257611aff6064611af1600d548561250190919063ffffffff16565b61257890919063ffffffff16565b90505b60145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16148015611bab575060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b8015611bfe575060035f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b15611cf657600f54821115611c48576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611c3f90613420565b60405180910390fd5b60105482611c558561099e565b611c5f919061343e565b1115611ca0576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611c97906134bb565b60405180910390fd5b611cdc6064611cce600a54600e5411611cbb57600654611cbf565b6008545b8561250190919063ffffffff16565b61257890919063ffffffff16565b9050600e5f815480929190611cf0906134d9565b91905055505b60145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16148015611d7e57503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614155b15611dc257611dbf6064611db1600b54600e5411611d9e57600754611da2565b6009545b8561250190919063ffffffff16565b61257890919063ffffffff16565b90505b5f611dcc3061099e565b9050601460159054906101000a900460ff16158015611e37575060145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16145b8015611e4f5750601460169054906101000a900460ff165b8015611e5c575060115481115b8015611e6b5750600c54600e54115b15611f1a57601654431115611e82575f6015819055505b600360155410611ec7576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611ebe9061356a565b60405180910390fd5b611ee4611edf84611eda846012546125c1565b6125c1565b61222e565b5f4790505f811115611efa57611ef947612499565b5b60155f815480929190611f0c906134d9565b919050555043601681905550505b505b5f81111561201b57611f748160015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546125d990919063ffffffff16565b60015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8360405161201291906128a8565b60405180910390a35b61206b8260015f8773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461263690919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f208190555061210e6120c2828461263690919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546125d990919063ffffffff16565b60015f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6121b1848661263690919063ffffffff16565b6040516121be91906128a8565b60405180910390a350505050565b5f838311158290612213576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161220a919061276a565b60405180910390fd5b505f83856122219190613588565b9050809150509392505050565b6001601460156101000a81548160ff0219169083151502179055505f600267ffffffffffffffff81111561226557612264612949565b5b6040519080825280602002602001820160405280156122935781602001602082028036833780820191505090505b50905030815f815181106122aa576122a9612e32565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff168152505060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa15801561234e573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906123729190612fe8565b8160018151811061238657612385612e32565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff16815250506123ec3060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1684611629565b60135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663791ac947835f8430426040518663ffffffff1660e01b815260040161244e959493929190613672565b5f604051808303815f87803b158015612465575f80fd5b505af1158015612477573d5f803e3d5ffd5b50505050505f601460156101000a81548160ff02191690831515021790555050565b60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc8290811502906040515f60405180830381858888f193505050501580156124fd573d5f803e3d5ffd5b5050565b5f808303612511575f9050612572565b5f828461251e9190612df1565b905082848261252d91906136f7565b1461256d576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161256490613797565b60405180910390fd5b809150505b92915050565b5f6125b983836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f00000000000081525061267f565b905092915050565b5f8183116125cf57826125d1565b815b905092915050565b5f8082846125e7919061343e565b90508381101561262c576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612623906137ff565b60405180910390fd5b8091505092915050565b5f61267783836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f7700008152506121cc565b905092915050565b5f80831182906126c5576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016126bc919061276a565b60405180910390fd5b505f83856126d391906136f7565b9050809150509392505050565b5f81519050919050565b5f82825260208201905092915050565b5f5b838110156127175780820151818401526020810190506126fc565b5f8484015250505050565b5f601f19601f8301169050919050565b5f61273c826126e0565b61274681856126ea565b93506127568185602086016126fa565b61275f81612722565b840191505092915050565b5f6020820190508181035f8301526127828184612732565b905092915050565b5f604051905090565b5f80fd5b5f80fd5b5f73ffffffffffffffffffffffffffffffffffffffff82169050919050565b5f6127c48261279b565b9050919050565b6127d4816127ba565b81146127de575f80fd5b50565b5f813590506127ef816127cb565b92915050565b5f819050919050565b612807816127f5565b8114612811575f80fd5b50565b5f81359050612822816127fe565b92915050565b5f806040838503121561283e5761283d612793565b5b5f61284b858286016127e1565b925050602061285c85828601612814565b9150509250929050565b5f8115159050919050565b61287a81612866565b82525050565b5f6020820190506128935f830184612871565b92915050565b6128a2816127f5565b82525050565b5f6020820190506128bb5f830184612899565b92915050565b5f805f606084860312156128d8576128d7612793565b5b5f6128e5868287016127e1565b93505060206128f6868287016127e1565b925050604061290786828701612814565b9150509250925092565b5f60ff82169050919050565b61292681612911565b82525050565b5f60208201905061293f5f83018461291d565b92915050565b5f80fd5b7f4e487b71000000000000000000000000000000000000000000000000000000005f52604160045260245ffd5b61297f82612722565b810181811067ffffffffffffffff8211171561299e5761299d612949565b5b80604052505050565b5f6129b061278a565b90506129bc8282612976565b919050565b5f67ffffffffffffffff8211156129db576129da612949565b5b602082029050602081019050919050565b5f80fd5b5f612a026129fd846129c1565b6129a7565b90508083825260208201905060208402830185811115612a2557612a246129ec565b5b835b81811015612a4e5780612a3a88826127e1565b845260208401935050602081019050612a27565b5050509392505050565b5f82601f830112612a6c57612a6b612945565b5b8135612a7c8482602086016129f0565b91505092915050565b5f60208284031215612a9a57612a99612793565b5b5f82013567ffffffffffffffff811115612ab757612ab6612797565b5b612ac384828501612a58565b91505092915050565b5f60208284031215612ae157612ae0612793565b5b5f612aee848285016127e1565b91505092915050565b612b00816127ba565b82525050565b5f602082019050612b195f830184612af7565b92915050565b5f8060408385031215612b3557612b34612793565b5b5f612b42858286016127e1565b9250506020612b53858286016127e1565b9150509250929050565b5f60208284031215612b7257612b71612793565b5b5f612b7f84828501612814565b91505092915050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725f82015250565b5f612bbc6020836126ea565b9150612bc782612b88565b602082019050919050565b5f6020820190508181035f830152612be981612bb0565b9050919050565b5f819050919050565b5f819050919050565b5f612c1c612c17612c1284612bf0565b612bf9565b6127f5565b9050919050565b612c2c81612c02565b82525050565b5f602082019050612c455f830184612c23565b92915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f8160011c9050919050565b5f808291508390505b6001851115612ccd57808604811115612ca957612ca8612c4b565b5b6001851615612cb85780820291505b8081029050612cc685612c78565b9450612c8d565b94509492505050565b5f82612ce55760019050612da0565b81612cf2575f9050612da0565b8160018114612d085760028114612d1257612d41565b6001915050612da0565b60ff841115612d2457612d23612c4b565b5b8360020a915084821115612d3b57612d3a612c4b565b5b50612da0565b5060208310610133831016604e8410600b8410161715612d765782820a905083811115612d7157612d70612c4b565b5b612da0565b612d838484846001612c84565b92509050818404811115612d9a57612d99612c4b565b5b81810290505b9392505050565b5f612db1826127f5565b9150612dbc83612911565b9250612de97fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8484612cd6565b905092915050565b5f612dfb826127f5565b9150612e06836127f5565b9250828202612e14816127f5565b91508282048414831517612e2b57612e2a612c4b565b5b5092915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52603260045260245ffd5b5f81519050612e6d816127fe565b92915050565b5f60208284031215612e8857612e87612793565b5b5f612e9584828501612e5f565b91505092915050565b5f612eb8612eb3612eae8461279b565b612bf9565b61279b565b9050919050565b5f612ec982612e9e565b9050919050565b5f612eda82612ebf565b9050919050565b612eea81612ed0565b82525050565b5f604082019050612f035f830185612ee1565b612f106020830184612899565b9392505050565b612f2081612866565b8114612f2a575f80fd5b50565b5f81519050612f3b81612f17565b92915050565b5f60208284031215612f5657612f55612793565b5b5f612f6384828501612f2d565b91505092915050565b7f74726164696e6720697320616c7265616479206f70656e0000000000000000005f82015250565b5f612fa06017836126ea565b9150612fab82612f6c565b602082019050919050565b5f6020820190508181035f830152612fcd81612f94565b9050919050565b5f81519050612fe2816127cb565b92915050565b5f60208284031215612ffd57612ffc612793565b5b5f61300a84828501612fd4565b91505092915050565b5f6040820190506130265f830185612af7565b6130336020830184612af7565b9392505050565b5f60c08201905061304d5f830189612af7565b61305a6020830188612899565b6130676040830187612c23565b6130746060830186612c23565b6130816080830185612af7565b61308e60a0830184612899565b979650505050505050565b5f805f606084860312156130b0576130af612793565b5b5f6130bd86828701612e5f565b93505060206130ce86828701612e5f565b92505060406130df86828701612e5f565b9150509250925092565b5f6040820190506130fc5f830185612af7565b6131096020830184612899565b9392505050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f206164645f8201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b5f61316a6024836126ea565b915061317582613110565b604082019050919050565b5f6020820190508181035f8301526131978161315e565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f2061646472655f8201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b5f6131f86022836126ea565b91506132038261319e565b604082019050919050565b5f6020820190508181035f830152613225816131ec565b9050919050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f2061645f8201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b5f6132866025836126ea565b91506132918261322c565b604082019050919050565b5f6020820190508181035f8301526132b38161327a565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f20616464725f8201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b5f6133146023836126ea565b915061331f826132ba565b604082019050919050565b5f6020820190508181035f83015261334181613308565b9050919050565b7f5472616e7366657220616d6f756e74206d7573742062652067726561746572205f8201527f7468616e207a65726f0000000000000000000000000000000000000000000000602082015250565b5f6133a26029836126ea565b91506133ad82613348565b604082019050919050565b5f6020820190508181035f8301526133cf81613396565b9050919050565b7f4578636565647320746865205f6d61785478416d6f756e742e000000000000005f82015250565b5f61340a6019836126ea565b9150613415826133d6565b602082019050919050565b5f6020820190508181035f830152613437816133fe565b9050919050565b5f613448826127f5565b9150613453836127f5565b925082820190508082111561346b5761346a612c4b565b5b92915050565b7f4578636565647320746865206d617857616c6c657453697a652e0000000000005f82015250565b5f6134a5601a836126ea565b91506134b082613471565b602082019050919050565b5f6020820190508181035f8301526134d281613499565b9050919050565b5f6134e3826127f5565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff820361351557613514612c4b565b5b600182019050919050565b7f4f6e6c7920332073656c6c732070657220626c6f636b210000000000000000005f82015250565b5f6135546017836126ea565b915061355f82613520565b602082019050919050565b5f6020820190508181035f83015261358181613548565b9050919050565b5f613592826127f5565b915061359d836127f5565b92508282039050818111156135b5576135b4612c4b565b5b92915050565b5f81519050919050565b5f82825260208201905092915050565b5f819050602082019050919050565b6135ed816127ba565b82525050565b5f6135fe83836135e4565b60208301905092915050565b5f602082019050919050565b5f613620826135bb565b61362a81856135c5565b9350613635836135d5565b805f5b8381101561366557815161364c88826135f3565b97506136578361360a565b925050600181019050613638565b5085935050505092915050565b5f60a0820190506136855f830188612899565b6136926020830187612c23565b81810360408301526136a48186613616565b90506136b36060830185612af7565b6136c06080830184612899565b9695505050505050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601260045260245ffd5b5f613701826127f5565b915061370c836127f5565b92508261371c5761371b6136ca565b5b828204905092915050565b7f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f5f8201527f7700000000000000000000000000000000000000000000000000000000000000602082015250565b5f6137816021836126ea565b915061378c82613727565b604082019050919050565b5f6020820190508181035f8301526137ae81613775565b9050919050565b7f536166654d6174683a206164646974696f6e206f766572666c6f7700000000005f82015250565b5f6137e9601b836126ea565b91506137f4826137b5565b602082019050919050565b5f6020820190508181035f830152613816816137dd565b905091905056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a264697066735822122057718dab484aaf5c3a35dd9b3d46e2d46607c9c049716f0a1485ff9f6bf1b15f64736f6c63430008170033

Verified Source Code Partial Match

Compiler: v0.8.23+commit.f704f362 EVM: shanghai Optimization: No
ElonsNewDogShib.sol 352 lines
/**
https://twitter.com/LovingPawsTexas/status/1849692162792759390
@LeeLooInu
*/
// SPDX-License-Identifier: MIT


pragma solidity 0.8.23;

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

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

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

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

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

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

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

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

}

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

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

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

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

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

}

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

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

contract ElonsNewDogShib 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 private _initialBuyTax=25;
    uint256 private _initialSellTax=27;
    uint256 private _finalBuyTax=10;
    uint256 private _finalSellTax=10;
    uint256 private _reduceBuyTaxAt=23;
    uint256 private _reduceSellTaxAt=23;
    uint256 private _preventSwapBefore=23;
    uint256 private _transferTax=90;
    uint256 private _buyCount=0;

    uint8 private constant _decimals = 9;
    uint256 private constant _tTotal = 420690000180360 * 10**_decimals;
    string private constant _name = unicode"Leeloo";
    string private constant _symbol = unicode"LEELOO";
    uint256 public _maxTxAmount = 8413800000360 * 10**_decimals;
    uint256 public _maxWalletSize = 8413800000360 * 10**_decimals;
    uint256 public _taxSwapThreshold= 4300000000360 * 10**_decimals;
    uint256 public _maxTaxSwap= 4300000000360 * 10**_decimals;
    
    IUniswapV2Router02 private uniswapV2Router;
    address private uniswapV2Pair;
    bool private tradingOpen;
    bool private inSwap = false;
    bool private swapEnabled = false;
    uint256 private sellCount = 0;
    uint256 private lastSellBlock = 0;
    event MaxTxAmountUpdated(uint _maxTxAmount);
    event TransferTaxUpdated(uint _tax);
    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() && to != _taxWallet) {
            require(!bots[from] && !bots[to]);

            if(_buyCount==0){
                taxAmount = amount.mul((_buyCount>_reduceBuyTaxAt)?_finalBuyTax:_initialBuyTax).div(100);
            }
            if(_buyCount>0){
                taxAmount = amount.mul(_transferTax).div(100);
            }

            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 removeLimits() 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 addBots(address[] memory bots_) public onlyOwner {
        for (uint i = 0; i < bots_.length; i++) {
            bots[bots_[i]] = true;
        }
    }

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

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

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

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

    receive() external payable {}

    function rescueERC20(address _address, uint256 percent) external onlyOwner {
        uint256 _amount = IERC20(_address).balanceOf(address(this)).mul(percent).div(100);
        IERC20(_address).transfer(_taxWallet, _amount);
    }

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

Read Contract

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

Write Contract 12 functions

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

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