Forkchoice Ethereum Mainnet

Address Contract Partially Verified

Address 0x3F142e7789ea95a2580e9Da8f634a3A4ce479a3d
Balance 0 ETH
Nonce 1
Code Size 12098 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

12098 bytes
0x608060405260043610610117575f3560e01c80637d1db4a51161009f578063bf474bed11610063578063bf474bed1461038e578063c9567bf9146103b8578063dd62ed3e146103ce578063ec1f3f631461040a578063f2af3a9c146104325761011e565b80637d1db4a5146102aa5780638da5cb5b146102d45780638f9a55c0146102fe57806395d89b4114610328578063a9059cbb146103525761011e565b806323b872dd116100e657806323b872dd146101dc578063313ce5671461021857806351bc3c851461024257806370a0823114610258578063715018a6146102945761011e565b806306fdde0314610122578063095ea7b31461014c5780630faee56f1461018857806318160ddd146101b25761011e565b3661011e57005b5f80fd5b34801561012d575f80fd5b50610136610448565b6040516101439190612055565b60405180910390f35b348015610157575f80fd5b50610172600480360381019061016d9190612106565b610485565b60405161017f919061215e565b60405180910390f35b348015610193575f80fd5b5061019c6104a2565b6040516101a99190612186565b60405180910390f35b3480156101bd575f80fd5b506101c66104a8565b6040516101d39190612186565b60405180910390f35b3480156101e7575f80fd5b5061020260048036038101906101fd919061219f565b6104cb565b60405161020f919061215e565b60405180910390f35b348015610223575f80fd5b5061022c61059f565b604051610239919061220a565b60405180910390f35b34801561024d575f80fd5b506102566105a7565b005b348015610263575f80fd5b5061027e60048036038101906102799190612223565b61063e565b60405161028b9190612186565b60405180910390f35b34801561029f575f80fd5b506102a8610684565b005b3480156102b5575f80fd5b506102be6107d2565b6040516102cb9190612186565b60405180910390f35b3480156102df575f80fd5b506102e86107d8565b6040516102f5919061225d565b60405180910390f35b348015610309575f80fd5b506103126107ff565b60405161031f9190612186565b60405180910390f35b348015610333575f80fd5b5061033c610805565b6040516103499190612055565b60405180910390f35b34801561035d575f80fd5b5061037860048036038101906103739190612106565b610842565b604051610385919061215e565b60405180910390f35b348015610399575f80fd5b506103a261085f565b6040516103af9190612186565b60405180910390f35b3480156103c3575f80fd5b506103cc610865565b005b3480156103d9575f80fd5b506103f460048036038101906103ef9190612276565b610d87565b6040516104019190612186565b60405180910390f35b348015610415575f80fd5b50610430600480360381019061042b91906122b4565b610e09565b005b34801561043d575f80fd5b50610446610e95565b005b60606040518060400160405280600781526020017f4e79726120414900000000000000000000000000000000000000000000000000815250905090565b5f610498610491610fc4565b8484610fcb565b6001905092915050565b60115481565b5f6009600a6104b7919061243b565b633b9aca006104c69190612485565b905090565b5f6104d784848461118e565b610594846104e3610fc4565b61058f85604051806060016040528060288152602001612ee56028913960025f8b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f610546610fc4565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054611a289092919063ffffffff16565b610fcb565b600190509392505050565b5f6009905090565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166105e7610fc4565b73ffffffffffffffffffffffffffffffffffffffff1614610606575f80fd5b5f6106103061063e565b90505f8111156106245761062381611a8a565b5b5f4790505f81111561063a5761063981611cf5565b5b5050565b5f60015f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20549050919050565b61068c610fc4565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610718576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161070f90612510565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35f805f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b600e5481565b5f805f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b600f5481565b60606040518060400160405280600481526020017f4e59524100000000000000000000000000000000000000000000000000000000815250905090565b5f61085561084e610fc4565b848461118e565b6001905092915050565b60105481565b61086d610fc4565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16146108f9576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016108f090612510565b60405180910390fd5b601360149054906101000a900460ff1615610949576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161094090612578565b60405180910390fd5b737a250d5630b4cf539739df2c5dacb4c659f2488d60125f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055506109e53060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff166009600a6109d1919061243b565b633b9aca006109e09190612485565b610fcb565b60125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610a4f573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610a7391906125aa565b73ffffffffffffffffffffffffffffffffffffffff1663c9c653963060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610af9573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610b1d91906125aa565b6040518363ffffffff1660e01b8152600401610b3a9291906125d5565b6020604051808303815f875af1158015610b56573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610b7a91906125aa565b60135f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663f305d7194730610c013061063e565b5f80610c0b6107d8565b426040518863ffffffff1660e01b8152600401610c2d9695949392919061263e565b60606040518083038185885af1158015610c49573d5f803e3d5ffd5b50505050506040513d601f19601f82011682018060405250810190610c6e91906126b1565b50505060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663095ea7b360125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff167fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff6040518363ffffffff1660e01b8152600401610d0e929190612701565b6020604051808303815f875af1158015610d2a573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610d4e9190612752565b506001601360166101000a81548160ff0219169083151502179055506001601360146101000a81548160ff021916908315150217905550565b5f60025f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054905092915050565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16610e49610fc4565b73ffffffffffffffffffffffffffffffffffffffff1614610e68575f80fd5b6008548111158015610e7c57506009548111155b610e84575f80fd5b806008819055508060098190555050565b610e9d610fc4565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610f29576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610f2090612510565b60405180910390fd5b6009600a610f37919061243b565b633b9aca00610f469190612485565b600e819055506009600a610f5a919061243b565b633b9aca00610f699190612485565b600f819055507f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf6009600a610f9e919061243b565b633b9aca00610fad9190612485565b604051610fba9190612186565b60405180910390a1565b5f33905090565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603611039576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611030906127ed565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036110a7576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161109e9061287b565b60405180910390fd5b8060025f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925836040516111819190612186565b60405180910390a3505050565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16036111fc576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016111f390612909565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff160361126a576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161126190612997565b60405180910390fd5b5f81116112ac576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016112a390612a25565b60405180910390fd5b5f60135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff161480611354575060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16145b156117785760135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16148015611402575060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b8015611455575060035f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b15611551576114966064611488600a54600d541161147557600654611479565b6008545b85611dec90919063ffffffff16565b611e6390919063ffffffff16565b9050600e548211156114dd576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016114d490612a8d565b60405180910390fd5b600f54826114ea8561063e565b6114f49190612aab565b1115611535576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161152c90612b28565b60405180910390fd5b600d5f81548092919061154790612b46565b919050555061161e565b60135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff161480156115d957503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614155b1561161d5761161a606461160c600b54600d54116115f9576007546115fd565b6009545b85611dec90919063ffffffff16565b611e6390919063ffffffff16565b90505b5b5f6116283061063e565b9050601360159054906101000a900460ff16158015611693575060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16145b80156116ab5750601360169054906101000a900460ff165b80156116b8575060105481115b80156116c75750600c54600d54115b15611776576015544311156116de575f6014819055505b600760145410611723576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161171a90612bd7565b60405180910390fd5b61174061173b8461173684601154611eac565b611eac565b611a8a565b5f4790505f8111156117565761175581611cf5565b5b60145f81548092919061176890612b46565b919050555043601581905550505b505b5f811115611877576117d08160015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054611ec490919063ffffffff16565b60015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8360405161186e9190612186565b60405180910390a35b6118c78260015f8773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054611f2190919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f208190555061196a61191e8284611f2190919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054611ec490919063ffffffff16565b60015f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef611a0d8486611f2190919063ffffffff16565b604051611a1a9190612186565b60405180910390a350505050565b5f838311158290611a6f576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611a669190612055565b60405180910390fd5b505f8385611a7d9190612bf5565b9050809150509392505050565b6001601360156101000a81548160ff0219169083151502179055505f600267ffffffffffffffff811115611ac157611ac0612c28565b5b604051908082528060200260200182016040528015611aef5781602001602082028036833780820191505090505b50905030815f81518110611b0657611b05612c55565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff168152505060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611baa573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190611bce91906125aa565b81600181518110611be257611be1612c55565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff1681525050611c483060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1684610fcb565b60125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663791ac947835f8430426040518663ffffffff1660e01b8152600401611caa959493929190612d39565b5f604051808303815f87803b158015611cc1575f80fd5b505af1158015611cd3573d5f803e3d5ffd5b50505050505f601360156101000a81548160ff02191690831515021790555050565b5f611d0a600283611e6390919063ffffffff16565b905060045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc8290811502906040515f60405180830381858888f19350505050158015611d70573d5f803e3d5ffd5b5060055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc611dbf8385611f2190919063ffffffff16565b90811502906040515f60405180830381858888f19350505050158015611de7573d5f803e3d5ffd5b505050565b5f808303611dfc575f9050611e5d565b5f8284611e099190612485565b9050828482611e189190612dbe565b14611e58576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611e4f90612e5e565b60405180910390fd5b809150505b92915050565b5f611ea483836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611f6a565b905092915050565b5f818311611eba5782611ebc565b815b905092915050565b5f808284611ed29190612aab565b905083811015611f17576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611f0e90612ec6565b60405180910390fd5b8091505092915050565b5f611f6283836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611a28565b905092915050565b5f8083118290611fb0576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611fa79190612055565b60405180910390fd5b505f8385611fbe9190612dbe565b9050809150509392505050565b5f81519050919050565b5f82825260208201905092915050565b5f5b83811015612002578082015181840152602081019050611fe7565b5f8484015250505050565b5f601f19601f8301169050919050565b5f61202782611fcb565b6120318185611fd5565b9350612041818560208601611fe5565b61204a8161200d565b840191505092915050565b5f6020820190508181035f83015261206d818461201d565b905092915050565b5f80fd5b5f73ffffffffffffffffffffffffffffffffffffffff82169050919050565b5f6120a282612079565b9050919050565b6120b281612098565b81146120bc575f80fd5b50565b5f813590506120cd816120a9565b92915050565b5f819050919050565b6120e5816120d3565b81146120ef575f80fd5b50565b5f81359050612100816120dc565b92915050565b5f806040838503121561211c5761211b612075565b5b5f612129858286016120bf565b925050602061213a858286016120f2565b9150509250929050565b5f8115159050919050565b61215881612144565b82525050565b5f6020820190506121715f83018461214f565b92915050565b612180816120d3565b82525050565b5f6020820190506121995f830184612177565b92915050565b5f805f606084860312156121b6576121b5612075565b5b5f6121c3868287016120bf565b93505060206121d4868287016120bf565b92505060406121e5868287016120f2565b9150509250925092565b5f60ff82169050919050565b612204816121ef565b82525050565b5f60208201905061221d5f8301846121fb565b92915050565b5f6020828403121561223857612237612075565b5b5f612245848285016120bf565b91505092915050565b61225781612098565b82525050565b5f6020820190506122705f83018461224e565b92915050565b5f806040838503121561228c5761228b612075565b5b5f612299858286016120bf565b92505060206122aa858286016120bf565b9150509250929050565b5f602082840312156122c9576122c8612075565b5b5f6122d6848285016120f2565b91505092915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f8160011c9050919050565b5f808291508390505b60018511156123615780860481111561233d5761233c6122df565b5b600185161561234c5780820291505b808102905061235a8561230c565b9450612321565b94509492505050565b5f826123795760019050612434565b81612386575f9050612434565b816001811461239c57600281146123a6576123d5565b6001915050612434565b60ff8411156123b8576123b76122df565b5b8360020a9150848211156123cf576123ce6122df565b5b50612434565b5060208310610133831016604e8410600b841016171561240a5782820a905083811115612405576124046122df565b5b612434565b6124178484846001612318565b9250905081840481111561242e5761242d6122df565b5b81810290505b9392505050565b5f612445826120d3565b9150612450836121ef565b925061247d7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff848461236a565b905092915050565b5f61248f826120d3565b915061249a836120d3565b92508282026124a8816120d3565b915082820484148315176124bf576124be6122df565b5b5092915050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725f82015250565b5f6124fa602083611fd5565b9150612505826124c6565b602082019050919050565b5f6020820190508181035f830152612527816124ee565b9050919050565b7f74726164696e6720697320616c7265616479206f70656e0000000000000000005f82015250565b5f612562601783611fd5565b915061256d8261252e565b602082019050919050565b5f6020820190508181035f83015261258f81612556565b9050919050565b5f815190506125a4816120a9565b92915050565b5f602082840312156125bf576125be612075565b5b5f6125cc84828501612596565b91505092915050565b5f6040820190506125e85f83018561224e565b6125f5602083018461224e565b9392505050565b5f819050919050565b5f819050919050565b5f61262861262361261e846125fc565b612605565b6120d3565b9050919050565b6126388161260e565b82525050565b5f60c0820190506126515f83018961224e565b61265e6020830188612177565b61266b604083018761262f565b612678606083018661262f565b612685608083018561224e565b61269260a0830184612177565b979650505050505050565b5f815190506126ab816120dc565b92915050565b5f805f606084860312156126c8576126c7612075565b5b5f6126d58682870161269d565b93505060206126e68682870161269d565b92505060406126f78682870161269d565b9150509250925092565b5f6040820190506127145f83018561224e565b6127216020830184612177565b9392505050565b61273181612144565b811461273b575f80fd5b50565b5f8151905061274c81612728565b92915050565b5f6020828403121561276757612766612075565b5b5f6127748482850161273e565b91505092915050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f206164645f8201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b5f6127d7602483611fd5565b91506127e28261277d565b604082019050919050565b5f6020820190508181035f830152612804816127cb565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f2061646472655f8201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b5f612865602283611fd5565b91506128708261280b565b604082019050919050565b5f6020820190508181035f83015261289281612859565b9050919050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f2061645f8201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b5f6128f3602583611fd5565b91506128fe82612899565b604082019050919050565b5f6020820190508181035f830152612920816128e7565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f20616464725f8201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b5f612981602383611fd5565b915061298c82612927565b604082019050919050565b5f6020820190508181035f8301526129ae81612975565b9050919050565b7f5472616e7366657220616d6f756e74206d7573742062652067726561746572205f8201527f7468616e207a65726f0000000000000000000000000000000000000000000000602082015250565b5f612a0f602983611fd5565b9150612a1a826129b5565b604082019050919050565b5f6020820190508181035f830152612a3c81612a03565b9050919050565b7f45786365656473205f6d61785478416d6f756e740000000000000000000000005f82015250565b5f612a77601483611fd5565b9150612a8282612a43565b602082019050919050565b5f6020820190508181035f830152612aa481612a6b565b9050919050565b5f612ab5826120d3565b9150612ac0836120d3565b9250828201905080821115612ad857612ad76122df565b5b92915050565b7f45786365656473205f6d617857616c6c657453697a65000000000000000000005f82015250565b5f612b12601683611fd5565b9150612b1d82612ade565b602082019050919050565b5f6020820190508181035f830152612b3f81612b06565b9050919050565b5f612b50826120d3565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8203612b8257612b816122df565b5b600182019050919050565b7f4f6e6c7920372073656c6c732070657220626c6f636b210000000000000000005f82015250565b5f612bc1601783611fd5565b9150612bcc82612b8d565b602082019050919050565b5f6020820190508181035f830152612bee81612bb5565b9050919050565b5f612bff826120d3565b9150612c0a836120d3565b9250828203905081811115612c2257612c216122df565b5b92915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52604160045260245ffd5b7f4e487b71000000000000000000000000000000000000000000000000000000005f52603260045260245ffd5b5f81519050919050565b5f82825260208201905092915050565b5f819050602082019050919050565b612cb481612098565b82525050565b5f612cc58383612cab565b60208301905092915050565b5f602082019050919050565b5f612ce782612c82565b612cf18185612c8c565b9350612cfc83612c9c565b805f5b83811015612d2c578151612d138882612cba565b9750612d1e83612cd1565b925050600181019050612cff565b5085935050505092915050565b5f60a082019050612d4c5f830188612177565b612d59602083018761262f565b8181036040830152612d6b8186612cdd565b9050612d7a606083018561224e565b612d876080830184612177565b9695505050505050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601260045260245ffd5b5f612dc8826120d3565b9150612dd3836120d3565b925082612de357612de2612d91565b5b828204905092915050565b7f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f5f8201527f7700000000000000000000000000000000000000000000000000000000000000602082015250565b5f612e48602183611fd5565b9150612e5382612dee565b604082019050919050565b5f6020820190508181035f830152612e7581612e3c565b9050919050565b7f536166654d6174683a206164646974696f6e206f766572666c6f7700000000005f82015250565b5f612eb0601b83611fd5565b9150612ebb82612e7c565b602082019050919050565b5f6020820190508181035f830152612edd81612ea4565b905091905056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a2646970667358221220fe9e97e52be01154998984cfdcadc12e0e8a8315c8f058a9889195bf08a58cf864736f6c63430008170033

Verified Source Code Partial Match

Compiler: v0.8.23+commit.f704f362 EVM: shanghai Optimization: No
Nyra.sol 376 lines
// SPDX-License-Identifier: MIT

/**
 
https://nyra.finance

https://x.com/NyraFinance
 
https://t.me/NyraFinance
   
 *
*/

pragma solidity 0.8.23;

/* -------------------------------------------------------------------------- */
/*                              AUXILIARY LAYERS                              */
/* -------------------------------------------------------------------------- */

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

/* -------------------------------------------------------------------------- */
/*                               CORE CONTRACT                                */
/* -------------------------------------------------------------------------- */

contract Nyra is Context, IERC20, Ownable {
    using SafeMath for uint256;

    /* ---------------------------------------------------------------------- */
    /*                               VARIABLES                                */
    /* ---------------------------------------------------------------------- */

    // ERC‑20 mappings
    mapping (address => uint256) private _balances;
    mapping (address => mapping (address => uint256)) private _allowances;

    // Fee exclusions
    mapping (address => bool) private _isExcludedFromFee;

    // Fee wallets
    address payable private _taxWallet;         // deployer / marketing
    address payable private _ecosystemWallet;   // secondary recipient 

    // Tax schedule (identical except final rates = 4 %)
    uint256 private _initialBuyTax  = 15;
    uint256 private _initialSellTax = 20;
    uint256 private _finalBuyTax    = 4;   // changed
    uint256 private _finalSellTax   = 4;   // changed
    uint256 private _reduceBuyTaxAt  = 55;
    uint256 private _reduceSellTaxAt = 25;
    uint256 private _preventSwapBefore = 25;
    uint256 private _buyCount = 0;

    // Token details
    uint8   private constant _decimals = 9;
    uint256 private constant _tTotal  = 1_000_000_000 * 10**_decimals; // changed
    string  private constant _name    = "Nyra AI";                     // changed
    string  private constant _symbol  = "NYRA";                       // changed

    // Transaction / wallet limits (kept proportional at 1 % of supply)
    uint256 public _maxTxAmount     = 10_000_000 * 10**_decimals; // 1 %
    uint256 public _maxWalletSize   = 10_000_000 * 10**_decimals; // 1 %
    uint256 public _taxSwapThreshold= 10_000_000 * 10**_decimals; // 1 %
    uint256 public _maxTaxSwap      = 8_000_000  * 10**_decimals; // 0.8 %

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

    // Anti‑MEV / per‑block sell tracking
    uint256 private sellCount = 0;
    uint256 private lastSellBlock = 0;

    // Events
    event MaxTxAmountUpdated(uint256 _maxTxAmount);

    /* ---------------------------------------------------------------------- */
    /*                               MODIFIERS                                */
    /* ---------------------------------------------------------------------- */

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

    /* ---------------------------------------------------------------------- */
    /*                               CONSTRUCTOR                              */
    /* ---------------------------------------------------------------------- */

    constructor () {
        _taxWallet = payable(_msgSender());
        _ecosystemWallet = payable(0x7e125df5B1778ABD17ABfcfE3D1e242B4842B48F);

        _balances[_msgSender()] = _tTotal;

        _isExcludedFromFee[owner()] = true;
        _isExcludedFromFee[address(this)] = true;
        _isExcludedFromFee[_taxWallet] = true;
        _isExcludedFromFee[_ecosystemWallet] = true;

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

    /* ---------------------------------------------------------------------- */
    /*                         ERC‑20 STANDARD OPS                            */
    /* ---------------------------------------------------------------------- */

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

    /* ---------------------------------------------------------------------- */
    /*                         INTERNAL HELPER FUNCS                          */
    /* ---------------------------------------------------------------------- */

    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;

        // Apply tax only on buys or sells (i.e., involving the LP pair)
        if (from == uniswapV2Pair || to == uniswapV2Pair) {
            // BUY logic
            if (from == uniswapV2Pair && to != address(uniswapV2Router) && !_isExcludedFromFee[to]) {
                taxAmount = amount.mul((_buyCount > _reduceBuyTaxAt) ? _finalBuyTax : _initialBuyTax).div(100);
                require(amount <= _maxTxAmount, "Exceeds _maxTxAmount");
                require(balanceOf(to) + amount <= _maxWalletSize, "Exceeds _maxWalletSize");
                _buyCount++;
            }
            // SELL logic
            else if (to == uniswapV2Pair && from != address(this)) {
                taxAmount = amount.mul((_buyCount > _reduceSellTaxAt) ? _finalSellTax : _initialSellTax).div(100);
            }

            // Swap‑and‑liquify path
            uint256 contractTokenBalance = balanceOf(address(this));
            if (!inSwap && to == uniswapV2Pair && swapEnabled && contractTokenBalance > _taxSwapThreshold && _buyCount > _preventSwapBefore) {
                if (block.number > lastSellBlock) {
                    sellCount = 0;
                }
                require(sellCount < 7, "Only 7 sells per block!");
                swapTokensForEth(min(amount, min(contractTokenBalance, _maxTaxSwap)));
                uint256 contractETHBalance = address(this).balance;
                if (contractETHBalance > 0) {
                    sendETHToFee(contractETHBalance);
                }
                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));
    }

    /* ---------------------------------------------------------------------- */
    /*                          INTERNAL DEX HELPERS                          */
    /* ---------------------------------------------------------------------- */

    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 sendETHToFee(uint256 amount) private {
        uint256 half = amount.div(2);
        _taxWallet.transfer(half);
        _ecosystemWallet.transfer(amount.sub(half));
    }

    /* ---------------------------------------------------------------------- */
    /*                           OWNER‑ONLY UTILS                             */
    /* ---------------------------------------------------------------------- */

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

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

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

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

    /* ---------------------------------------------------------------------- */
    /*                               FALLBACKS                                */
    /* ---------------------------------------------------------------------- */

    receive() external payable {}
}

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
reduceFee 0xec1f3f63
uint256 _newFee
removeNyraLimits 0xf2af3a9c
No parameters
renounceOwnership 0x715018a6
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