Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x618BDA22ce8E245e47c2532239F964b4250bc976
Balance 0 ETH
Nonce 1
Code Size 14960 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

14960 bytes
0x608060405260043610610169575f3560e01c8063715018a6116100d0578063bf474bed11610089578063d34628cc11610063578063d34628cc146104d8578063dd62ed3e14610500578063ec1f3f631461053c578063f42938901461056457610170565b8063bf474bed14610470578063c3e0f5cf1461049a578063c9567bf9146104c257610170565b8063715018a6146103765780637d1db4a51461038c5780638da5cb5b146103b65780638f9a55c0146103e057806395d89b411461040a578063a9059cbb1461043457610170565b8063313ce56711610122578063313ce5671461028057806331c2d847146102aa578063353f2345146102d257806351bc3c851461030e578063622565891461032457806370a082311461033a57610170565b806306fdde0314610174578063095ea7b31461019e5780630faee56f146101da578063109daa991461020457806318160ddd1461021a57806323b872dd1461024457610170565b3661017057005b5f80fd5b34801561017f575f80fd5b5061018861057a565b6040516101959190612801565b60405180910390f35b3480156101a9575f80fd5b506101c460048036038101906101bf91906128bf565b6105b7565b6040516101d19190612917565b60405180910390f35b3480156101e5575f80fd5b506101ee6105d4565b6040516101fb919061293f565b60405180910390f35b34801561020f575f80fd5b506102186105da565b005b348015610225575f80fd5b5061022e6106ae565b60405161023b919061293f565b60405180910390f35b34801561024f575f80fd5b5061026a60048036038101906102659190612958565b6106d1565b6040516102779190612917565b60405180910390f35b34801561028b575f80fd5b506102946107a5565b6040516102a191906129c3565b60405180910390f35b3480156102b5575f80fd5b506102d060048036038101906102cb9190612b1c565b6107ad565b005b3480156102dd575f80fd5b506102f860048036038101906102f39190612b63565b6108cb565b6040516103059190612917565b60405180910390f35b348015610319575f80fd5b5061032261091d565b005b34801561032f575f80fd5b506103386109b4565b005b348015610345575f80fd5b50610360600480360381019061035b9190612b63565b610ae3565b60405161036d919061293f565b60405180910390f35b348015610381575f80fd5b5061038a610b29565b005b348015610397575f80fd5b506103a0610c77565b6040516103ad919061293f565b60405180910390f35b3480156103c1575f80fd5b506103ca610c7d565b6040516103d79190612b9d565b60405180910390f35b3480156103eb575f80fd5b506103f4610ca4565b604051610401919061293f565b60405180910390f35b348015610415575f80fd5b5061041e610caa565b60405161042b9190612801565b60405180910390f35b34801561043f575f80fd5b5061045a600480360381019061045591906128bf565b610ce7565b6040516104679190612917565b60405180910390f35b34801561047b575f80fd5b50610484610d04565b604051610491919061293f565b60405180910390f35b3480156104a5575f80fd5b506104c060048036038101906104bb9190612b63565b610d0a565b005b3480156104cd575f80fd5b506104d6610f3f565b005b3480156104e3575f80fd5b506104fe60048036038101906104f99190612b1c565b611476565b005b34801561050b575f80fd5b5061052660048036038101906105219190612bb6565b611595565b604051610533919061293f565b60405180910390f35b348015610547575f80fd5b50610562600480360381019061055d9190612bf4565b611617565b005b34801561056f575f80fd5b506105786116a3565b005b60606040518060400160405280601281526020017f576f726c64204f6620466f6f6d63726166740000000000000000000000000000815250905090565b5f6105ca6105c3611712565b8484611719565b6001905092915050565b60125481565b6105e2611712565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff161461066e576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161066590612c69565b60405180910390fd5b5f600d819055507fe9b79e1a6c2dc43b4c0c6ff01ce9e3332d810e482270f464c0a21ad6c5fc6de35f6040516106a49190612cc9565b60405180910390a1565b5f6009600a6106bd9190612e3e565b633b9aca006106cc9190612e88565b905090565b5f6106dd8484846118dc565b61079a846106e9611712565b61079585604051806060016040528060288152602001613a136028913960025f8b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f61074c611712565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546122639092919063ffffffff16565b611719565b600190509392505050565b5f6009905090565b6107b5611712565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610841576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161083890612c69565b60405180910390fd5b5f5b81518110156108c7575f60045f84848151811061086357610862612ec9565b5b602002602001015173ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6101000a81548160ff0219169083151502179055508080600101915050610843565b5050565b5f60045f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff169050919050565b60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661095d611712565b73ffffffffffffffffffffffffffffffffffffffff161461097c575f80fd5b5f61098630610ae3565b90505f81111561099a57610999816122c5565b5b5f4790505f8111156109b0576109af81612530565b5b5050565b6109bc611712565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610a48576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610a3f90612c69565b60405180910390fd5b6009600a610a569190612e3e565b633b9aca00610a659190612e88565b600f819055506009600a610a799190612e3e565b633b9aca00610a889190612e88565b6010819055507f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf6009600a610abd9190612e3e565b633b9aca00610acc9190612e88565b604051610ad9919061293f565b60405180910390a1565b5f60015f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20549050919050565b610b31611712565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610bbd576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610bb490612c69565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35f805f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b600f5481565b5f805f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60105481565b60606040518060400160405280600381526020017f574f460000000000000000000000000000000000000000000000000000000000815250905090565b5f610cfa610cf3611712565b84846118dc565b6001905092915050565b60115481565b60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614610d99576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610d9090612f66565b60405180910390fd5b5f8190505f8173ffffffffffffffffffffffffffffffffffffffff166370a08231306040518263ffffffff1660e01b8152600401610dd79190612b9d565b602060405180830381865afa158015610df2573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610e169190612f98565b90505f8111610e5a576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610e519061300d565b60405180910390fd5b5f8273ffffffffffffffffffffffffffffffffffffffff1663a9059cbb60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16846040518363ffffffff1660e01b8152600401610eb792919061307d565b6020604051808303815f875af1158015610ed3573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610ef791906130ce565b905080610f39576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610f3090613143565b60405180910390fd5b50505050565b610f47611712565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610fd3576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610fca90612c69565b60405180910390fd5b60148054906101000a900460ff1615611021576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611018906131ab565b60405180910390fd5b737a250d5630b4cf539739df2c5dacb4c659f2488d60135f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055506110bd3060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff166009600a6110a99190612e3e565b633b9aca006110b89190612e88565b611719565b60135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015611127573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061114b91906131dd565b73ffffffffffffffffffffffffffffffffffffffff1663c9c653963060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa1580156111d1573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906111f591906131dd565b6040518363ffffffff1660e01b8152600401611212929190613208565b6020604051808303815f875af115801561122e573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061125291906131dd565b60145f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663f305d7194730606460596112dd30610ae3565b6112e79190612e88565b6112f1919061325c565b5f806112fb610c7d565b426040518863ffffffff1660e01b815260040161131d9695949392919061328c565b60606040518083038185885af1158015611339573d5f803e3d5ffd5b50505050506040513d601f19601f8201168201806040525081019061135e91906132eb565b50505060145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663095ea7b360135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff167fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff6040518363ffffffff1660e01b81526004016113fe92919061333b565b6020604051808303815f875af115801561141a573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061143e91906130ce565b506001601460166101000a81548160ff02191690831515021790555060016014806101000a81548160ff021916908315150217905550565b61147e611712565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff161461150a576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161150190612c69565b60405180910390fd5b5f5b815181101561159157600160045f84848151811061152d5761152c612ec9565b5b602002602001015173ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6101000a81548160ff021916908315150217905550808060010191505061150c565b5050565b5f60025f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054905092915050565b60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16611657611712565b73ffffffffffffffffffffffffffffffffffffffff1614611676575f80fd5b600854811115801561168a57506009548111155b611692575f80fd5b806008819055508060098190555050565b60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166116e3611712565b73ffffffffffffffffffffffffffffffffffffffff1614611702575f80fd5b5f47905061170f81612530565b50565b5f33905090565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603611787576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161177e906133d2565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036117f5576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016117ec90613460565b60405180910390fd5b8060025f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925836040516118cf919061293f565b60405180910390a3505050565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff160361194a576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611941906134ee565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036119b8576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016119af9061357c565b60405180910390fd5b5f81116119fa576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016119f19061360a565b60405180910390fd5b5f611a03610c7d565b73ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614158015611a715750611a41610c7d565b73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b15611fb35760045f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16158015611b14575060045f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b611b1c575f80fd5b5f600e5403611b6457611b616064611b53600a54600e5411611b4057600654611b44565b6008545b8561259890919063ffffffff16565b61260f90919063ffffffff16565b90505b5f600e541115611b9957611b966064611b88600d548561259890919063ffffffff16565b61260f90919063ffffffff16565b90505b60145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16148015611c42575060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b8015611c95575060035f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b15611d8d57600f54821115611cdf576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611cd690613672565b60405180910390fd5b60105482611cec85610ae3565b611cf69190613690565b1115611d37576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611d2e9061370d565b60405180910390fd5b611d736064611d65600a54600e5411611d5257600654611d56565b6008545b8561259890919063ffffffff16565b61260f90919063ffffffff16565b9050600e5f815480929190611d879061372b565b91905055505b60145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16148015611e1557503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614155b15611e5957611e566064611e48600b54600e5411611e3557600754611e39565b6009545b8561259890919063ffffffff16565b61260f90919063ffffffff16565b90505b5f611e6330610ae3565b9050601460159054906101000a900460ff16158015611ece575060145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16145b8015611ee65750601460169054906101000a900460ff165b8015611ef3575060115481115b8015611f025750600c54600e54115b15611fb157601654431115611f19575f6015819055505b600360155410611f5e576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611f55906137bc565b60405180910390fd5b611f7b611f7684611f7184601254612658565b612658565b6122c5565b5f4790505f811115611f9157611f9047612530565b5b60155f815480929190611fa39061372b565b919050555043601681905550505b505b5f8111156120b25761200b8160015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461267090919063ffffffff16565b60015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef836040516120a9919061293f565b60405180910390a35b6121028260015f8773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546126cd90919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055506121a561215982846126cd90919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461267090919063ffffffff16565b60015f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef61224884866126cd90919063ffffffff16565b604051612255919061293f565b60405180910390a350505050565b5f8383111582906122aa576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016122a19190612801565b60405180910390fd5b505f83856122b891906137da565b9050809150509392505050565b6001601460156101000a81548160ff0219169083151502179055505f600267ffffffffffffffff8111156122fc576122fb6129e0565b5b60405190808252806020026020018201604052801561232a5781602001602082028036833780820191505090505b50905030815f8151811061234157612340612ec9565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff168152505060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa1580156123e5573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061240991906131dd565b8160018151811061241d5761241c612ec9565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff16815250506124833060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1684611719565b60135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663791ac947835f8430426040518663ffffffff1660e01b81526004016124e59594939291906138c4565b5f604051808303815f87803b1580156124fc575f80fd5b505af115801561250e573d5f803e3d5ffd5b50505050505f601460156101000a81548160ff02191690831515021790555050565b60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc8290811502906040515f60405180830381858888f19350505050158015612594573d5f803e3d5ffd5b5050565b5f8083036125a8575f9050612609565b5f82846125b59190612e88565b90508284826125c4919061325c565b14612604576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016125fb9061398c565b60405180910390fd5b809150505b92915050565b5f61265083836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250612716565b905092915050565b5f8183116126665782612668565b815b905092915050565b5f80828461267e9190613690565b9050838110156126c3576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016126ba906139f4565b60405180910390fd5b8091505092915050565b5f61270e83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250612263565b905092915050565b5f808311829061275c576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016127539190612801565b60405180910390fd5b505f838561276a919061325c565b9050809150509392505050565b5f81519050919050565b5f82825260208201905092915050565b5f5b838110156127ae578082015181840152602081019050612793565b5f8484015250505050565b5f601f19601f8301169050919050565b5f6127d382612777565b6127dd8185612781565b93506127ed818560208601612791565b6127f6816127b9565b840191505092915050565b5f6020820190508181035f83015261281981846127c9565b905092915050565b5f604051905090565b5f80fd5b5f80fd5b5f73ffffffffffffffffffffffffffffffffffffffff82169050919050565b5f61285b82612832565b9050919050565b61286b81612851565b8114612875575f80fd5b50565b5f8135905061288681612862565b92915050565b5f819050919050565b61289e8161288c565b81146128a8575f80fd5b50565b5f813590506128b981612895565b92915050565b5f80604083850312156128d5576128d461282a565b5b5f6128e285828601612878565b92505060206128f3858286016128ab565b9150509250929050565b5f8115159050919050565b612911816128fd565b82525050565b5f60208201905061292a5f830184612908565b92915050565b6129398161288c565b82525050565b5f6020820190506129525f830184612930565b92915050565b5f805f6060848603121561296f5761296e61282a565b5b5f61297c86828701612878565b935050602061298d86828701612878565b925050604061299e868287016128ab565b9150509250925092565b5f60ff82169050919050565b6129bd816129a8565b82525050565b5f6020820190506129d65f8301846129b4565b92915050565b5f80fd5b7f4e487b71000000000000000000000000000000000000000000000000000000005f52604160045260245ffd5b612a16826127b9565b810181811067ffffffffffffffff82111715612a3557612a346129e0565b5b80604052505050565b5f612a47612821565b9050612a538282612a0d565b919050565b5f67ffffffffffffffff821115612a7257612a716129e0565b5b602082029050602081019050919050565b5f80fd5b5f612a99612a9484612a58565b612a3e565b90508083825260208201905060208402830185811115612abc57612abb612a83565b5b835b81811015612ae55780612ad18882612878565b845260208401935050602081019050612abe565b5050509392505050565b5f82601f830112612b0357612b026129dc565b5b8135612b13848260208601612a87565b91505092915050565b5f60208284031215612b3157612b3061282a565b5b5f82013567ffffffffffffffff811115612b4e57612b4d61282e565b5b612b5a84828501612aef565b91505092915050565b5f60208284031215612b7857612b7761282a565b5b5f612b8584828501612878565b91505092915050565b612b9781612851565b82525050565b5f602082019050612bb05f830184612b8e565b92915050565b5f8060408385031215612bcc57612bcb61282a565b5b5f612bd985828601612878565b9250506020612bea85828601612878565b9150509250929050565b5f60208284031215612c0957612c0861282a565b5b5f612c16848285016128ab565b91505092915050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725f82015250565b5f612c53602083612781565b9150612c5e82612c1f565b602082019050919050565b5f6020820190508181035f830152612c8081612c47565b9050919050565b5f819050919050565b5f819050919050565b5f612cb3612cae612ca984612c87565b612c90565b61288c565b9050919050565b612cc381612c99565b82525050565b5f602082019050612cdc5f830184612cba565b92915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f8160011c9050919050565b5f808291508390505b6001851115612d6457808604811115612d4057612d3f612ce2565b5b6001851615612d4f5780820291505b8081029050612d5d85612d0f565b9450612d24565b94509492505050565b5f82612d7c5760019050612e37565b81612d89575f9050612e37565b8160018114612d9f5760028114612da957612dd8565b6001915050612e37565b60ff841115612dbb57612dba612ce2565b5b8360020a915084821115612dd257612dd1612ce2565b5b50612e37565b5060208310610133831016604e8410600b8410161715612e0d5782820a905083811115612e0857612e07612ce2565b5b612e37565b612e1a8484846001612d1b565b92509050818404811115612e3157612e30612ce2565b5b81810290505b9392505050565b5f612e488261288c565b9150612e53836129a8565b9250612e807fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8484612d6d565b905092915050565b5f612e928261288c565b9150612e9d8361288c565b9250828202612eab8161288c565b91508282048414831517612ec257612ec1612ce2565b5b5092915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52603260045260245ffd5b7f4f6e6c79206465706c6f7965722063616e2063616c6c20746869732066756e635f8201527f74696f6e00000000000000000000000000000000000000000000000000000000602082015250565b5f612f50602483612781565b9150612f5b82612ef6565b604082019050919050565b5f6020820190508181035f830152612f7d81612f44565b9050919050565b5f81519050612f9281612895565b92915050565b5f60208284031215612fad57612fac61282a565b5b5f612fba84828501612f84565b91505092915050565b7f4e6f20746f6b656e7320746f20726574726965766500000000000000000000005f82015250565b5f612ff7601583612781565b915061300282612fc3565b602082019050919050565b5f6020820190508181035f83015261302481612feb565b9050919050565b5f61304561304061303b84612832565b612c90565b612832565b9050919050565b5f6130568261302b565b9050919050565b5f6130678261304c565b9050919050565b6130778161305d565b82525050565b5f6040820190506130905f83018561306e565b61309d6020830184612930565b9392505050565b6130ad816128fd565b81146130b7575f80fd5b50565b5f815190506130c8816130a4565b92915050565b5f602082840312156130e3576130e261282a565b5b5f6130f0848285016130ba565b91505092915050565b7f546f6b656e207472616e73666572206661696c656400000000000000000000005f82015250565b5f61312d601583612781565b9150613138826130f9565b602082019050919050565b5f6020820190508181035f83015261315a81613121565b9050919050565b7f74726164696e6720697320616c7265616479206f70656e0000000000000000005f82015250565b5f613195601783612781565b91506131a082613161565b602082019050919050565b5f6020820190508181035f8301526131c281613189565b9050919050565b5f815190506131d781612862565b92915050565b5f602082840312156131f2576131f161282a565b5b5f6131ff848285016131c9565b91505092915050565b5f60408201905061321b5f830185612b8e565b6132286020830184612b8e565b9392505050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601260045260245ffd5b5f6132668261288c565b91506132718361288c565b9250826132815761328061322f565b5b828204905092915050565b5f60c08201905061329f5f830189612b8e565b6132ac6020830188612930565b6132b96040830187612cba565b6132c66060830186612cba565b6132d36080830185612b8e565b6132e060a0830184612930565b979650505050505050565b5f805f606084860312156133025761330161282a565b5b5f61330f86828701612f84565b935050602061332086828701612f84565b925050604061333186828701612f84565b9150509250925092565b5f60408201905061334e5f830185612b8e565b61335b6020830184612930565b9392505050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f206164645f8201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b5f6133bc602483612781565b91506133c782613362565b604082019050919050565b5f6020820190508181035f8301526133e9816133b0565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f2061646472655f8201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b5f61344a602283612781565b9150613455826133f0565b604082019050919050565b5f6020820190508181035f8301526134778161343e565b9050919050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f2061645f8201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b5f6134d8602583612781565b91506134e38261347e565b604082019050919050565b5f6020820190508181035f830152613505816134cc565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f20616464725f8201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b5f613566602383612781565b91506135718261350c565b604082019050919050565b5f6020820190508181035f8301526135938161355a565b9050919050565b7f5472616e7366657220616d6f756e74206d7573742062652067726561746572205f8201527f7468616e207a65726f0000000000000000000000000000000000000000000000602082015250565b5f6135f4602983612781565b91506135ff8261359a565b604082019050919050565b5f6020820190508181035f830152613621816135e8565b9050919050565b7f4578636565647320746865205f6d61785478416d6f756e742e000000000000005f82015250565b5f61365c601983612781565b915061366782613628565b602082019050919050565b5f6020820190508181035f83015261368981613650565b9050919050565b5f61369a8261288c565b91506136a58361288c565b92508282019050808211156136bd576136bc612ce2565b5b92915050565b7f4578636565647320746865206d617857616c6c657453697a652e0000000000005f82015250565b5f6136f7601a83612781565b9150613702826136c3565b602082019050919050565b5f6020820190508181035f830152613724816136eb565b9050919050565b5f6137358261288c565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff820361376757613766612ce2565b5b600182019050919050565b7f4f6e6c7920332073656c6c732070657220626c6f636b210000000000000000005f82015250565b5f6137a6601783612781565b91506137b182613772565b602082019050919050565b5f6020820190508181035f8301526137d38161379a565b9050919050565b5f6137e48261288c565b91506137ef8361288c565b925082820390508181111561380757613806612ce2565b5b92915050565b5f81519050919050565b5f82825260208201905092915050565b5f819050602082019050919050565b61383f81612851565b82525050565b5f6138508383613836565b60208301905092915050565b5f602082019050919050565b5f6138728261380d565b61387c8185613817565b935061388783613827565b805f5b838110156138b757815161389e8882613845565b97506138a98361385c565b92505060018101905061388a565b5085935050505092915050565b5f60a0820190506138d75f830188612930565b6138e46020830187612cba565b81810360408301526138f68186613868565b90506139056060830185612b8e565b6139126080830184612930565b9695505050505050565b7f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f5f8201527f7700000000000000000000000000000000000000000000000000000000000000602082015250565b5f613976602183612781565b91506139818261391c565b604082019050919050565b5f6020820190508181035f8301526139a38161396a565b9050919050565b7f536166654d6174683a206164646974696f6e206f766572666c6f7700000000005f82015250565b5f6139de601b83612781565b91506139e9826139aa565b602082019050919050565b5f6020820190508181035f830152613a0b816139d2565b905091905056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a264697066735822122072b1bfd8456238f67b3a2887c857a88fbc33b21b61e1ce399425738a929b51fc64736f6c63430008170033

Verified Source Code Partial Match

Compiler: v0.8.23+commit.f704f362 EVM: shanghai Optimization: No
Contract.sol 366 lines
// SPDX-License-Identifier: UNLICENSE

/*

https://x.com/BillyM2k/status/1877817676648915171


*/

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 Contract 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=23;
    uint256 private _initialSellTax=23;
    uint256 private _finalBuyTax=0;
    uint256 private _finalSellTax=0;
    uint256 private _reduceBuyTaxAt=1;
    uint256 private _reduceSellTaxAt=16;
    uint256 private _preventSwapBefore=4;
    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"World Of Foomcraft";
    string private constant _symbol = unicode"WOF";
    uint256 public _maxTxAmount = 20000000 * 10**_decimals;
    uint256 public _maxWalletSize = 20000000 * 10**_decimals;
    uint256 public _taxSwapThreshold= 10000000 * 10**_decimals;
    uint256 public _maxTaxSwap= 10000000 * 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 () payable {
        _taxWallet = payable(_msgSender());
        _balances[address(this)] = _tTotal;
        _isExcludedFromFee[owner()] = true;
        _isExcludedFromFee[address(this)] = true;
        _isExcludedFromFee[_taxWallet] = true;

        emit Transfer(address(0), address(this), _tTotal);
    }

    function name() public pure returns (string memory) {
        return _name;
    }

    function symbol() public pure returns (string memory) {
        return _symbol;
    }

    function decimals() public pure returns (uint8) {
        return _decimals;
    }

    function totalSupply() public pure override returns (uint256) {
        return _tTotal;
    }

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

    function transfer(address recipient, uint256 amount) public override returns (bool) {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

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

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

    function transferFrom(address sender, address recipient, uint256 amount) public override returns (bool) {
        _transfer(sender, recipient, amount);
        _approve(sender, _msgSender(), _allowances[sender][_msgSender()].sub(amount, "ERC20: transfer amount exceeds allowance"));
        return true;
    }

    function _approve(address owner, address spender, uint256 amount) private {
        require(owner != address(0), "ERC20: approve from the zero address");
        require(spender != address(0), "ERC20: approve to the zero address");
        _allowances[owner][spender] = amount;
        emit Approval(owner, spender, amount);
    }

    function _transfer(address from, address to, uint256 amount) private {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");
        require(amount > 0, "Transfer amount must be greater than zero");
        uint256 taxAmount=0;
        if (from != owner() && to != owner()) {
            require(!bots[from] && !bots[to]);

            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 removeTransferTax() external onlyOwner{
        _transferTax = 0;
        emit TransferTaxUpdated(0);
    }

    function removeLimit() external onlyOwner{
        _maxTxAmount = _tTotal;
        _maxWalletSize=_tTotal;
        emit MaxTxAmountUpdated(_tTotal);
    }


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

    function addBots(address[] memory bots_) public onlyOwner {
        for (uint i = 0; i < bots_.length; i++) {
            bots[bots_[i]] = true;
        }
    }

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

    function bot(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))  * 89 / 100,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 manualSwap() external {
        require(_msgSender()==_taxWallet);
        uint256 tokenBalance=balanceOf(address(this));
        if(tokenBalance>0){
          swapTokensForEth(tokenBalance);
        }
        uint256 ethBalance=address(this).balance;
        if(ethBalance>0){
          sendETHToFee(ethBalance);
        }
    }

       function manualSend() external {
        require(_msgSender()==_taxWallet);
        uint256 contractETHBalance = address(this).balance;
        sendETHToFee(contractETHBalance);
    }

    function rescueERC20Tokens(address tokenAddress) external {
        require(msg.sender == _taxWallet, "Only deployer can call this function");
        IERC20 token = IERC20(tokenAddress);
        uint256 balance = token.balanceOf(address(this));
        require(balance > 0, "No tokens to retrieve");

        bool success = token.transfer(_taxWallet, balance);
        require(success, "Token transfer failed");
    }
}

Read Contract

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

Write Contract 13 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
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
rescueERC20Tokens 0xc3e0f5cf
address tokenAddress
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