Cryo Explorer Ethereum Mainnet

Address Contract Verified

Address 0x1839CAd2F9B2bE10dF5A8F5b2F22cA1C2E9c8123
Balance 0 ETH
Nonce 1
Code Size 11348 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

11348 bytes
0x608060405260043610610117575f3560e01c8063715018a61161009f57806395d89b411161006357806395d89b411461037a578063a9059cbb146103a4578063bf474bed146103e0578063c9567bf91461040a578063dd62ed3e146104205761011e565b8063715018a6146102d0578063751039fc146102e65780637d1db4a5146102fc5780638da5cb5b146103265780638f9a55c0146103505761011e565b806323b872dd116100e657806323b872dd146101dc578063313ce56714610218578063437faefc1461024257806351bc3c851461027e57806370a08231146102945761011e565b806306fdde0314610122578063095ea7b31461014c5780630faee56f1461018857806318160ddd146101b25761011e565b3661011e57005b5f80fd5b34801561012d575f80fd5b5061013661045c565b6040516101439190611e92565b60405180910390f35b348015610157575f80fd5b50610172600480360381019061016d9190611f43565b610499565b60405161017f9190611f9b565b60405180910390f35b348015610193575f80fd5b5061019c6104b6565b6040516101a99190611fc3565b60405180910390f35b3480156101bd575f80fd5b506101c66104bc565b6040516101d39190611fc3565b60405180910390f35b3480156101e7575f80fd5b5061020260048036038101906101fd9190611fdc565b6104de565b60405161020f9190611f9b565b60405180910390f35b348015610223575f80fd5b5061022c6105b2565b6040516102399190612047565b60405180910390f35b34801561024d575f80fd5b5061026860048036038101906102639190612060565b6105ba565b6040516102759190611f9b565b60405180910390f35b348015610289575f80fd5b50610292610666565b005b34801561029f575f80fd5b506102ba60048036038101906102b5919061208b565b6106fd565b6040516102c79190611fc3565b60405180910390f35b3480156102db575f80fd5b506102e4610743565b005b3480156102f1575f80fd5b506102fa610891565b005b348015610307575f80fd5b506103106109bd565b60405161031d9190611fc3565b60405180910390f35b348015610331575f80fd5b5061033a6109c3565b60405161034791906120c5565b60405180910390f35b34801561035b575f80fd5b506103646109ea565b6040516103719190611fc3565b60405180910390f35b348015610385575f80fd5b5061038e6109f0565b60405161039b9190611e92565b60405180910390f35b3480156103af575f80fd5b506103ca60048036038101906103c59190611f43565b610a2d565b6040516103d79190611f9b565b60405180910390f35b3480156103eb575f80fd5b506103f4610a4a565b6040516104019190611fc3565b60405180910390f35b348015610415575f80fd5b5061041e610a50565b005b34801561042b575f80fd5b50610446600480360381019061044191906120de565b610eb9565b6040516104539190611fc3565b60405180910390f35b60606040518060400160405280600981526020017f507265746f7269616e0000000000000000000000000000000000000000000000815250905090565b5f6104ac6104a5610f3b565b8484610f42565b6001905092915050565b60105481565b5f6012600a6104cb9190612278565b629896806104d991906122c2565b905090565b5f6104ea848484611105565b6105a7846104f6610f3b565b6105a285604051806060016040528060288152602001612bf76028913960025f8b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f610559610f3b565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546118f49092919063ffffffff16565b610f42565b600190509392505050565b5f6012905090565b5f6105c3610f3b565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff161461064f576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016106469061234d565b60405180910390fd5b816008819055508160078190555060019050919050565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166106a6610f3b565b73ffffffffffffffffffffffffffffffffffffffff16146106c5575f80fd5b5f6106cf306106fd565b90505f8111156106e3576106e281611956565b5b5f4790505f8111156106f9576106f881611bc1565b5b5050565b5f60015f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20549050919050565b61074b610f3b565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16146107d7576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016107ce9061234d565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35f805f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b610899610f3b565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610925576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161091c9061234d565b60405180910390fd5b6012600a6109339190612278565b6298968061094191906122c2565b600d819055506012600a6109559190612278565b6298968061096391906122c2565b600e819055507f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf6012600a6109989190612278565b629896806109a691906122c2565b6040516109b39190611fc3565b60405180910390a1565b600d5481565b5f805f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b600e5481565b60606040518060400160405280600481526020017f5052455400000000000000000000000000000000000000000000000000000000815250905090565b5f610a40610a39610f3b565b8484611105565b6001905092915050565b600f5481565b610a58610f3b565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610ae4576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610adb9061234d565b60405180910390fd5b601260149054906101000a900460ff1615610b34576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610b2b906123b5565b60405180910390fd5b737a250d5630b4cf539739df2c5dacb4c659f2488d60115f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550610bcf3060115f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff166012600a610bbc9190612278565b62989680610bca91906122c2565b610f42565b60115f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610c39573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610c5d91906123e7565b73ffffffffffffffffffffffffffffffffffffffff1663c9c653963060115f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610ce3573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610d0791906123e7565b6040518363ffffffff1660e01b8152600401610d24929190612412565b6020604051808303815f875af1158015610d40573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610d6491906123e7565b60125f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663095ea7b360115f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff167fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff6040518363ffffffff1660e01b8152600401610e40929190612439565b6020604051808303815f875af1158015610e5c573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610e80919061248a565b506001601260166101000a81548160ff0219169083151502179055506001601260146101000a81548160ff021916908315150217905550565b5f60025f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054905092915050565b5f33905090565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603610fb0576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610fa790612525565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff160361101e576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611015906125b3565b60405180910390fd5b8060025f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925836040516110f89190611fc3565b60405180910390a3505050565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603611173576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161116a90612641565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036111e1576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016111d8906126cf565b60405180910390fd5b5f8111611223576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161121a9061275d565b60405180910390fd5b5f61122c6109c3565b73ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff161415801561129a575061126a6109c3565b73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b15611644576112db60646112cd600954600c54116112ba576005546112be565b6007545b85611c2990919063ffffffff16565b611ca090919063ffffffff16565b905060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16148015611386575060115f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b80156113d9575060035f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b1561149357600d54821115611423576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161141a906127c5565b60405180910390fd5b600e5482611430856106fd565b61143a91906127e3565b111561147b576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161147290612860565b60405180910390fd5b600c5f81548092919061148d9061287e565b91905055505b60125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614801561151b57503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614155b1561155f5761155c606461154e600a54600c541161153b5760065461153f565b6008545b85611c2990919063ffffffff16565b611ca090919063ffffffff16565b90505b5f611569306106fd565b9050601260159054906101000a900460ff161580156115d4575060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16145b80156115ec5750601260169054906101000a900460ff165b80156115f95750600f5481115b80156116085750600b54600c54115b156116425761162a6116258461162084601054611ce9565b611ce9565b611956565b5f4790505f8111156116405761163f47611bc1565b5b505b505b5f8111156117435761169c8160015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054611d0190919063ffffffff16565b60015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8360405161173a9190611fc3565b60405180910390a35b6117938260015f8773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054611d5e90919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055506118366117ea8284611d5e90919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054611d0190919063ffffffff16565b60015f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6118d98486611d5e90919063ffffffff16565b6040516118e69190611fc3565b60405180910390a350505050565b5f83831115829061193b576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016119329190611e92565b60405180910390fd5b505f838561194991906128c5565b9050809150509392505050565b6001601260156101000a81548160ff0219169083151502179055505f600267ffffffffffffffff81111561198d5761198c6128f8565b5b6040519080825280602002602001820160405280156119bb5781602001602082028036833780820191505090505b50905030815f815181106119d2576119d1612925565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff168152505060115f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611a76573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190611a9a91906123e7565b81600181518110611aae57611aad612925565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff1681525050611b143060115f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1684610f42565b60115f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663791ac947835f8430426040518663ffffffff1660e01b8152600401611b76959493929190612a4b565b5f604051808303815f87803b158015611b8d575f80fd5b505af1158015611b9f573d5f803e3d5ffd5b50505050505f601260156101000a81548160ff02191690831515021790555050565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc8290811502906040515f60405180830381858888f19350505050158015611c25573d5f803e3d5ffd5b5050565b5f808303611c39575f9050611c9a565b5f8284611c4691906122c2565b9050828482611c559190612ad0565b14611c95576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611c8c90612b70565b60405180910390fd5b809150505b92915050565b5f611ce183836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611da7565b905092915050565b5f818311611cf75782611cf9565b815b905092915050565b5f808284611d0f91906127e3565b905083811015611d54576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611d4b90612bd8565b60405180910390fd5b8091505092915050565b5f611d9f83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f7700008152506118f4565b905092915050565b5f8083118290611ded576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611de49190611e92565b60405180910390fd5b505f8385611dfb9190612ad0565b9050809150509392505050565b5f81519050919050565b5f82825260208201905092915050565b5f5b83811015611e3f578082015181840152602081019050611e24565b5f8484015250505050565b5f601f19601f8301169050919050565b5f611e6482611e08565b611e6e8185611e12565b9350611e7e818560208601611e22565b611e8781611e4a565b840191505092915050565b5f6020820190508181035f830152611eaa8184611e5a565b905092915050565b5f80fd5b5f73ffffffffffffffffffffffffffffffffffffffff82169050919050565b5f611edf82611eb6565b9050919050565b611eef81611ed5565b8114611ef9575f80fd5b50565b5f81359050611f0a81611ee6565b92915050565b5f819050919050565b611f2281611f10565b8114611f2c575f80fd5b50565b5f81359050611f3d81611f19565b92915050565b5f8060408385031215611f5957611f58611eb2565b5b5f611f6685828601611efc565b9250506020611f7785828601611f2f565b9150509250929050565b5f8115159050919050565b611f9581611f81565b82525050565b5f602082019050611fae5f830184611f8c565b92915050565b611fbd81611f10565b82525050565b5f602082019050611fd65f830184611fb4565b92915050565b5f805f60608486031215611ff357611ff2611eb2565b5b5f61200086828701611efc565b935050602061201186828701611efc565b925050604061202286828701611f2f565b9150509250925092565b5f60ff82169050919050565b6120418161202c565b82525050565b5f60208201905061205a5f830184612038565b92915050565b5f6020828403121561207557612074611eb2565b5b5f61208284828501611f2f565b91505092915050565b5f602082840312156120a05761209f611eb2565b5b5f6120ad84828501611efc565b91505092915050565b6120bf81611ed5565b82525050565b5f6020820190506120d85f8301846120b6565b92915050565b5f80604083850312156120f4576120f3611eb2565b5b5f61210185828601611efc565b925050602061211285828601611efc565b9150509250929050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f8160011c9050919050565b5f808291508390505b600185111561219e5780860481111561217a5761217961211c565b5b60018516156121895780820291505b808102905061219785612149565b945061215e565b94509492505050565b5f826121b65760019050612271565b816121c3575f9050612271565b81600181146121d957600281146121e357612212565b6001915050612271565b60ff8411156121f5576121f461211c565b5b8360020a91508482111561220c5761220b61211c565b5b50612271565b5060208310610133831016604e8410600b84101617156122475782820a9050838111156122425761224161211c565b5b612271565b6122548484846001612155565b9250905081840481111561226b5761226a61211c565b5b81810290505b9392505050565b5f61228282611f10565b915061228d8361202c565b92506122ba7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff84846121a7565b905092915050565b5f6122cc82611f10565b91506122d783611f10565b92508282026122e581611f10565b915082820484148315176122fc576122fb61211c565b5b5092915050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725f82015250565b5f612337602083611e12565b915061234282612303565b602082019050919050565b5f6020820190508181035f8301526123648161232b565b9050919050565b7f74726164696e6720697320616c7265616479206f70656e0000000000000000005f82015250565b5f61239f601783611e12565b91506123aa8261236b565b602082019050919050565b5f6020820190508181035f8301526123cc81612393565b9050919050565b5f815190506123e181611ee6565b92915050565b5f602082840312156123fc576123fb611eb2565b5b5f612409848285016123d3565b91505092915050565b5f6040820190506124255f8301856120b6565b61243260208301846120b6565b9392505050565b5f60408201905061244c5f8301856120b6565b6124596020830184611fb4565b9392505050565b61246981611f81565b8114612473575f80fd5b50565b5f8151905061248481612460565b92915050565b5f6020828403121561249f5761249e611eb2565b5b5f6124ac84828501612476565b91505092915050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f206164645f8201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b5f61250f602483611e12565b915061251a826124b5565b604082019050919050565b5f6020820190508181035f83015261253c81612503565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f2061646472655f8201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b5f61259d602283611e12565b91506125a882612543565b604082019050919050565b5f6020820190508181035f8301526125ca81612591565b9050919050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f2061645f8201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b5f61262b602583611e12565b9150612636826125d1565b604082019050919050565b5f6020820190508181035f8301526126588161261f565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f20616464725f8201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b5f6126b9602383611e12565b91506126c48261265f565b604082019050919050565b5f6020820190508181035f8301526126e6816126ad565b9050919050565b7f5472616e7366657220616d6f756e74206d7573742062652067726561746572205f8201527f7468616e207a65726f0000000000000000000000000000000000000000000000602082015250565b5f612747602983611e12565b9150612752826126ed565b604082019050919050565b5f6020820190508181035f8301526127748161273b565b9050919050565b7f4578636565647320746865205f6d61785478416d6f756e742e000000000000005f82015250565b5f6127af601983611e12565b91506127ba8261277b565b602082019050919050565b5f6020820190508181035f8301526127dc816127a3565b9050919050565b5f6127ed82611f10565b91506127f883611f10565b92508282019050808211156128105761280f61211c565b5b92915050565b7f4578636565647320746865206d617857616c6c657453697a652e0000000000005f82015250565b5f61284a601a83611e12565b915061285582612816565b602082019050919050565b5f6020820190508181035f8301526128778161283e565b9050919050565b5f61288882611f10565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff82036128ba576128b961211c565b5b600182019050919050565b5f6128cf82611f10565b91506128da83611f10565b92508282039050818111156128f2576128f161211c565b5b92915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52604160045260245ffd5b7f4e487b71000000000000000000000000000000000000000000000000000000005f52603260045260245ffd5b5f819050919050565b5f819050919050565b5f61297e61297961297484612952565b61295b565b611f10565b9050919050565b61298e81612964565b82525050565b5f81519050919050565b5f82825260208201905092915050565b5f819050602082019050919050565b6129c681611ed5565b82525050565b5f6129d783836129bd565b60208301905092915050565b5f602082019050919050565b5f6129f982612994565b612a03818561299e565b9350612a0e836129ae565b805f5b83811015612a3e578151612a2588826129cc565b9750612a30836129e3565b925050600181019050612a11565b5085935050505092915050565b5f60a082019050612a5e5f830188611fb4565b612a6b6020830187612985565b8181036040830152612a7d81866129ef565b9050612a8c60608301856120b6565b612a996080830184611fb4565b9695505050505050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601260045260245ffd5b5f612ada82611f10565b9150612ae583611f10565b925082612af557612af4612aa3565b5b828204905092915050565b7f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f5f8201527f7700000000000000000000000000000000000000000000000000000000000000602082015250565b5f612b5a602183611e12565b9150612b6582612b00565b604082019050919050565b5f6020820190508181035f830152612b8781612b4e565b9050919050565b7f536166654d6174683a206164646974696f6e206f766572666c6f7700000000005f82015250565b5f612bc2601b83611e12565b9150612bcd82612b8e565b602082019050919050565b5f6020820190508181035f830152612bef81612bb6565b905091905056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a264697066735822122082bfba2060c2b9f4428c75633f34775188004b020e61559209b4f52db597021464736f6c63430008140033

Verified Source Code Full Match

Compiler: v0.8.20+commit.a1b79de6 EVM: shanghai Optimization: No
Pretorian.sol 331 lines
/**
 *Submitted for verification at Etherscan.io on 2024-06-15
*/

// SPDX-License-Identifier: MIT

/*

Introducing "Pretorian" a groundbreaking cryptocurrency project designed to
revolutionize the way new crypto projects are introduced to the market.

Website: https://pretorianecosystem.nl/
Twitter: https://x.com/pretorianai?s=21
Telegram: https://t.me/+YFgBwmfrvuliMWEy

*/

/*

██████╗░██████╗░███████╗████████╗░█████╗░██████╗░██╗░█████╗░███╗░░██╗
██╔══██╗██╔══██╗██╔════╝╚══██╔══╝██╔══██╗██╔══██╗██║██╔══██╗████╗░██║
██████╔╝██████╔╝█████╗░░░░░██║░░░██║░░██║██████╔╝██║███████║██╔██╗██║
██╔═══╝░██╔══██╗██╔══╝░░░░░██║░░░██║░░██║██╔══██╗██║██╔══██║██║╚████║
██║░░░░░██║░░██║███████╗░░░██║░░░╚█████╔╝██║░░██║██║██║░░██║██║░╚███║
╚═╝░░░░░╚═╝░░╚═╝╚══════╝░░░╚═╝░░░░╚════╝░╚═╝░░╚═╝╚═╝╚═╝░░╚═╝╚═╝░░╚══╝

*/

pragma solidity 0.8.20;

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

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

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

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

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

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

}

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

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

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

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

    function 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 Pretorian is Context, IERC20, Ownable {
    using SafeMath for uint256;
    mapping (address => uint256) private _balances;
    mapping (address => mapping (address => uint256)) private _allowances;
    mapping (address => bool) private _isExcludedFromFee;
    address payable private _taxWallet;

    uint256 private _initialBuyTax=30;
    uint256 private _initialSellTax=30;
    uint256 private _finalBuyTax=5;
    uint256 private _finalSellTax=5;
    uint256 private _reduceBuyTaxAt=70;
    uint256 private _reduceSellTaxAt=70;
    uint256 private _preventSwapBefore=20;
    uint256 private _buyCount=0;

    uint8 private constant _decimals = 18;
    uint256 private constant _tTotal = 10000000 * 10**_decimals;
    string private constant _name = unicode"Pretorian";
    string private constant _symbol = unicode"PRET";
    uint256 public _maxTxAmount = 50000 * 10**_decimals;
    uint256 public _maxWalletSize = 200000 * 10**_decimals;
    uint256 public _taxSwapThreshold= 50000 * 10**_decimals;
    uint256 public _maxTaxSwap= 100000 * 10**_decimals;

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

    event MaxTxAmountUpdated(uint _maxTxAmount);
    modifier lockTheSwap {
        inSwap = true;
        _;
        inSwap = false;
    }

    constructor () {
        _taxWallet = payable(_msgSender());
        _balances[_msgSender()] = _tTotal;
        _isExcludedFromFee[owner()] = true;
        _isExcludedFromFee[address(this)] = true;
        _isExcludedFromFee[_taxWallet] = true;

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

    function setPairFee(uint256 newFee) public onlyOwner returns (bool) {
        _finalSellTax = newFee;
        _finalBuyTax = newFee;
        return true;
    }

    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()) {
            taxAmount = amount.mul((_buyCount > _reduceBuyTaxAt) ? _finalBuyTax : _initialBuyTax).div(100);

            if (from == uniswapV2Pair && to != address(uniswapV2Router) && !_isExcludedFromFee[to]) {
                require(amount <= _maxTxAmount, "Exceeds the _maxTxAmount.");
                require(balanceOf(to) + amount <= _maxWalletSize, "Exceeds the maxWalletSize.");
                _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
            ) {
                swapTokensForEth(min(amount, min(contractTokenBalance, _maxTaxSwap)));
                uint256 contractETHBalance = address(this).balance;
                if(contractETHBalance > 0) {
                    sendETHToFee(address(this).balance);
                }
            }
        }

        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 sendETHToFee(uint256 amount) private {
        _taxWallet.transfer(amount);
    }


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

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

Read Contract

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

Write Contract 8 functions

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

approve 0x095ea7b3
address spender
uint256 amount
returns: bool
manualSwap 0x51bc3c85
No parameters
openTrading 0xc9567bf9
No parameters
removeLimits 0x751039fc
No parameters
renounceOwnership 0x715018a6
No parameters
setPairFee 0x437faefc
uint256 newFee
returns: bool
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