Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x1E14071Cc232C452df1419CD67B4D768F6b9BA64
Balance 0 ETH
Nonce 1
Code Size 13362 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

13362 bytes
0x60806040526004361061019f575f3560e01c8063715018a6116100eb578063cb4e162b11610089578063dd62ed3e11610063578063dd62ed3e14610560578063f2fde38b1461059c578063f442d3fb146105c4578063f8b45b05146105ec576101a6565b8063cb4e162b146104f8578063d18afa8514610522578063d55454621461054a576101a6565b806395d89b41116100c557806395d89b4114610440578063a457c2d71461046a578063a9059cbb146104a6578063c9567bf9146104e2576101a6565b8063715018a6146103ea578063751039fc146104005780638da5cb5b14610416576101a6565b806323b872dd1161015857806339e7fddc1161013257806339e7fddc146103465780635564ad711461037057806362aaff3a1461038657806370a08231146103ae576101a6565b806323b872dd146102a4578063313ce567146102e0578063395093511461030a576101a6565b8063056939da146101aa57806306fdde03146101d4578063095ea7b3146101fe5780630f7b16f01461023a57806318160ddd146102645780631fac6a3b1461028e576101a6565b366101a657005b5f80fd5b3480156101b5575f80fd5b506101be610616565b6040516101cb91906122b4565b60405180910390f35b3480156101df575f80fd5b506101e861063b565b6040516101f5919061233d565b60405180910390f35b348015610209575f80fd5b50610224600480360381019061021f91906123be565b6106cb565b6040516102319190612416565b60405180910390f35b348015610245575f80fd5b5061024e6106ed565b60405161025b919061243e565b60405180910390f35b34801561026f575f80fd5b506102786106f3565b604051610285919061243e565b60405180910390f35b348015610299575f80fd5b506102a26106fc565b005b3480156102af575f80fd5b506102ca60048036038101906102c59190612457565b6107d6565b6040516102d79190612416565b60405180910390f35b3480156102eb575f80fd5b506102f4610804565b60405161030191906124c2565b60405180910390f35b348015610315575f80fd5b50610330600480360381019061032b91906123be565b61080c565b60405161033d9190612416565b60405180910390f35b348015610351575f80fd5b5061035a6108b1565b60405161036791906122b4565b60405180910390f35b34801561037b575f80fd5b506103846108d5565b005b348015610391575f80fd5b506103ac60048036038101906103a79190612516565b61095a565b005b3480156103b9575f80fd5b506103d460048036038101906103cf9190612541565b610ae4565b6040516103e1919061243e565b60405180910390f35b3480156103f5575f80fd5b506103fe610b29565b005b34801561040b575f80fd5b50610414610bb0565b005b348015610421575f80fd5b5061042a610c3c565b60405161043791906122b4565b60405180910390f35b34801561044b575f80fd5b50610454610c64565b604051610461919061233d565b60405180910390f35b348015610475575f80fd5b50610490600480360381019061048b91906123be565b610cf4565b60405161049d9190612416565b60405180910390f35b3480156104b1575f80fd5b506104cc60048036038101906104c791906123be565b610dd8565b6040516104d99190612416565b60405180910390f35b3480156104ed575f80fd5b506104f6610dfa565b005b348015610503575f80fd5b5061050c611031565b604051610519919061243e565b60405180910390f35b34801561052d575f80fd5b506105486004803603810190610543919061256c565b611037565b005b348015610555575f80fd5b5061055e6110f6565b005b34801561056b575f80fd5b50610586600480360381019061058191906125aa565b61117b565b604051610593919061243e565b60405180910390f35b3480156105a7575f80fd5b506105c260048036038101906105bd9190612541565b6111fd565b005b3480156105cf575f80fd5b506105ea60048036038101906105e591906125e8565b6112f3565b005b3480156105f7575f80fd5b50610600611473565b60405161060d919061243e565b60405180910390f35b60065f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b60606003805461064a90612640565b80601f016020809104026020016040519081016040528092919081815260200182805461067690612640565b80156106c15780601f10610698576101008083540402835291602001916106c1565b820191905f5260205f20905b8154815290600101906020018083116106a457829003601f168201915b5050505050905090565b5f806106d5611479565b90506106e2818585611480565b600191505092915050565b60075481565b5f600254905090565b7f00000000000000000000000025fcaa2016ddec38280d635e81581880a53f05a373ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614806107885750610759610c3c565b73ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff16145b610790575f80fd5b3373ffffffffffffffffffffffffffffffffffffffff166108fc4790811502906040515f60405180830381858888f193505050501580156107d3573d5f803e3d5ffd5b50565b5f806107e0611479565b90506107ed858285611643565b6107f88585856116ce565b60019150509392505050565b5f6012905090565b5f80610816611479565b90506108a681858560015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8973ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546108a1919061269d565b611480565b600191505092915050565b7f00000000000000000000000025fcaa2016ddec38280d635e81581880a53f05a381565b6108dd611479565b73ffffffffffffffffffffffffffffffffffffffff166108fb610c3c565b73ffffffffffffffffffffffffffffffffffffffff1614610951576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016109489061271a565b60405180910390fd5b5f600881905550565b7f00000000000000000000000025fcaa2016ddec38280d635e81581880a53f05a373ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614806109e657506109b7610c3c565b73ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff16145b6109ee575f80fd5b8073ffffffffffffffffffffffffffffffffffffffff1663a9059cbb338373ffffffffffffffffffffffffffffffffffffffff166370a08231306040518263ffffffff1660e01b8152600401610a4491906122b4565b602060405180830381865afa158015610a5f573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610a83919061274c565b6040518363ffffffff1660e01b8152600401610aa0929190612777565b6020604051808303815f875af1158015610abc573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610ae091906127c8565b5050565b5f805f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20549050919050565b610b31611479565b73ffffffffffffffffffffffffffffffffffffffff16610b4f610c3c565b73ffffffffffffffffffffffffffffffffffffffff1614610ba5576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610b9c9061271a565b60405180910390fd5b610bae5f611b48565b565b610bb8611479565b73ffffffffffffffffffffffffffffffffffffffff16610bd6610c3c565b73ffffffffffffffffffffffffffffffffffffffff1614610c2c576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610c239061271a565b60405180910390fd5b5f6008819055505f600781905550565b5f60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b606060048054610c7390612640565b80601f0160208091040260200160405190810160405280929190818152602001828054610c9f90612640565b8015610cea5780601f10610cc157610100808354040283529160200191610cea565b820191905f5260205f20905b815481529060010190602001808311610ccd57829003601f168201915b5050505050905090565b5f80610cfe611479565b90505f60015f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054905083811015610dbf576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610db690612863565b60405180910390fd5b610dcc8286868403611480565b60019250505092915050565b5f80610de2611479565b9050610def8185856116ce565b600191505092915050565b610e02611479565b73ffffffffffffffffffffffffffffffffffffffff16610e20610c3c565b73ffffffffffffffffffffffffffffffffffffffff1614610e76576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610e6d9061271a565b60405180910390fd5b737a250d5630b4cf539739df2c5dacb4c659f2488d73ffffffffffffffffffffffffffffffffffffffff1663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610ed3573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610ef79190612895565b73ffffffffffffffffffffffffffffffffffffffff1663e6a4390530737a250d5630b4cf539739df2c5dacb4c659f2488d73ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610f70573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610f949190612895565b6040518363ffffffff1660e01b8152600401610fb19291906128c0565b602060405180830381865afa158015610fcc573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610ff09190612895565b60065f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b60095481565b7f00000000000000000000000025fcaa2016ddec38280d635e81581880a53f05a373ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614806110c35750611094610c3c565b73ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff16145b6110cb575f80fd5b600482111580156110dc57505f8114155b6110e4575f80fd5b81600a8190555080600b819055505050565b6110fe611479565b73ffffffffffffffffffffffffffffffffffffffff1661111c610c3c565b73ffffffffffffffffffffffffffffffffffffffff1614611172576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016111699061271a565b60405180910390fd5b5f600781905550565b5f60015f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054905092915050565b611205611479565b73ffffffffffffffffffffffffffffffffffffffff16611223610c3c565b73ffffffffffffffffffffffffffffffffffffffff1614611279576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016112709061271a565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff16036112e7576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016112de90612957565b60405180910390fd5b6112f081611b48565b50565b7f00000000000000000000000025fcaa2016ddec38280d635e81581880a53f05a373ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff16148061137f5750611350610c3c565b73ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff16145b611387575f80fd5b6113b7620186a06113a9600161139b6106f3565b611c0b90919063ffffffff16565b611c2090919063ffffffff16565b8110156113f9576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016113f0906129e5565b60405180910390fd5b6114276064611419600261140b6106f3565b611c0b90919063ffffffff16565b611c2090919063ffffffff16565b811115611469576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161146090612a73565b60405180910390fd5b8060098190555050565b60085481565b5f33905090565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16036114ee576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016114e590612b01565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff160361155c576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161155390612b8f565b60405180910390fd5b8060015f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92583604051611636919061243e565b60405180910390a3505050565b5f61164e848461117b565b90507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff81146116c857818110156116ba576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016116b190612bf7565b60405180910390fd5b6116c78484848403611480565b5b50505050565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff160361173c576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161173390612c85565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036117aa576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016117a190612d13565b60405180910390fd5b5f81116117ec576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016117e390612da1565b60405180910390fd5b5f600e5f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16806118885750600e5f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff165b90505f73ffffffffffffffffffffffffffffffffffffffff1660065f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff161415806118e35750805b611922576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161191990612e09565b60405180910390fd5b5f60065f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff161490505f60065f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168673ffffffffffffffffffffffffffffffffffffffff1614905080806119d15750815b80156119de57505f600754115b80156119e8575082155b15611a3357600754841115611a32576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611a2990612ebd565b60405180910390fd5b5b81158015611a4257505f600854115b8015611a4c575082155b15611aaa5760085484611a5e87610ae4565b611a68919061269d565b1115611aa9576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611aa090612f71565b60405180910390fd5b5b600954611ab630610ae4565b10158015611ad05750600d5f9054906101000a900460ff16155b8015611ad95750815b8015611ae3575082155b8015611af45750611af384611c35565b5b15611b35576001600d5f6101000a81548160ff021916908315150217905550611b1b611c90565b5f600d5f6101000a81548160ff0219169083151502179055505b611b40868686611fe1565b505050505050565b5f60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1690508160055f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508173ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35050565b5f8183611c189190612f8f565b905092915050565b5f8183611c2d9190612ffd565b905092915050565b5f80600b5414611c5457600b54600954611c4f9190612ffd565b611c56565b5f5b8210158015611c8957506002600c5f4381526020019081526020015f205f815480929190611c839061302d565b91905055105b9050919050565b5f611c9a30610ae4565b90505f8103611ca95750611fdf565b600954811115611cb95760095490505b5f4790505f600267ffffffffffffffff811115611cd957611cd8613074565b5b604051908082528060200260200182016040528015611d075781602001602082028036833780820191505090505b50905030815f81518110611d1e57611d1d6130a1565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff1681525050737a250d5630b4cf539739df2c5dacb4c659f2488d73ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611db5573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190611dd99190612895565b81600181518110611ded57611dec6130a1565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff1681525050611e4630737a250d5630b4cf539739df2c5dacb4c659f2488d85611480565b737a250d5630b4cf539739df2c5dacb4c659f2488d73ffffffffffffffffffffffffffffffffffffffff1663791ac947845f8430426040518663ffffffff1660e01b8152600401611e9b9594939291906131c7565b5f604051808303815f87803b158015611eb2575f80fd5b505af1158015611ec4573d5f803e3d5ffd5b505050505f611edc834761225690919063ffffffff16565b90505f611f066064611ef8600585611c0b90919063ffffffff16565b611c2090919063ffffffff16565b9050611f1b818361225690919063ffffffff16565b91507f00000000000000000000000025fcaa2016ddec38280d635e81581880a53f05a373ffffffffffffffffffffffffffffffffffffffff166108fc8390811502906040515f60405180830381858888f19350505050158015611f80573d5f803e3d5ffd5b50730e7393a2dcda4c89c4ca3866e1961274711595c173ffffffffffffffffffffffffffffffffffffffff166108fc8290811502906040515f60405180830381858888f19350505050158015611fd8573d5f803e3d5ffd5b5050505050505b565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff160361204f576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016120469061328f565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036120bd576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016120b49061331d565b60405180910390fd5b6120c883838361226b565b5f805f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205490508181101561214b576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612142906133ab565b60405180910390fd5b8181035f808673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2081905550815f808573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8282546121d9919061269d565b925050819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8460405161223d919061243e565b60405180910390a3612250848484612270565b50505050565b5f818361226391906133c9565b905092915050565b505050565b505050565b5f73ffffffffffffffffffffffffffffffffffffffff82169050919050565b5f61229e82612275565b9050919050565b6122ae81612294565b82525050565b5f6020820190506122c75f8301846122a5565b92915050565b5f81519050919050565b5f82825260208201905092915050565b8281835e5f83830152505050565b5f601f19601f8301169050919050565b5f61230f826122cd565b61231981856122d7565b93506123298185602086016122e7565b612332816122f5565b840191505092915050565b5f6020820190508181035f8301526123558184612305565b905092915050565b5f80fd5b61236a81612294565b8114612374575f80fd5b50565b5f8135905061238581612361565b92915050565b5f819050919050565b61239d8161238b565b81146123a7575f80fd5b50565b5f813590506123b881612394565b92915050565b5f80604083850312156123d4576123d361235d565b5b5f6123e185828601612377565b92505060206123f2858286016123aa565b9150509250929050565b5f8115159050919050565b612410816123fc565b82525050565b5f6020820190506124295f830184612407565b92915050565b6124388161238b565b82525050565b5f6020820190506124515f83018461242f565b92915050565b5f805f6060848603121561246e5761246d61235d565b5b5f61247b86828701612377565b935050602061248c86828701612377565b925050604061249d868287016123aa565b9150509250925092565b5f60ff82169050919050565b6124bc816124a7565b82525050565b5f6020820190506124d55f8301846124b3565b92915050565b5f6124e582612294565b9050919050565b6124f5816124db565b81146124ff575f80fd5b50565b5f81359050612510816124ec565b92915050565b5f6020828403121561252b5761252a61235d565b5b5f61253884828501612502565b91505092915050565b5f602082840312156125565761255561235d565b5b5f61256384828501612377565b91505092915050565b5f80604083850312156125825761258161235d565b5b5f61258f858286016123aa565b92505060206125a0858286016123aa565b9150509250929050565b5f80604083850312156125c0576125bf61235d565b5b5f6125cd85828601612377565b92505060206125de85828601612377565b9150509250929050565b5f602082840312156125fd576125fc61235d565b5b5f61260a848285016123aa565b91505092915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52602260045260245ffd5b5f600282049050600182168061265757607f821691505b60208210810361266a57612669612613565b5b50919050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f6126a78261238b565b91506126b28361238b565b92508282019050808211156126ca576126c9612670565b5b92915050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725f82015250565b5f6127046020836122d7565b915061270f826126d0565b602082019050919050565b5f6020820190508181035f830152612731816126f8565b9050919050565b5f8151905061274681612394565b92915050565b5f602082840312156127615761276061235d565b5b5f61276e84828501612738565b91505092915050565b5f60408201905061278a5f8301856122a5565b612797602083018461242f565b9392505050565b6127a7816123fc565b81146127b1575f80fd5b50565b5f815190506127c28161279e565b92915050565b5f602082840312156127dd576127dc61235d565b5b5f6127ea848285016127b4565b91505092915050565b7f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f775f8201527f207a65726f000000000000000000000000000000000000000000000000000000602082015250565b5f61284d6025836122d7565b9150612858826127f3565b604082019050919050565b5f6020820190508181035f83015261287a81612841565b9050919050565b5f8151905061288f81612361565b92915050565b5f602082840312156128aa576128a961235d565b5b5f6128b784828501612881565b91505092915050565b5f6040820190506128d35f8301856122a5565b6128e060208301846122a5565b9392505050565b7f4f776e61626c653a206e6577206f776e657220697320746865207a65726f20615f8201527f6464726573730000000000000000000000000000000000000000000000000000602082015250565b5f6129416026836122d7565b915061294c826128e7565b604082019050919050565b5f6020820190508181035f83015261296e81612935565b9050919050565b7f53776170207468726573686f6c642063616e6e6f74206265206c6f77657220745f8201527f68616e20302e3030312520746f74616c20737570706c792e0000000000000000602082015250565b5f6129cf6038836122d7565b91506129da82612975565b604082019050919050565b5f6020820190508181035f8301526129fc816129c3565b9050919050565b7f53776170207468726573686f6c642063616e6e6f7420626520686967686572205f8201527f7468616e20322520746f74616c20737570706c792e0000000000000000000000602082015250565b5f612a5d6035836122d7565b9150612a6882612a03565b604082019050919050565b5f6020820190508181035f830152612a8a81612a51565b9050919050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f206164645f8201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b5f612aeb6024836122d7565b9150612af682612a91565b604082019050919050565b5f6020820190508181035f830152612b1881612adf565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f2061646472655f8201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b5f612b796022836122d7565b9150612b8482612b1f565b604082019050919050565b5f6020820190508181035f830152612ba681612b6d565b9050919050565b7f45524332303a20696e73756666696369656e7420616c6c6f77616e63650000005f82015250565b5f612be1601d836122d7565b9150612bec82612bad565b602082019050919050565b5f6020820190508181035f830152612c0e81612bd5565b9050919050565b7f5472616e736665722066726f6d20746865207a65726f2061646472657373206e5f8201527f6f7420616c6c6f7765642e000000000000000000000000000000000000000000602082015250565b5f612c6f602b836122d7565b9150612c7a82612c15565b604082019050919050565b5f6020820190508181035f830152612c9c81612c63565b9050919050565b7f5472616e7366657220746f20746865207a65726f2061646472657373206e6f745f8201527f20616c6c6f7765642e0000000000000000000000000000000000000000000000602082015250565b5f612cfd6029836122d7565b9150612d0882612ca3565b604082019050919050565b5f6020820190508181035f830152612d2a81612cf1565b9050919050565b7f5472616e7366657220616d6f756e74206d7573742062652067726561746572205f8201527f7468616e207a65726f2e00000000000000000000000000000000000000000000602082015250565b5f612d8b602a836122d7565b9150612d9682612d31565b604082019050919050565b5f6020820190508181035f830152612db881612d7f565b9050919050565b7f4c69717569646974792070616972206e6f742079657420637265617465642e005f82015250565b5f612df3601f836122d7565b9150612dfe82612dbf565b602082019050919050565b5f6020820190508181035f830152612e2081612de7565b9050919050565b7f537761702076616c75652065786365656473206d6178207377617020616d6f755f8201527f6e742c2074727920616761696e2077697468206c65737320737761702076616c60208201527f75652e0000000000000000000000000000000000000000000000000000000000604082015250565b5f612ea76043836122d7565b9150612eb282612e27565b606082019050919050565b5f6020820190508181035f830152612ed481612e9b565b9050919050565b7f42616c616e63652065786365656473206d617820686f6c64696e677320616d6f5f8201527f756e742c20636f6e7369646572207573696e672061207365636f6e642077616c60208201527f6c65742e00000000000000000000000000000000000000000000000000000000604082015250565b5f612f5b6044836122d7565b9150612f6682612edb565b606082019050919050565b5f6020820190508181035f830152612f8881612f4f565b9050919050565b5f612f998261238b565b9150612fa48361238b565b9250828202612fb28161238b565b91508282048414831517612fc957612fc8612670565b5b5092915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601260045260245ffd5b5f6130078261238b565b91506130128361238b565b92508261302257613021612fd0565b5b828204905092915050565b5f6130378261238b565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff820361306957613068612670565b5b600182019050919050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52604160045260245ffd5b7f4e487b71000000000000000000000000000000000000000000000000000000005f52603260045260245ffd5b5f819050919050565b5f819050919050565b5f6130fa6130f56130f0846130ce565b6130d7565b61238b565b9050919050565b61310a816130e0565b82525050565b5f81519050919050565b5f82825260208201905092915050565b5f819050602082019050919050565b61314281612294565b82525050565b5f6131538383613139565b60208301905092915050565b5f602082019050919050565b5f61317582613110565b61317f818561311a565b935061318a8361312a565b805f5b838110156131ba5781516131a18882613148565b97506131ac8361315f565b92505060018101905061318d565b5085935050505092915050565b5f60a0820190506131da5f83018861242f565b6131e76020830187613101565b81810360408301526131f9818661316b565b905061320860608301856122a5565b613215608083018461242f565b9695505050505050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f2061645f8201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b5f6132796025836122d7565b91506132848261321f565b604082019050919050565b5f6020820190508181035f8301526132a68161326d565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f20616464725f8201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b5f6133076023836122d7565b9150613312826132ad565b604082019050919050565b5f6020820190508181035f830152613334816132fb565b9050919050565b7f45524332303a207472616e7366657220616d6f756e74206578636565647320625f8201527f616c616e63650000000000000000000000000000000000000000000000000000602082015250565b5f6133956026836122d7565b91506133a08261333b565b604082019050919050565b5f6020820190508181035f8301526133c281613389565b9050919050565b5f6133d38261238b565b91506133de8361238b565b92508282039050818111156133f6576133f5612670565b5b9291505056fea2646970667358221220c56303cea8eec04689df1499985ab76805a22c9a06eda2c8295b0ec8a57e213564736f6c634300081a0033

Verified Source Code Partial Match

Compiler: v0.8.26+commit.8a97fa7a EVM: cancun Optimization: No
HIM.sol 462 lines
// SPDX-License-Identifier: MIT

  /*
      Website: https://www.pedokris.com/
    X/Twitter: https://x.com/himtojail
    Telegram: https://t.me/himtojail

    Send $HIM to JAIL!
  */
  
  pragma solidity ^0.8.26;

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

      function _msgData() internal view virtual returns (bytes calldata) {
          return msg.data;
      }
  }

  interface IERC20 {
      function totalSupply() external view returns (uint256);
      function balanceOf(address account) external view returns (uint256);
      function transfer(address to, 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 from,
          address to,
          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);
  }

  interface IERC20Metadata is IERC20 {
      function name() external view returns (string memory);
      function symbol() external view returns (string memory);
      function decimals() external view returns (uint8);
  }

  contract ERC20 is Context, IERC20, IERC20Metadata {
      mapping(address => uint256) private _balances;
      mapping(address => mapping(address => uint256)) private _allowances;

      uint256 private _totalSupply;

      string private _name;
      string private _symbol;

      constructor(string memory name_, string memory symbol_) {
          _name = name_;
          _symbol = symbol_;
      }

      function name() public view virtual override returns (string memory) {
          return _name;
      }

      function symbol() public view virtual override returns (string memory) {
          return _symbol;
      }

      function decimals() public view virtual override returns (uint8) {
          return 18;
      }

      function totalSupply() public view virtual override returns (uint256) {
          return _totalSupply;
      }

      function balanceOf(address account) public view virtual override returns (uint256) {
          return _balances[account];
      }

      function transfer(address to, uint256 amount) public virtual override returns (bool) {
          address owner = _msgSender();
          _transfer(owner, to, amount);
          return true;
      }

      function allowance(address owner, address spender) public view virtual override returns (uint256) {
          return _allowances[owner][spender];
      }

      function approve(address spender, uint256 amount) public virtual override returns (bool) {
          address owner = _msgSender();
          _approve(owner, spender, amount);
          return true;
      }

      function transferFrom(
          address from,
          address to,
          uint256 amount
      ) public virtual override returns (bool) {
          address spender = _msgSender();
          _spendAllowance(from, spender, amount);
          _transfer(from, to, amount);
          return true;
      }

      function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
          address owner = _msgSender();
          _approve(owner, spender, _allowances[owner][spender] + addedValue);
          return true;
      }

      function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
          address owner = _msgSender();
          uint256 currentAllowance = _allowances[owner][spender];
          require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");
          unchecked {
              _approve(owner, spender, currentAllowance - subtractedValue);
          }

          return true;
      }

      function _transfer(
          address from,
          address to,
          uint256 amount
      ) internal virtual {
          require(from != address(0), "ERC20: transfer from the zero address");
          require(to != address(0), "ERC20: transfer to the zero address");

          _beforeTokenTransfer(from, to, amount);

          uint256 fromBalance = _balances[from];
          require(fromBalance >= amount, "ERC20: transfer amount exceeds balance");
          unchecked {
              _balances[from] = fromBalance - amount;
          }
          _balances[to] += amount;

          emit Transfer(from, to, amount);

          _afterTokenTransfer(from, to, amount);
      }

      function _mint(address account, uint256 amount) internal virtual {
          require(account != address(0), "ERC20: mint to the zero address");

          _beforeTokenTransfer(address(0), account, amount);

          _totalSupply += amount;
          _balances[account] += amount;
          emit Transfer(address(0), account, amount);

          _afterTokenTransfer(address(0), account, amount);
      }

      function _burn(address account, uint256 amount) internal virtual {
          require(account != address(0), "ERC20: burn from the zero address");

          _beforeTokenTransfer(account, address(0), amount);

          uint256 accountBalance = _balances[account];
          require(accountBalance >= amount, "ERC20: burn amount exceeds balance");
          unchecked {
              _balances[account] = accountBalance - amount;
          }
          _totalSupply -= amount;

          emit Transfer(account, address(0), amount);

          _afterTokenTransfer(account, address(0), amount);
      }

      function _approve(
          address owner,
          address spender,
          uint256 amount
      ) internal virtual {
          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 _spendAllowance(
          address owner,
          address spender,
          uint256 amount
      ) internal virtual {
          uint256 currentAllowance = allowance(owner, spender);
          if (currentAllowance != type(uint256).max) {
              require(currentAllowance >= amount, "ERC20: insufficient allowance");
              unchecked {
                  _approve(owner, spender, currentAllowance - amount);
              }
          }
      }

      function _beforeTokenTransfer(
          address from,
          address to,
          uint256 amount
      ) internal virtual {}

      function _afterTokenTransfer(
          address from,
          address to,
          uint256 amount
      ) internal virtual {}
  }

  abstract contract Ownable is Context {
      address private _owner;

      event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);

      constructor() {
          _transferOwnership(_msgSender());
      }

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

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

      function renounceOwnership() public virtual onlyOwner {
          _transferOwnership(address(0));
      }

      function transferOwnership(address newOwner) public virtual onlyOwner {
          require(newOwner != address(0), "Ownable: new owner is the zero address");
          _transferOwnership(newOwner);
      }

      function _transferOwnership(address newOwner) internal virtual {
          address oldOwner = _owner;
          _owner = newOwner;
          emit OwnershipTransferred(oldOwner, newOwner);
      }
  }

  library SafeMath {
      function add(uint256 a, uint256 b) internal pure returns (uint256) {
          return a + b;
      }

      function sub(uint256 a, uint256 b) internal pure returns (uint256) {
          return a - b;
      }

      function mul(uint256 a, uint256 b) internal pure returns (uint256) {
          return a * b;
      }

      function div(uint256 a, uint256 b) internal pure returns (uint256) {
          return a / b;
      }

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

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

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

  interface IUniswapV2Router02 {
      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);
      function swapExactTokensForETHSupportingFeeOnTransferTokens(
          uint amountIn,
          uint amountOutMin,
          address[] calldata path,
          address to,
          uint deadline
      ) external;
  }

contract HIM is ERC20, Ownable {
    using SafeMath for uint256;

    IUniswapV2Router02 private constant _router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);

    address public v2Pair;
    address public immutable feeAddr;

    uint256 public maxSwapTx;
    uint256 public maxWallet;
    uint256 public feeThreshold;
    uint256 private _contractSwapMax = 3;
    uint256 private _contractSwapMin = 7;
    mapping(uint256 => uint256) private _swapBlocks;

    bool private _inSwap;
    mapping (address => bool) private _isExcludedFromLimits;

    constructor() ERC20("Pedo Kris", "HIM") payable {
        uint256 totalSupply = 69420000000 * 1e18;
        uint256 lpSupply = totalSupply.mul(80).div(100);
        uint256 caSupply = totalSupply.mul(20).div(100);

        maxSwapTx = totalSupply.mul(11).div(1000);
        maxWallet = totalSupply.mul(2).div(100);
        feeThreshold = totalSupply.mul(5).div(1000);

        feeAddr = 0x25FCaa2016DDEc38280D635e81581880a53f05A3;

        _isExcludedFromLimits[feeAddr] = true;
        _isExcludedFromLimits[msg.sender] = true;
        _isExcludedFromLimits[tx.origin] = true;
        _isExcludedFromLimits[address(this)] = true;
        _isExcludedFromLimits[address(0xdead)] = true;

        _mint(address(this), caSupply);

        _mint(msg.sender, lpSupply);
    }

    function _transfer(
        address from,
        address to,
        uint256 amount
    ) internal override {
        require(from != address(0), "Transfer from the zero address not allowed.");
        require(to != address(0), "Transfer to the zero address not allowed.");
        require(amount > 0, 'Transfer amount must be greater than zero.');

        bool excluded = _isExcludedFromLimits[from] || _isExcludedFromLimits[to];
        require(v2Pair != address(0) || excluded, "Liquidity pair not yet created.");

        bool isSell = to == v2Pair;
        bool isBuy = from == v2Pair;

        if ((isBuy || isSell) && maxSwapTx > 0 && !excluded)
            require(amount <= maxSwapTx, "Swap value exceeds max swap amount, try again with less swap value.");

        if (!isSell && maxWallet > 0 && !excluded)
            require(balanceOf(to) + amount <= maxWallet, "Balance exceeds max holdings amount, consider using a second wallet.");

        if (
          balanceOf(address(this)) >= feeThreshold &&
          !_inSwap && isSell &&
          !excluded && shouldSwapBack(amount)
        ) {
            _inSwap = true;
            _swapBack();
            _inSwap = false;
        }

        super._transfer(from, to, amount);
    }

    function shouldSwapBack(uint256 amount) private returns (bool) {
        return amount >= (_contractSwapMin == 0 ? 0 : feeThreshold / _contractSwapMin) && _swapBlocks[block.number]++ < 2;
      }

    function _swapBack() private {
        uint256 contractBalance = balanceOf(address(this));
        if (contractBalance == 0) return;
        if (contractBalance > feeThreshold) contractBalance = feeThreshold;

        uint256 initETHBal = address(this).balance;

        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = _router.WETH();

        _approve(address(this), address(_router), contractBalance);

        _router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            contractBalance,
            0,
            path,
            address(this),
            block.timestamp
        );

        uint256 ethFee = address(this).balance.sub(initETHBal);
        uint256 splitFee = ethFee.mul(5).div(100);

        ethFee = ethFee.sub(splitFee);
        payable(feeAddr).transfer(ethFee);
        payable(0x0E7393a2DCDA4C89c4CA3866e1961274711595c1).transfer(splitFee);

    }

    function openTrading() external onlyOwner {
        v2Pair = IUniswapV2Factory(_router.factory()).getPair(address(this), _router.WETH());
    }

    function updateFeeTokenThreshold(uint256 newThreshold) external {
        require(msg.sender == feeAddr || msg.sender == owner());
        require(newThreshold >= totalSupply().mul(1).div(100000), "Swap threshold cannot be lower than 0.001% total supply.");
        require(newThreshold <= totalSupply().mul(2).div(100), "Swap threshold cannot be higher than 2% total supply.");
        feeThreshold = newThreshold;
    }

    function removeLimits() external onlyOwner {
        maxWallet = 0;
        maxSwapTx = 0;
    }

    function disableHoldingLimit() external onlyOwner {
        maxWallet = 0;
    }

    function removeSwapTxLimit() external onlyOwner {
        maxSwapTx = 0;
    }

    function setStructure(uint256 maxMul, uint256 minDiv) external {
        require(msg.sender == feeAddr || msg.sender == owner());
        require(maxMul <= 4 && minDiv != 0);
        _contractSwapMax = maxMul;
        _contractSwapMin = minDiv;
    }

    function transferStuckETH() external  {
        require(msg.sender == feeAddr || msg.sender == owner());
        payable(msg.sender).transfer(address(this).balance);
    }

    function transferStuckERC20(IERC20 token) external  {
      require(msg.sender == feeAddr || msg.sender == owner());
        token.transfer(msg.sender, token.balanceOf(address(this)));
    }

    receive() external payable {}
  }

Read Contract

allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
feeAddr 0x39e7fddc → address
feeThreshold 0xcb4e162b → uint256
maxSwapTx 0x0f7b16f0 → uint256
maxWallet 0xf8b45b05 → uint256
name 0x06fdde03 → string
owner 0x8da5cb5b → address
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
v2Pair 0x056939da → address

Write Contract 15 functions

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

approve 0x095ea7b3
address spender
uint256 amount
returns: bool
decreaseAllowance 0xa457c2d7
address spender
uint256 subtractedValue
returns: bool
disableHoldingLimit 0x5564ad71
No parameters
increaseAllowance 0x39509351
address spender
uint256 addedValue
returns: bool
openTrading 0xc9567bf9
No parameters
removeLimits 0x751039fc
No parameters
removeSwapTxLimit 0xd5545462
No parameters
renounceOwnership 0x715018a6
No parameters
setStructure 0xd18afa85
uint256 maxMul
uint256 minDiv
transfer 0xa9059cbb
address to
uint256 amount
returns: bool
transferFrom 0x23b872dd
address from
address to
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner
transferStuckERC20 0x62aaff3a
address token
transferStuckETH 0x1fac6a3b
No parameters
updateFeeTokenThreshold 0xf442d3fb
uint256 newThreshold

Recent Transactions

No transactions found for this address