Forkchoice Ethereum Mainnet

Address Contract Partially Verified

Address 0xf690bB39a99eF124aa3AdF182780910211d649F2
Balance 0 ETH
Nonce 1
Code Size 13923 bytes
Indexed Transactions 0 (1 on-chain, 1.4% indexed)
External Etherscan · Sourcify

Contract Bytecode

13923 bytes
0x6080604052600436106102255760003560e01c806370a0823111610123578063a22cb465116100ab578063cb2b1c5e1161006f578063cb2b1c5e1461079c578063d5abeb01146107c5578063e268e4d3146107f0578063e985e9c514610819578063f2fde38b1461085657610225565b8063a22cb465146106c6578063abfc4efa146106ef578063b88d4fde1461071a578063bedb86fb14610736578063c87b56dd1461075f57610225565b80638da5cb5b116100f25780638da5cb5b14610602578063940cd05b1461062d57806395d89b4114610656578063a0712d6814610681578063a0bcfc7f1461069d57610225565b806370a082311461055a578063715018a6146105975780638456cb59146105ae5780638ba4cc3c146105d957610225565b80633ccfd60b116101b15780634751333411610175578063475133341461047557806354214f69146104a05780635b28fd91146104cb5780636352211e146104f45780636f8b44b01461053157610225565b80633ccfd60b146103c55780633d6d652a146103dc57806342842e0e1461040557806344a0d68a14610421578063453c23101461044a57610225565b8063095ea7b3116101f8578063095ea7b31461030c57806313faede6146103285780631638fef01461035357806318160ddd1461037e57806323b872dd146103a957610225565b80630103c92b1461022a57806301ffc9a71461026757806306fdde03146102a4578063081812fc146102cf575b600080fd5b34801561023657600080fd5b50610251600480360381019061024c91906125ca565b61087f565b60405161025e9190612610565b60405180910390f35b34801561027357600080fd5b5061028e60048036038101906102899190612683565b610897565b60405161029b91906126cb565b60405180910390f35b3480156102b057600080fd5b506102b9610929565b6040516102c69190612776565b60405180910390f35b3480156102db57600080fd5b506102f660048036038101906102f191906127c4565b6109bb565b6040516103039190612800565b60405180910390f35b6103266004803603810190610321919061281b565b610a3a565b005b34801561033457600080fd5b5061033d610b7e565b60405161034a9190612610565b60405180910390f35b34801561035f57600080fd5b50610368610b84565b6040516103759190612776565b60405180910390f35b34801561038a57600080fd5b50610393610c12565b6040516103a09190612610565b60405180910390f35b6103c360048036038101906103be919061285b565b610c29565b005b3480156103d157600080fd5b506103da610f4b565b005b3480156103e857600080fd5b5061040360048036038101906103fe91906127c4565b610fd3565b005b61041f600480360381019061041a919061285b565b611029565b005b34801561042d57600080fd5b50610448600480360381019061044391906127c4565b611049565b005b34801561045657600080fd5b5061045f61105b565b60405161046c9190612610565b60405180910390f35b34801561048157600080fd5b5061048a611061565b6040516104979190612610565b60405180910390f35b3480156104ac57600080fd5b506104b5611067565b6040516104c291906126cb565b60405180910390f35b3480156104d757600080fd5b506104f260048036038101906104ed91906127c4565b61107a565b005b34801561050057600080fd5b5061051b600480360381019061051691906127c4565b61108c565b6040516105289190612800565b60405180910390f35b34801561053d57600080fd5b50610558600480360381019061055391906127c4565b61109e565b005b34801561056657600080fd5b50610581600480360381019061057c91906125ca565b6110b0565b60405161058e9190612610565b60405180910390f35b3480156105a357600080fd5b506105ac611168565b005b3480156105ba57600080fd5b506105c361117c565b6040516105d091906126cb565b60405180910390f35b3480156105e557600080fd5b5061060060048036038101906105fb919061281b565b61118f565b005b34801561060e57600080fd5b506106176111fc565b6040516106249190612800565b60405180910390f35b34801561063957600080fd5b50610654600480360381019061064f91906128da565b611226565b005b34801561066257600080fd5b5061066b61124b565b6040516106789190612776565b60405180910390f35b61069b600480360381019061069691906127c4565b6112dd565b005b3480156106a957600080fd5b506106c460048036038101906106bf9190612a3c565b6116b9565b005b3480156106d257600080fd5b506106ed60048036038101906106e89190612a85565b6116d4565b005b3480156106fb57600080fd5b506107046117df565b6040516107119190612610565b60405180910390f35b610734600480360381019061072f9190612b66565b6117e5565b005b34801561074257600080fd5b5061075d600480360381019061075891906128da565b611858565b005b34801561076b57600080fd5b50610786600480360381019061078191906127c4565b61187d565b6040516107939190612776565b60405180910390f35b3480156107a857600080fd5b506107c360048036038101906107be9190612a3c565b6119d3565b005b3480156107d157600080fd5b506107da6119ee565b6040516107e79190612610565b60405180910390f35b3480156107fc57600080fd5b50610817600480360381019061081291906127c4565b6119f4565b005b34801561082557600080fd5b50610840600480360381019061083b9190612be9565b611a4a565b60405161084d91906126cb565b60405180910390f35b34801561086257600080fd5b5061087d600480360381019061087891906125ca565b611ade565b005b60126020528060005260406000206000915090505481565b60006301ffc9a760e01b827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff191614806108f257506380ac58cd60e01b827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916145b806109225750635b5e139f60e01b827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916145b9050919050565b60606002805461093890612c58565b80601f016020809104026020016040519081016040528092919081815260200182805461096490612c58565b80156109b15780601f10610986576101008083540402835291602001916109b1565b820191906000526020600020905b81548152906001019060200180831161099457829003601f168201915b5050505050905090565b60006109c682611b61565b6109fc576040517fcf4700e400000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6006600083815260200190815260200160002060000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050919050565b6000610a458261108c565b90508073ffffffffffffffffffffffffffffffffffffffff16610a66611bc0565b73ffffffffffffffffffffffffffffffffffffffff1614610ac957610a9281610a8d611bc0565b611a4a565b610ac8576040517fcfb3b94200000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b5b826006600084815260200190815260200160002060000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550818373ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92560405160405180910390a4505050565b600c5481565b60118054610b9190612c58565b80601f0160208091040260200160405190810160405280929190818152602001828054610bbd90612c58565b8015610c0a5780601f10610bdf57610100808354040283529160200191610c0a565b820191906000526020600020905b815481529060010190602001808311610bed57829003601f168201915b505050505081565b6000610c1c611bc8565b6001546000540303905090565b6000610c3482611bd1565b90508373ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1614610c9b576040517fa114810000000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b600080610ca784611c9d565b91509150610cbd8187610cb8611bc0565b611cc4565b610d0957610cd286610ccd611bc0565b611a4a565b610d08576040517f59c896be00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b5b600073ffffffffffffffffffffffffffffffffffffffff168573ffffffffffffffffffffffffffffffffffffffff1603610d6f576040517fea553b3400000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b610d7c8686866001611d08565b8015610d8757600082555b600560008773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020600081546001900391905081905550600560008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206000815460010191905081905550610e5585610e31888887611d0e565b7c020000000000000000000000000000000000000000000000000000000017611d36565b600460008681526020019081526020016000208190555060007c0200000000000000000000000000000000000000000000000000000000841603610edb5760006001850190506000600460008381526020019081526020016000205403610ed9576000548114610ed8578360046000838152602001908152602001600020819055505b5b505b838573ffffffffffffffffffffffffffffffffffffffff168773ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a4610f438686866001611d61565b505050505050565b610f53611d67565b6000610f5d6111fc565b73ffffffffffffffffffffffffffffffffffffffff1647604051610f8090612cba565b60006040518083038185875af1925050503d8060008114610fbd576040519150601f19603f3d011682016040523d82523d6000602084013e610fc2565b606091505b5050905080610fd057600080fd5b50565b610fdb611d67565b600e54811061101f576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161101690612d1b565b60405180910390fd5b80600d8190555050565b611044838383604051806020016040528060008152506117e5565b505050565b611051611d67565b80600c8190555050565b600e5481565b600b5481565b600f60009054906101000a900460ff1681565b611082611d67565b80600b8190555050565b600061109782611bd1565b9050919050565b6110a6611d67565b80600a8190555050565b60008073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603611117576040517f8f4eb60400000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b67ffffffffffffffff600560008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054169050919050565b611170611d67565b61117a6000611de5565b565b600f60019054906101000a900460ff1681565b611197611d67565b600a54816111a3611eab565b6111ad9190612d6a565b11156111ee576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016111e590612dea565b60405180910390fd5b6111f88282611ebe565b5050565b6000600860009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b61122e611d67565b80600f60006101000a81548160ff02191690831515021790555050565b60606003805461125a90612c58565b80601f016020809104026020016040519081016040528092919081815260200182805461128690612c58565b80156112d35780601f106112a8576101008083540402835291602001916112d3565b820191906000526020600020905b8154815290600101906020018083116112b657829003601f168201915b5050505050905090565b600f60019054906101000a900460ff161561132d576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161132490612e56565b60405180910390fd5b600d54601260003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054106113ca5780600c546113839190612e76565b3410156113c5576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016113bc90612f2a565b60405180910390fd5b611538565b600b54816113d6610c12565b6113e09190612d6a565b116114e657601260003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054600d546114329190612f4a565b8111156114e157601260003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054600d546114869190612f4a565b816114919190612f4a565b600c5461149e9190612e76565b3410156114e0576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016114d790612fca565b60405180910390fd5b5b611537565b80600c546114f49190612e76565b341015611536576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161152d90612f2a565b60405180910390fd5b5b5b600a5481611544611eab565b61154e9190612d6a565b111561158f576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161158690612dea565b60405180910390fd5b600e5481601260003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020546115dd9190612d6a565b111561161e576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161161590613036565b60405180910390fd5b6116283382611ebe565b80601260003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020546116739190612d6a565b601260003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208190555050565b6116c1611d67565b80601090816116d09190613202565b5050565b80600760006116e1611bc0565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055508173ffffffffffffffffffffffffffffffffffffffff1661178e611bc0565b73ffffffffffffffffffffffffffffffffffffffff167f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31836040516117d391906126cb565b60405180910390a35050565b600d5481565b6117f0848484610c29565b60008373ffffffffffffffffffffffffffffffffffffffff163b146118525761181b84848484611edc565b611851576040517fd1a57ed600000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b5b50505050565b611860611d67565b80600f60016101000a81548160ff02191690831515021790555050565b606061188882611b61565b6118c7576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016118be90613320565b60405180910390fd5b60001515600f60009054906101000a900460ff1615150361197457601180546118ef90612c58565b80601f016020809104026020016040519081016040528092919081815260200182805461191b90612c58565b80156119685780601f1061193d57610100808354040283529160200191611968565b820191906000526020600020905b81548152906001019060200180831161194b57829003601f168201915b505050505090506119ce565b600061197e61202c565b511161199957604051806020016040528060008152506119cb565b6119a161202c565b6119aa836120be565b6040516020016119bb9291906133c8565b6040516020818303038152906040525b90505b919050565b6119db611d67565b80601190816119ea9190613202565b5050565b600a5481565b6119fc611d67565b600d548111611a40576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611a3790612d1b565b60405180910390fd5b80600e8190555050565b6000600760008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16905092915050565b611ae6611d67565b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1603611b55576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611b4c90613469565b60405180910390fd5b611b5e81611de5565b50565b600081611b6c611bc8565b11158015611b7b575060005482105b8015611bb9575060007c0100000000000000000000000000000000000000000000000000000000600460008581526020019081526020016000205416145b9050919050565b600033905090565b60006001905090565b60008082905080611be0611bc8565b11611c6657600054811015611c655760006004600083815260200190815260200160002054905060007c0100000000000000000000000000000000000000000000000000000000821603611c63575b60008103611c59576004600083600190039350838152602001908152602001600020549050611c2f565b8092505050611c98565b505b5b6040517fdf2d9b4200000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b919050565b60008060006006600085815260200190815260200160002090508092508254915050915091565b600073ffffffffffffffffffffffffffffffffffffffff8316925073ffffffffffffffffffffffffffffffffffffffff821691508382148383141790509392505050565b50505050565b60008060e883901c905060e8611d2586868461218c565b62ffffff16901b9150509392505050565b600073ffffffffffffffffffffffffffffffffffffffff83169250814260a01b178317905092915050565b50505050565b611d6f612195565b73ffffffffffffffffffffffffffffffffffffffff16611d8d6111fc565b73ffffffffffffffffffffffffffffffffffffffff1614611de3576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611dda906134fb565b60405180910390fd5b565b6000600860009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905081600860006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508173ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35050565b6000611eb5611bc8565b60005403905090565b611ed882826040518060200160405280600081525061219d565b5050565b60008373ffffffffffffffffffffffffffffffffffffffff1663150b7a02611f02611bc0565b8786866040518563ffffffff1660e01b8152600401611f249493929190613570565b6020604051808303816000875af1925050508015611f6057506040513d601f19601f82011682018060405250810190611f5d91906135d1565b60015b611fd9573d8060008114611f90576040519150601f19603f3d011682016040523d82523d6000602084013e611f95565b606091505b506000815103611fd1576040517fd1a57ed600000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b805181602001fd5b63150b7a0260e01b7bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916817bffffffffffffffffffffffffffffffffffffffffffffffffffffffff191614915050949350505050565b60606010805461203b90612c58565b80601f016020809104026020016040519081016040528092919081815260200182805461206790612c58565b80156120b45780601f10612089576101008083540402835291602001916120b4565b820191906000526020600020905b81548152906001019060200180831161209757829003601f168201915b5050505050905090565b6060600060016120cd8461223a565b01905060008167ffffffffffffffff8111156120ec576120eb612911565b5b6040519080825280601f01601f19166020018201604052801561211e5781602001600182028036833780820191505090505b509050600082602001820190505b600115612181578080600190039150507f3031323334353637383961626364656600000000000000000000000000000000600a86061a8153600a8581612175576121746135fe565b5b0494506000850361212c575b819350505050919050565b60009392505050565b600033905090565b6121a7838361238d565b60008373ffffffffffffffffffffffffffffffffffffffff163b1461223557600080549050600083820390505b6121e76000868380600101945086611edc565b61221d576040517fd1a57ed600000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b8181106121d457816000541461223257600080fd5b50505b505050565b600080600090507a184f03e93ff9f4daa797ed6e38ed64bf6a1f0100000000000000008310612298577a184f03e93ff9f4daa797ed6e38ed64bf6a1f010000000000000000838161228e5761228d6135fe565b5b0492506040810190505b6d04ee2d6d415b85acef810000000083106122d5576d04ee2d6d415b85acef810000000083816122cb576122ca6135fe565b5b0492506020810190505b662386f26fc10000831061230457662386f26fc1000083816122fa576122f96135fe565b5b0492506010810190505b6305f5e100831061232d576305f5e1008381612323576123226135fe565b5b0492506008810190505b6127108310612352576127108381612348576123476135fe565b5b0492506004810190505b60648310612375576064838161236b5761236a6135fe565b5b0492506002810190505b600a8310612384576001810190505b80915050919050565b600080549050600082036123cd576040517fb562e8dd00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6123da6000848385611d08565b600160406001901b178202600560008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008282540192505081905550612451836124426000866000611d0e565b61244b85612548565b17611d36565b6004600083815260200190815260200160002081905550600080838301905073ffffffffffffffffffffffffffffffffffffffff85169150828260007fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef600080a4600183015b8181146124f257808360007fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef600080a46001810190506124b7565b506000820361252d576040517f2e07630000000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b8060008190555050506125436000848385611d61565b505050565b60006001821460e11b9050919050565b6000604051905090565b600080fd5b600080fd5b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b60006125978261256c565b9050919050565b6125a78161258c565b81146125b257600080fd5b50565b6000813590506125c48161259e565b92915050565b6000602082840312156125e0576125df612562565b5b60006125ee848285016125b5565b91505092915050565b6000819050919050565b61260a816125f7565b82525050565b60006020820190506126256000830184612601565b92915050565b60007fffffffff0000000000000000000000000000000000000000000000000000000082169050919050565b6126608161262b565b811461266b57600080fd5b50565b60008135905061267d81612657565b92915050565b60006020828403121561269957612698612562565b5b60006126a78482850161266e565b91505092915050565b60008115159050919050565b6126c5816126b0565b82525050565b60006020820190506126e060008301846126bc565b92915050565b600081519050919050565b600082825260208201905092915050565b60005b83811015612720578082015181840152602081019050612705565b60008484015250505050565b6000601f19601f8301169050919050565b6000612748826126e6565b61275281856126f1565b9350612762818560208601612702565b61276b8161272c565b840191505092915050565b60006020820190508181036000830152612790818461273d565b905092915050565b6127a1816125f7565b81146127ac57600080fd5b50565b6000813590506127be81612798565b92915050565b6000602082840312156127da576127d9612562565b5b60006127e8848285016127af565b91505092915050565b6127fa8161258c565b82525050565b600060208201905061281560008301846127f1565b92915050565b6000806040838503121561283257612831612562565b5b6000612840858286016125b5565b9250506020612851858286016127af565b9150509250929050565b60008060006060848603121561287457612873612562565b5b6000612882868287016125b5565b9350506020612893868287016125b5565b92505060406128a4868287016127af565b9150509250925092565b6128b7816126b0565b81146128c257600080fd5b50565b6000813590506128d4816128ae565b92915050565b6000602082840312156128f0576128ef612562565b5b60006128fe848285016128c5565b91505092915050565b600080fd5b600080fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b6129498261272c565b810181811067ffffffffffffffff8211171561296857612967612911565b5b80604052505050565b600061297b612558565b90506129878282612940565b919050565b600067ffffffffffffffff8211156129a7576129a6612911565b5b6129b08261272c565b9050602081019050919050565b82818337600083830152505050565b60006129df6129da8461298c565b612971565b9050828152602081018484840111156129fb576129fa61290c565b5b612a068482856129bd565b509392505050565b600082601f830112612a2357612a22612907565b5b8135612a338482602086016129cc565b91505092915050565b600060208284031215612a5257612a51612562565b5b600082013567ffffffffffffffff811115612a7057612a6f612567565b5b612a7c84828501612a0e565b91505092915050565b60008060408385031215612a9c57612a9b612562565b5b6000612aaa858286016125b5565b9250506020612abb858286016128c5565b9150509250929050565b600067ffffffffffffffff821115612ae057612adf612911565b5b612ae98261272c565b9050602081019050919050565b6000612b09612b0484612ac5565b612971565b905082815260208101848484011115612b2557612b2461290c565b5b612b308482856129bd565b509392505050565b600082601f830112612b4d57612b4c612907565b5b8135612b5d848260208601612af6565b91505092915050565b60008060008060808587031215612b8057612b7f612562565b5b6000612b8e878288016125b5565b9450506020612b9f878288016125b5565b9350506040612bb0878288016127af565b925050606085013567ffffffffffffffff811115612bd157612bd0612567565b5b612bdd87828801612b38565b91505092959194509250565b60008060408385031215612c0057612bff612562565b5b6000612c0e858286016125b5565b9250506020612c1f858286016125b5565b9150509250929050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b60006002820490506001821680612c7057607f821691505b602082108103612c8357612c82612c29565b5b50919050565b600081905092915050565b50565b6000612ca4600083612c89565b9150612caf82612c94565b600082019050919050565b6000612cc582612c97565b9150819050919050565b7f596f2120497473204e6f7420706f737369626c65000000000000000000000000600082015250565b6000612d056014836126f1565b9150612d1082612ccf565b602082019050919050565b60006020820190508181036000830152612d3481612cf8565b9050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b6000612d75826125f7565b9150612d80836125f7565b9250828201905080821115612d9857612d97612d3b565b5b92915050565b7f45786365656473206d6178206170657320737570706c79000000000000000000600082015250565b6000612dd46017836126f1565b9150612ddf82612d9e565b602082019050919050565b60006020820190508181036000830152612e0381612dc7565b9050919050565b7f41706573206973206f6e20706175736500000000000000000000000000000000600082015250565b6000612e406010836126f1565b9150612e4b82612e0a565b602082019050919050565b60006020820190508181036000830152612e6f81612e33565b9050919050565b6000612e81826125f7565b9150612e8c836125f7565b9250828202612e9a816125f7565b91508282048414831517612eb157612eb0612d3b565b5b5092915050565b7f496e73756666696369656e74206574682066756e647320746f2062757920617060008201527f6573000000000000000000000000000000000000000000000000000000000000602082015250565b6000612f146022836126f1565b9150612f1f82612eb8565b604082019050919050565b60006020820190508181036000830152612f4381612f07565b9050919050565b6000612f55826125f7565b9150612f60836125f7565b9250828203905081811115612f7857612f77612d3b565b5b92915050565b7f496e73756666696369656e742066756e64730000000000000000000000000000600082015250565b6000612fb46012836126f1565b9150612fbf82612f7e565b602082019050919050565b60006020820190508181036000830152612fe381612fa7565b9050919050565b7f45786365656473206d61782061706573207065722077616c6c65740000000000600082015250565b6000613020601b836126f1565b915061302b82612fea565b602082019050919050565b6000602082019050818103600083015261304f81613013565b9050919050565b60008190508160005260206000209050919050565b60006020601f8301049050919050565b600082821b905092915050565b6000600883026130b87fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8261307b565b6130c2868361307b565b95508019841693508086168417925050509392505050565b6000819050919050565b60006130ff6130fa6130f5846125f7565b6130da565b6125f7565b9050919050565b6000819050919050565b613119836130e4565b61312d61312582613106565b848454613088565b825550505050565b600090565b613142613135565b61314d818484613110565b505050565b5b818110156131715761316660008261313a565b600181019050613153565b5050565b601f8211156131b65761318781613056565b6131908461306b565b8101602085101561319f578190505b6131b36131ab8561306b565b830182613152565b50505b505050565b600082821c905092915050565b60006131d9600019846008026131bb565b1980831691505092915050565b60006131f283836131c8565b9150826002028217905092915050565b61320b826126e6565b67ffffffffffffffff81111561322457613223612911565b5b61322e8254612c58565b613239828285613175565b600060209050601f83116001811461326c576000841561325a578287015190505b61326485826131e6565b8655506132cc565b601f19841661327a86613056565b60005b828110156132a25784890151825560018201915060208501945060208101905061327d565b868310156132bf57848901516132bb601f8916826131c8565b8355505b6001600288020188555050505b505050505050565b7f546861742061706520646f65736e277420657869737400000000000000000000600082015250565b600061330a6016836126f1565b9150613315826132d4565b602082019050919050565b60006020820190508181036000830152613339816132fd565b9050919050565b600081905092915050565b6000613356826126e6565b6133608185613340565b9350613370818560208601612702565b80840191505092915050565b7f2e6a736f6e000000000000000000000000000000000000000000000000000000600082015250565b60006133b2600583613340565b91506133bd8261337c565b600582019050919050565b60006133d4828561334b565b91506133e0828461334b565b91506133eb826133a5565b91508190509392505050565b7f4f776e61626c653a206e6577206f776e6572206f66204170652069732074686560008201527f207a65726f206164647265737300000000000000000000000000000000000000602082015250565b6000613453602d836126f1565b915061345e826133f7565b604082019050919050565b6000602082019050818103600083015261348281613446565b9050919050565b7f4f776e61626c653a2063616c6c6572206f6620417065206973206e6f7420746860008201527f65206f776e657221000000000000000000000000000000000000000000000000602082015250565b60006134e56028836126f1565b91506134f082613489565b604082019050919050565b60006020820190508181036000830152613514816134d8565b9050919050565b600081519050919050565b600082825260208201905092915050565b60006135428261351b565b61354c8185613526565b935061355c818560208601612702565b6135658161272c565b840191505092915050565b600060808201905061358560008301876127f1565b61359260208301866127f1565b61359f6040830185612601565b81810360608301526135b18184613537565b905095945050505050565b6000815190506135cb81612657565b92915050565b6000602082840312156135e7576135e6612562565b5b60006135f5848285016135bc565b91505092915050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601260045260246000fdfea26469706673582212204bcc786bda7c690c30b6451640dcf6868d1027ea342bb0f860c87665109d119164736f6c63430008130033

Verified Source Code Partial Match

Compiler: v0.8.19+commit.7dd6d404 EVM: paris Optimization: No
JapanLadyApes.sol 1291 lines
/**

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

Collection Name: Japan Lady Apes Club

Description:
The Japan Lady Apes Club is a unique and vibrant collection of 6666 tokens built on the Ethereum Blockchain. Each token represents a distinct and beautifully crafted character within the collection. These characters embody the spirit and culture of Japan, each with its own story and personality.

Club Goals:
The Japan Lady Apes Club has set several ambitious goals to foster a thriving and engaged community:

Cultural Celebration: Our primary goal is to celebrate and honor Japanese culture through art, storytelling, and community engagement. We aim to educate and entertain our members about the rich traditions, history, and folklore of Japan.

Community Building: We strive to create a welcoming and supportive community where members can connect, share, and collaborate. Our aim is to build a diverse and inclusive group of enthusiasts who appreciate Japanese culture and art.

Artistic Exploration: The Japan Lady Apes Club is committed to pushing the boundaries of artistic expression. We encourage artists within our community to experiment with various styles, techniques, and media to create captivating and unique artwork.

Join us on this exciting journey as we explore the wonders of Japan through the Japan Lady Apes Club. Together, we'll create, learn, and make a difference in the world while enjoying the beauty of Japanese culture.

*/

pragma solidity ^0.8.0;
abstract contract ReentrancyGuard {

    uint256 private constant _NOT_ENTERED = 1;
    uint256 private constant _ENTERED = 2;

    uint256 private _status;

    constructor() {
        _status = _NOT_ENTERED;
    }

    modifier nonReentrant() {
        _nonReentrantBefore();
        _;
        _nonReentrantAfter();
    }

    function _nonReentrantBefore() private {
        // On the first call to nonReentrant, _status will be _NOT_ENTERED
        require(_status != _ENTERED, "Yo! ReentrancyGuard: reentrant call");

        // Any calls to nonReentrant after this point will fail
        _status = _ENTERED;
    }

    function _nonReentrantAfter() private {

        _status = _NOT_ENTERED;
    }
}

pragma solidity ^0.8.0;

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

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

pragma solidity ^0.8.0;

abstract contract Ownable is Context {
    address private _owner;

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

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

    modifier onlyOwner() {
        _checkOwner();
        _;
    }

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

    function _checkOwner() internal view virtual {
        require(owner() == _msgSender(), "Ownable: caller of Ape is not the owner!");
    }

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

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

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

pragma solidity ^0.8.0;

library Math {
    enum Rounding {
        Down, // Toward negative infinity
        Up, // Toward infinity
        Zero // Toward zero
    }

    function max(uint256 a, uint256 b) internal pure returns (uint256) {
        return a > b ? a : b;
    }

    function min(uint256 a, uint256 b) internal pure returns (uint256) {
        return a < b ? a : b;
    }

    function average(uint256 a, uint256 b) internal pure returns (uint256) {
        // (a + b) / 2 can overflow.
        return (a & b) + (a ^ b) / 2;
    }

    function ceilDiv(uint256 a, uint256 b) internal pure returns (uint256) {
        // (a + b - 1) / b can overflow on addition, so we distribute.
        return a == 0 ? 0 : (a - 1) / b + 1;
    }

    function mulDiv(
        uint256 x,
        uint256 y,
        uint256 denominator
    ) internal pure returns (uint256 result) {
        unchecked {

            uint256 prod0; // Least significant 256 bits of the product
            uint256 prod1; // Most significant 256 bits of the product
            assembly {
                let mm := mulmod(x, y, not(0))
                prod0 := mul(x, y)
                prod1 := sub(sub(mm, prod0), lt(mm, prod0))
            }

            // Handle non-overflow cases, 256 by 256 division.
            if (prod1 == 0) {
                return prod0 / denominator;
            }

            // Make sure the result is less than 2^256. Also prevents denominator == 0.
            require(denominator > prod1);

            uint256 remainder;
            assembly {
                // Compute remainder using mulmod.
                remainder := mulmod(x, y, denominator)

                // Subtract 256 bit number from 512 bit number.
                prod1 := sub(prod1, gt(remainder, prod0))
                prod0 := sub(prod0, remainder)
            }

        
            uint256 twos = denominator & (~denominator + 1);
            assembly {
                // Divide denominator by twos.
                denominator := div(denominator, twos)

                // Divide [prod1 prod0] by twos.
                prod0 := div(prod0, twos)

                // Flip twos such that it is 2^256 / twos. If twos is zero, then it becomes one.
                twos := add(div(sub(0, twos), twos), 1)
            }

            // Shift in bits from prod1 into prod0.
            prod0 |= prod1 * twos;
            uint256 inverse = (3 * denominator) ^ 2;

            inverse *= 2 - denominator * inverse; // inverse mod 2^8
            inverse *= 2 - denominator * inverse; // inverse mod 2^16
            inverse *= 2 - denominator * inverse; // inverse mod 2^32
            inverse *= 2 - denominator * inverse; // inverse mod 2^64
            inverse *= 2 - denominator * inverse; // inverse mod 2^128
            inverse *= 2 - denominator * inverse; // inverse mod 2^256
            result = prod0 * inverse;
            return result;
        }
    }

    function mulDiv(
        uint256 x,
        uint256 y,
        uint256 denominator,
        Rounding rounding
    ) internal pure returns (uint256) {
        uint256 result = mulDiv(x, y, denominator);
        if (rounding == Rounding.Up && mulmod(x, y, denominator) > 0) {
            result += 1;
        }
        return result;
    }

    function sqrt(uint256 a) internal pure returns (uint256) {
        if (a == 0) {
            return 0;
        }

        uint256 result = 1 << (log2(a) >> 1);

        unchecked {
            result = (result + a / result) >> 1;
            result = (result + a / result) >> 1;
            result = (result + a / result) >> 1;
            result = (result + a / result) >> 1;
            result = (result + a / result) >> 1;
            result = (result + a / result) >> 1;
            result = (result + a / result) >> 1;
            return min(result, a / result);
        }
    }

    function sqrt(uint256 a, Rounding rounding) internal pure returns (uint256) {
        unchecked {
            uint256 result = sqrt(a);
            return result + (rounding == Rounding.Up && result * result < a ? 1 : 0);
        }
    }

    function log2(uint256 value) internal pure returns (uint256) {
        uint256 result = 0;
        unchecked {
            if (value >> 128 > 0) {
                value >>= 128;
                result += 128;
            }
            if (value >> 64 > 0) {
                value >>= 64;
                result += 64;
            }
            if (value >> 32 > 0) {
                value >>= 32;
                result += 32;
            }
            if (value >> 16 > 0) {
                value >>= 16;
                result += 16;
            }
            if (value >> 8 > 0) {
                value >>= 8;
                result += 8;
            }
            if (value >> 4 > 0) {
                value >>= 4;
                result += 4;
            }
            if (value >> 2 > 0) {
                value >>= 2;
                result += 2;
            }
            if (value >> 1 > 0) {
                result += 1;
            }
        }
        return result;
    }

    function log2(uint256 value, Rounding rounding) internal pure returns (uint256) {
        unchecked {
            uint256 result = log2(value);
            return result + (rounding == Rounding.Up && 1 << result < value ? 1 : 0);
        }
    }

    function log10(uint256 value) internal pure returns (uint256) {
        uint256 result = 0;
        unchecked {
            if (value >= 10**64) {
                value /= 10**64;
                result += 64;
            }
            if (value >= 10**32) {
                value /= 10**32;
                result += 32;
            }
            if (value >= 10**16) {
                value /= 10**16;
                result += 16;
            }
            if (value >= 10**8) {
                value /= 10**8;
                result += 8;
            }
            if (value >= 10**4) {
                value /= 10**4;
                result += 4;
            }
            if (value >= 10**2) {
                value /= 10**2;
                result += 2;
            }
            if (value >= 10**1) {
                result += 1;
            }
        }
        return result;
    }

    function log10(uint256 value, Rounding rounding) internal pure returns (uint256) {
        unchecked {
            uint256 result = log10(value);
            return result + (rounding == Rounding.Up && 10**result < value ? 1 : 0);
        }
    }

    function log256(uint256 value) internal pure returns (uint256) {
        uint256 result = 0;
        unchecked {
            if (value >> 128 > 0) {
                value >>= 128;
                result += 16;
            }
            if (value >> 64 > 0) {
                value >>= 64;
                result += 8;
            }
            if (value >> 32 > 0) {
                value >>= 32;
                result += 4;
            }
            if (value >> 16 > 0) {
                value >>= 16;
                result += 2;
            }
            if (value >> 8 > 0) {
                result += 1;
            }
        }
        return result;
    }

    function log256(uint256 value, Rounding rounding) internal pure returns (uint256) {
        unchecked {
            uint256 result = log256(value);
            return result + (rounding == Rounding.Up && 1 << (result * 8) < value ? 1 : 0);
        }
    }
}

pragma solidity ^0.8.0;

library Strings {
    bytes16 private constant _SYMBOLS = "0123456789abcdef";
    uint8 private constant _ADDRESS_LENGTH = 20;

    /**
     * @dev Converts a `uint256` to its ASCII `string` decimal representation.
     */
    function toString(uint256 value) internal pure returns (string memory) {
        unchecked {
            uint256 length = Math.log10(value) + 1;
            string memory buffer = new string(length);
            uint256 ptr;
            /// @solidity memory-safe-assembly
            assembly {
                ptr := add(buffer, add(32, length))
            }
            while (true) {
                ptr--;
                /// @solidity memory-safe-assembly
                assembly {
                    mstore8(ptr, byte(mod(value, 10), _SYMBOLS))
                }
                value /= 10;
                if (value == 0) break;
            }
            return buffer;
        }
    }

    function toHexString(uint256 value) internal pure returns (string memory) {
        unchecked {
            return toHexString(value, Math.log256(value) + 1);
        }
    }

    function toHexString(uint256 value, uint256 length) internal pure returns (string memory) {
        bytes memory buffer = new bytes(2 * length + 2);
        buffer[0] = "0";
        buffer[1] = "x";
        for (uint256 i = 2 * length + 1; i > 1; --i) {
            buffer[i] = _SYMBOLS[value & 0xf];
            value >>= 4;
        }
        require(value == 0, "Strings: hex length insufficient");
        return string(buffer);
    }

    function toHexString(address addr) internal pure returns (string memory) {
        return toHexString(uint256(uint160(addr)), _ADDRESS_LENGTH);
    }
}

// ERC721A Contracts v4.2.3
// Creator:Chiru Labs

pragma solidity ^0.8.4;

interface IERC721A {

    error ApprovalCallerNotOwnerNorApproved();

    error ApprovalQueryForNonexistentToken();

    error BalanceQueryForZeroAddress();

    error MintToZeroAddress();

    error MintZeroQuantity();

    error OwnerQueryForNonexistentToken();

    error TransferCallerNotOwnerNorApproved();

    error TransferFromIncorrectOwner();

    error TransferToNonERC721ReceiverImplementer();

    error TransferToZeroAddress();

    error URIQueryForNonexistentToken();

    error MintERC2309QuantityExceedsLimit();

    error OwnershipNotInitializedForExtraData();

    struct TokenOwnership {
        // The address of the owner.
        address addr;
        // Stores the start time of ownership with minimal overhead for tokenomics.
        uint64 startTimestamp;
        // Whether the token has been burned.
        bool burned;
        // Arbitrary data similar to `startTimestamp` that can be set via {_extraData}.
        uint24 extraData;
    }

    function totalSupply() external view returns (uint256);

    function supportsInterface(bytes4 interfaceId) external view returns (bool);

    event Transfer(address indexed from, address indexed to, uint256 indexed tokenId);

    event Approval(address indexed owner, address indexed approved, uint256 indexed tokenId);

    event ApprovalForAll(address indexed owner, address indexed operator, bool approved);

    function balanceOf(address owner) external view returns (uint256 balance);

    function ownerOf(uint256 tokenId) external view returns (address owner);

    function safeTransferFrom(
        address from,
        address to,
        uint256 tokenId,
        bytes calldata data
    ) external payable;

    function safeTransferFrom(
        address from,
        address to,
        uint256 tokenId
    ) external payable;

    function transferFrom(
        address from,
        address to,
        uint256 tokenId
    ) external payable;

    function approve(address to, uint256 tokenId) external payable;
    function setApprovalForAll(address operator, bool _approved) external;
    function getApproved(uint256 tokenId) external view returns (address operator);
    function isApprovedForAll(address owner, address operator) external view returns (bool);
    function name() external view returns (string memory);
    function symbol() external view returns (string memory);
    function tokenURI(uint256 tokenId) external view returns (string memory);

    event ConsecutiveTransfer(uint256 indexed fromTokenId, uint256 toTokenId, address indexed from, address indexed to);
}

// ERC721A Contracts v4.2.3
// Creator:Chiru Labs

pragma solidity ^0.8.4;

interface ERC721A__IERC721Receiver {
    function onERC721Received(
        address operator,
        address from,
        uint256 tokenId,
        bytes calldata data
    ) external returns (bytes4);
}

contract ERC721A is IERC721A {
    // Bypass for a `--via-ir` bug (https://github.com/chiru-labs/ERC721A/pull/364).
    struct TokenApprovalRef {
        address value;
    }

    // Mask of an entry in packed address data.
    uint256 private constant _BITMASK_ADDRESS_DATA_ENTRY = (1 << 64) - 1;

    // The bit position of `numberMinted` in packed address data.
    uint256 private constant _BITPOS_NUMBER_MINTED = 64;

    // The bit position of `numberBurned` in packed address data.
    uint256 private constant _BITPOS_NUMBER_BURNED = 128;

    // The bit position of `aux` in packed address data.
    uint256 private constant _BITPOS_AUX = 192;

    // Mask of all 256 bits in packed address data except the 64 bits for `aux`.
    uint256 private constant _BITMASK_AUX_COMPLEMENT = (1 << 192) - 1;

    // The bit position of `startTimestamp` in packed ownership.
    uint256 private constant _BITPOS_START_TIMESTAMP = 160;

    // The bit mask of the `burned` bit in packed ownership.
    uint256 private constant _BITMASK_BURNED = 1 << 224;

    // The bit position of the `nextInitialized` bit in packed ownership.
    uint256 private constant _BITPOS_NEXT_INITIALIZED = 225;

    // The bit mask of the `nextInitialized` bit in packed ownership.
    uint256 private constant _BITMASK_NEXT_INITIALIZED = 1 << 225;

    // The bit position of `extraData` in packed ownership.
    uint256 private constant _BITPOS_EXTRA_DATA = 232;

    // Mask of all 256 bits in a packed ownership except the 24 bits for `extraData`.
    uint256 private constant _BITMASK_EXTRA_DATA_COMPLEMENT = (1 << 232) - 1;

    // The mask of the lower 160 bits for addresses.
    uint256 private constant _BITMASK_ADDRESS = (1 << 160) - 1;
    uint256 private constant _MAX_MINT_ERC2309_QUANTITY_LIMIT = 5000;

    // The `Transfer` event signature is given by:
    // `keccak256(bytes("Transfer(address,address,uint256)"))`.
    bytes32 private constant _TRANSFER_EVENT_SIGNATURE =
        0xddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef;

    uint256 private _currentIndex;

    // The number of tokens burned.
    uint256 private _burnCounter;

    // Token name
    string private _name;

    // Token symbol
    string private _symbol;

    mapping(uint256 => uint256) private _packedOwnerships;
    mapping(address => uint256) private _packedAddressData;
    mapping(uint256 => TokenApprovalRef) private _tokenApprovals;
    mapping(address => mapping(address => bool)) private _operatorApprovals;

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

    function _startTokenId() internal view virtual returns (uint256) {
        return 0;
    }

    function _nextTokenId() internal view virtual returns (uint256) {
        return _currentIndex;
    }

    function totalSupply() public view virtual override returns (uint256) {
        // Counter underflow is impossible as _burnCounter cannot be incremented
        // more than `_currentIndex - _startTokenId()` times.
        unchecked {
            return _currentIndex - _burnCounter - _startTokenId();
        }
    }

    function _totalMinted() internal view virtual returns (uint256) {
        // Counter underflow is impossible as `_currentIndex` does not decrement,
        // and it is initialized to `_startTokenId()`.
        unchecked {
            return _currentIndex - _startTokenId();
        }
    }

    function _totalBurned() internal view virtual returns (uint256) {
        return _burnCounter;
    }

    function balanceOf(address owner) public view virtual override returns (uint256) {
        if (owner == address(0)) revert BalanceQueryForZeroAddress();
        return _packedAddressData[owner] & _BITMASK_ADDRESS_DATA_ENTRY;
    }

    function _numberMinted(address owner) internal view returns (uint256) {
        return (_packedAddressData[owner] >> _BITPOS_NUMBER_MINTED) & _BITMASK_ADDRESS_DATA_ENTRY;
    }

    function _numberBurned(address owner) internal view returns (uint256) {
        return (_packedAddressData[owner] >> _BITPOS_NUMBER_BURNED) & _BITMASK_ADDRESS_DATA_ENTRY;
    }

    function _getAux(address owner) internal view returns (uint64) {
        return uint64(_packedAddressData[owner] >> _BITPOS_AUX);
    }

    function _setAux(address owner, uint64 aux) internal virtual {
        uint256 packed = _packedAddressData[owner];
        uint256 auxCasted;
        // Cast `aux` with assembly to avoid redundant masking.
        assembly {
            auxCasted := aux
        }
        packed = (packed & _BITMASK_AUX_COMPLEMENT) | (auxCasted << _BITPOS_AUX);
        _packedAddressData[owner] = packed;
    }

    function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {

        return
            interfaceId == 0x01ffc9a7 || // ERC165 interface ID for ERC165.
            interfaceId == 0x80ac58cd || // ERC165 interface ID for ERC721.
            interfaceId == 0x5b5e139f; // ERC165 interface ID for ERC721Metadata.
    }

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

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

    function tokenURI(uint256 tokenId) public view virtual override returns (string memory) {
        if (!_exists(tokenId)) revert URIQueryForNonexistentToken();

        string memory baseURI = _baseURI();
        return bytes(baseURI).length != 0 ? string(abi.encodePacked(baseURI, _toString(tokenId))) : '';
    }

    function _baseURI() internal view virtual returns (string memory) {
        return '';
    }

    function ownerOf(uint256 tokenId) public view virtual override returns (address) {
        return address(uint160(_packedOwnershipOf(tokenId)));
    }

    function _ownershipOf(uint256 tokenId) internal view virtual returns (TokenOwnership memory) {
        return _unpackedOwnership(_packedOwnershipOf(tokenId));
    }

    /**
     * @dev Returns the unpacked `TokenOwnership` struct at `index`.
     */
    function _ownershipAt(uint256 index) internal view virtual returns (TokenOwnership memory) {
        return _unpackedOwnership(_packedOwnerships[index]);
    }

    /**
     * @dev Initializes the ownership slot minted at `index` for efficiency purposes.
     */
    function _initializeOwnershipAt(uint256 index) internal virtual {
        if (_packedOwnerships[index] == 0) {
            _packedOwnerships[index] = _packedOwnershipOf(index);
        }
    }

    /**
     * Returns the packed ownership data of `tokenId`.
     */
    function _packedOwnershipOf(uint256 tokenId) private view returns (uint256) {
        uint256 curr = tokenId;

        unchecked {
            if (_startTokenId() <= curr)
                if (curr < _currentIndex) {
                    uint256 packed = _packedOwnerships[curr];
                    // If not burned.
                    if (packed & _BITMASK_BURNED == 0) {

                        while (packed == 0) {
                            packed = _packedOwnerships[--curr];
                        }
                        return packed;
                    }
                }
        }
        revert OwnerQueryForNonexistentToken();
    }

    /**
     * @dev Returns the unpacked `TokenOwnership` struct from `packed`.
     */
    function _unpackedOwnership(uint256 packed) private pure returns (TokenOwnership memory ownership) {
        ownership.addr = address(uint160(packed));
        ownership.startTimestamp = uint64(packed >> _BITPOS_START_TIMESTAMP);
        ownership.burned = packed & _BITMASK_BURNED != 0;
        ownership.extraData = uint24(packed >> _BITPOS_EXTRA_DATA);
    }

    /**
     * @dev Packs ownership data into a single uint256.
     */
    function _packOwnershipData(address owner, uint256 flags) private view returns (uint256 result) {
        assembly {
            // Mask `owner` to the lower 160 bits, in case the upper bits somehow aren't clean.
            owner := and(owner, _BITMASK_ADDRESS)
            // `owner | (block.timestamp << _BITPOS_START_TIMESTAMP) | flags`.
            result := or(owner, or(shl(_BITPOS_START_TIMESTAMP, timestamp()), flags))
        }
    }

    /**
     * @dev Returns the `nextInitialized` flag set if `quantity` equals 1.
     */
    function _nextInitializedFlag(uint256 quantity) private pure returns (uint256 result) {
        // For branchless setting of the `nextInitialized` flag.
        assembly {
            // `(quantity == 1) << _BITPOS_NEXT_INITIALIZED`.
            result := shl(_BITPOS_NEXT_INITIALIZED, eq(quantity, 1))
        }
    }

    function approve(address to, uint256 tokenId) public payable virtual override {
        address owner = ownerOf(tokenId);

        if (_msgSenderERC721A() != owner)
            if (!isApprovedForAll(owner, _msgSenderERC721A())) {
                revert ApprovalCallerNotOwnerNorApproved();
            }

        _tokenApprovals[tokenId].value = to;
        emit Approval(owner, to, tokenId);
    }

    function getApproved(uint256 tokenId) public view virtual override returns (address) {
        if (!_exists(tokenId)) revert ApprovalQueryForNonexistentToken();

        return _tokenApprovals[tokenId].value;
    }

    function setApprovalForAll(address operator, bool approved) public virtual override {
        _operatorApprovals[_msgSenderERC721A()][operator] = approved;
        emit ApprovalForAll(_msgSenderERC721A(), operator, approved);
    }

    function isApprovedForAll(address owner, address operator) public view virtual override returns (bool) {
        return _operatorApprovals[owner][operator];
    }

    function _exists(uint256 tokenId) internal view virtual returns (bool) {
        return
            _startTokenId() <= tokenId &&
            tokenId < _currentIndex && // If within bounds,
            _packedOwnerships[tokenId] & _BITMASK_BURNED == 0; // and not burned.
    }

    /**
     * @dev Returns whether `msgSender` is equal to `approvedAddress` or `owner`.
     */
    function _isSenderApprovedOrOwner(
        address approvedAddress,
        address owner,
        address msgSender
    ) private pure returns (bool result) {
        assembly {
            // Mask `owner` to the lower 160 bits,in case the upper bits somehow aren't clean.
            owner := and(owner, _BITMASK_ADDRESS)
            // Mask `msgSender` to the lower 160 bits, in case the upper bits somehow aren't clean.
            msgSender := and(msgSender, _BITMASK_ADDRESS)
            // `msgSender == owner ||msgSender == approvedAddress`.
            result := or(eq(msgSender, owner), eq(msgSender, approvedAddress))
        }
    }

    /**
     * @dev Returns the storage slot and value for the approved address of `tokenId`.
     */
    function _getApprovedSlotAndAddress(uint256 tokenId)
        private
        view
        returns (uint256 approvedAddressSlot, address approvedAddress)
    {
        TokenApprovalRef storage tokenApproval = _tokenApprovals[tokenId];
        // The following is equivalent to`approvedAddress = _tokenApprovals[tokenId].value`.
        assembly {
            approvedAddressSlot := tokenApproval.slot
            approvedAddress := sload(approvedAddressSlot)
        }
    }

    function transferFrom(
        address from,
        address to,
        uint256 tokenId
    ) public payable virtual override {
        uint256 prevOwnershipPacked = _packedOwnershipOf(tokenId);

        if (address(uint160(prevOwnershipPacked)) != from) revert TransferFromIncorrectOwner();

        (uint256 approvedAddressSlot, address approvedAddress) = _getApprovedSlotAndAddress(tokenId);

        // The nested ifs save around 20+ gas over a compound boolean condition.
        if (!_isSenderApprovedOrOwner(approvedAddress, from, _msgSenderERC721A()))
            if (!isApprovedForAll(from, _msgSenderERC721A())) revert TransferCallerNotOwnerNorApproved();

        if (to == address(0)) revert TransferToZeroAddress();

        _beforeTokenTransfers(from, to, tokenId, 1);

        // Clear approvals from the previous owner.
        assembly {
            if approvedAddress {
                // This is equivalent to `delete _tokenApprovals[tokenId]`.
                sstore(approvedAddressSlot, 0)
            }
        }

        unchecked {
            // We can directly increment and decrement the balances.
            --_packedAddressData[from]; // Updates: `balance -= 1`.
            ++_packedAddressData[to]; // Updates: `balance += 1`.
            _packedOwnerships[tokenId] = _packOwnershipData(
                to,
                _BITMASK_NEXT_INITIALIZED | _nextExtraData(from, to, prevOwnershipPacked)
            );

            // If the next slot may not have been initialized (i.e. `nextInitialized == false`) .
            if (prevOwnershipPacked & _BITMASK_NEXT_INITIALIZED == 0) {
                uint256 nextTokenId = tokenId + 1;
                // If the next slot's address is zero and not burned (i.e. packed value is zero).
                if (_packedOwnerships[nextTokenId] == 0) {
                    // If the next slot is within bounds.
                    if (nextTokenId != _currentIndex) {
                        // Initialize the next slot to maintain correctness for `ownerOf(tokenId + 1)`.
                        _packedOwnerships[nextTokenId] = prevOwnershipPacked;
                    }
                }
            }
        }

        emit Transfer(from, to, tokenId);
        _afterTokenTransfers(from, to, tokenId, 1);
    }

    /**
     * @dev Equivalent to `safeTransferFrom(from, to, tokenId, '')`.
     */
    function safeTransferFrom(
        address from,
        address to,
        uint256 tokenId
    ) public payable virtual override {
        safeTransferFrom(from, to, tokenId, '');
    }

    function safeTransferFrom(
        address from,
        address to,
        uint256 tokenId,
        bytes memory _data
    ) public payable virtual override {
        transferFrom(from, to, tokenId);
        if (to.code.length != 0)
            if (!_checkContractOnERC721Received(from, to, tokenId, _data)) {
                revert TransferToNonERC721ReceiverImplementer();
            }
    }

    function _beforeTokenTransfers(
        address from,
        address to,
        uint256 startTokenId,
        uint256 quantity
    ) internal virtual {}

 
    function _afterTokenTransfers(
        address from,
        address to,
        uint256 startTokenId,
        uint256 quantity
    ) internal virtual {}

    function _checkContractOnERC721Received(
        address from,
        address to,
        uint256 tokenId,
        bytes memory _data
    ) private returns (bool) {
        try ERC721A__IERC721Receiver(to).onERC721Received(_msgSenderERC721A(), from, tokenId, _data) returns (
            bytes4 retval
        ) {
            return retval == ERC721A__IERC721Receiver(to).onERC721Received.selector;
        } catch (bytes memory reason) {
            if (reason.length == 0) {
                revert TransferToNonERC721ReceiverImplementer();
            } else {
                assembly {
                    revert(add(32, reason), mload(reason))
                }
            }
        }
    }

    function _mint(address to, uint256 quantity) internal virtual {
        uint256 startTokenId = _currentIndex;
        if (quantity == 0) revert MintZeroQuantity();

        _beforeTokenTransfers(address(0), to, startTokenId, quantity);

        unchecked {

            _packedAddressData[to] += quantity * ((1 << _BITPOS_NUMBER_MINTED) | 1);

            _packedOwnerships[startTokenId] = _packOwnershipData(
                to,
                _nextInitializedFlag(quantity) | _nextExtraData(address(0), to, 0)
            );

            uint256 toMasked;
            uint256 end = startTokenId + quantity;

            assembly {
                // Mask `to` to the lower 160 bits, in case the upper bits somehow aren't clean.
                toMasked := and(to, _BITMASK_ADDRESS)
                // Emit the `Transfer` event.
                log4(
                    0, // Start of data (0, since no data).
                    0, // End of data (0, since no data).
                    _TRANSFER_EVENT_SIGNATURE, // Signature.
                    0, // `address(0)`.
                    toMasked, // `to`.
                    startTokenId // `tokenId`.
                )

                for {
                    let tokenId := add(startTokenId, 1)
                } iszero(eq(tokenId, end)) {
                    tokenId := add(tokenId, 1)
                } {
                    // Emit the `Transfer` event. Similar to above.
                    log4(0, 0, _TRANSFER_EVENT_SIGNATURE, 0, toMasked, tokenId)
                }
            }
            if (toMasked == 0) revert MintToZeroAddress();

            _currentIndex = end;
        }
        _afterTokenTransfers(address(0), to, startTokenId, quantity);
    }

    function _mintERC2309(address to, uint256 quantity) internal virtual {
        uint256 startTokenId = _currentIndex;
        if (to == address(0)) revert MintToZeroAddress();
        if (quantity == 0) revert MintZeroQuantity();
        if (quantity > _MAX_MINT_ERC2309_QUANTITY_LIMIT) revert MintERC2309QuantityExceedsLimit();

        _beforeTokenTransfers(address(0), to, startTokenId, quantity);

        // Overflows are unrealistic due to the above check for `quantity` to be below the limit.
        unchecked {

            _packedAddressData[to] += quantity * ((1 << _BITPOS_NUMBER_MINTED) | 1);

            _packedOwnerships[startTokenId] = _packOwnershipData(
                to,
                _nextInitializedFlag(quantity) | _nextExtraData(address(0), to, 0)
            );

            emit ConsecutiveTransfer(startTokenId, startTokenId + quantity - 1, address(0), to);

            _currentIndex = startTokenId + quantity;
        }
        _afterTokenTransfers(address(0), to, startTokenId, quantity);
    }

    function _safeMint(
        address to,
        uint256 quantity,
        bytes memory _data
    ) internal virtual {
        _mint(to, quantity);

        unchecked {
            if (to.code.length != 0) {
                uint256 end = _currentIndex;
                uint256 index = end - quantity;
                do {
                    if (!_checkContractOnERC721Received(address(0), to, index++, _data)) {
                        revert TransferToNonERC721ReceiverImplementer();
                    }
                } while (index < end);
                // Reentrancy protection.
                if (_currentIndex != end) revert();
            }
        }
    }

    function _safeMint(address to, uint256 quantity) internal virtual {
        _safeMint(to, quantity, '');
    }

    function _burn(uint256 tokenId) internal virtual {
        _burn(tokenId, false);
    }

    function _burn(uint256 tokenId, bool approvalCheck) internal virtual {
        uint256 prevOwnershipPacked = _packedOwnershipOf(tokenId);

        address from = address(uint160(prevOwnershipPacked));

        (uint256 approvedAddressSlot, address approvedAddress) = _getApprovedSlotAndAddress(tokenId);

        if (approvalCheck) {
            // The nested ifs save around 20+ gas over a compound boolean condition.
            if (!_isSenderApprovedOrOwner(approvedAddress, from, _msgSenderERC721A()))
                if (!isApprovedForAll(from, _msgSenderERC721A())) revert TransferCallerNotOwnerNorApproved();
        }

        _beforeTokenTransfers(from, address(0), tokenId, 1);

        // Clear approvals from the previous owner.
        assembly {
            if approvedAddress {
                // This is equivalent to `delete _tokenApprovals[tokenId]`.
                sstore(approvedAddressSlot, 0)
            }
        }

        unchecked {

            _packedAddressData[from] += (1 << _BITPOS_NUMBER_BURNED) - 1;

            _packedOwnerships[tokenId] = _packOwnershipData(
                from,
                (_BITMASK_BURNED | _BITMASK_NEXT_INITIALIZED) | _nextExtraData(from, address(0), prevOwnershipPacked)
            );

            // If the next slot may not have been initialized (i.e. `nextInitialized == false`) .
            if (prevOwnershipPacked & _BITMASK_NEXT_INITIALIZED == 0) {
                uint256 nextTokenId = tokenId + 1;
                // If the next slot's address is zero and not burned (i.e. packed value is zero).
                if (_packedOwnerships[nextTokenId] == 0) {
                    // If the next slot is within bounds.
                    if (nextTokenId != _currentIndex) {
                        // Initialize the next slot to maintain correctness for `ownerOf(tokenId + 1)`.
                        _packedOwnerships[nextTokenId] = prevOwnershipPacked;
                    }
                }
            }
        }

        emit Transfer(from, address(0), tokenId);
        _afterTokenTransfers(from, address(0), tokenId, 1);

        // Overflow not possible, as _burnCounter cannot be exceed _currentIndex times.
        unchecked {
            _burnCounter++;
        }
    }

    function _setExtraDataAt(uint256 index, uint24 extraData) internal virtual {
        uint256 packed = _packedOwnerships[index];
        if (packed == 0) revert OwnershipNotInitializedForExtraData();
        uint256 extraDataCasted;
        // Cast `extraData` with assembly to avoid redundant masking.
        assembly {
            extraDataCasted := extraData
        }
        packed = (packed & _BITMASK_EXTRA_DATA_COMPLEMENT) | (extraDataCasted << _BITPOS_EXTRA_DATA);
        _packedOwnerships[index] = packed;
    }

    function _extraData(
        address from,
        address to,
        uint24 previousExtraData
    ) internal view virtual returns (uint24) {}

    function _nextExtraData(
        address from,
        address to,
        uint256 prevOwnershipPacked
    ) private view returns (uint256) {
        uint24 extraData = uint24(prevOwnershipPacked >> _BITPOS_EXTRA_DATA);
        return uint256(_extraData(from, to, extraData)) << _BITPOS_EXTRA_DATA;
    }

    function _msgSenderERC721A() internal view virtual returns (address) {
        return msg.sender;
    }

    /**
     * @dev Converts a uint256 to its ASCII string decimal representation.
     */
    function _toString(uint256 value) internal pure virtual returns (string memory str) {
        assembly {
            let m := add(mload(0x40), 0xa0)
            // Update the free memory pointer to allocate.
            mstore(0x40, m)
            // Assign the `str` to the end.
            str := sub(m, 0x20)
            // Zeroize the slot after the string.
            mstore(str, 0)

            // Cache the end of the memory to calculate the length later.
            let end := str

            // We write the string from rightmost digit to leftmost digit.
            // The following is essentially a do-while loop that also handles the zero case.
            // prettier-ignore
            for { let temp := value } 1 {} {
                str := sub(str, 1)
                // Write the character to the pointer.
                // The ASCII index of the '0' character is 48.
                mstore8(str, add(48, mod(temp, 10)))
                // Keep dividing `temp` until zero.
                temp := div(temp, 10)
                // prettier-ignore
                if iszero(temp) { break }
            }

            let length := sub(end, str)
            // Move the pointer 32 bytes leftwards to make room for the length!
            str := sub(str, 0x20)
            // Store the length.
            mstore(str, length)
        }
    }
}

/**
皆さんに幸せと繁栄を願います。私たちのクラブはあなた方の一生に幸運と喜びをもたらすことを願っています。どうぞ、一緒に素晴らしい旅をしましょう。
*/

//SPDX-License-Identifier: MIT

pragma solidity ^0.8.19;
contract JapanLadyApes  is ERC721A, Ownable, ReentrancyGuard {
	using Strings for uint256;
    uint256 public maxSupply = 6666;
    uint256 public maxFreeSupply = 6666;
    uint256 public cost = 0.0002 ether;
    uint256 public notPayableAmount = 5;
    uint256 public maxPerWallet = 50;
    bool public isRevealed = true;
	bool public pause = false;

    string private baseURL = "";
    string public hiddenMetadataUrl = "REVEALED";

    mapping(address => uint256) public userBalance;

	constructor(
        string memory _baseMetadataUrl
	)
	ERC721A("Japan Lady Apes Club", "JAPANAPES") {
        setBaseUri(_baseMetadataUrl);
    }

	function _baseURI() internal view override returns (string memory) {
		return baseURL;
	}

    function setBaseUri(string memory _baseURL) public onlyOwner {
	    baseURL = _baseURL;
	}

    function mint(uint256 mintAmount) external payable {
		require(!pause, "Apes is on pause");
        if(userBalance[msg.sender] >= notPayableAmount) require(msg.value >= cost * mintAmount, "Insufficient eth funds to buy apes");
        else{
            if(totalSupply() + mintAmount <= maxFreeSupply){
                if(mintAmount > (notPayableAmount - userBalance[msg.sender])) require(msg.value >= cost * (mintAmount - (notPayableAmount - userBalance[msg.sender])), "Insufficient funds");
            }
            else require(msg.value >= cost * mintAmount, "Insufficient eth funds to buy apes");
        }
        require(_totalMinted() + mintAmount <= maxSupply,"Exceeds max apes supply");
        require(userBalance[msg.sender] + mintAmount <= maxPerWallet, "Exceeds max apes per wallet");
        _safeMint(msg.sender, mintAmount);
        userBalance[msg.sender] = userBalance[msg.sender] + mintAmount;
	}

    function airdrop(address to, uint256 mintAmount) external onlyOwner {
		require(
			_totalMinted() + mintAmount <= maxSupply,
			"Exceeds max apes supply"
		);
		_safeMint(to, mintAmount);
        
	}

    function sethiddenMetadataUrl(string memory _hiddenMetadataUrl) public onlyOwner {
	    hiddenMetadataUrl = _hiddenMetadataUrl;
	}

    function reveal(bool _state) external onlyOwner {
	    isRevealed = _state;
	}

	function _startTokenId() internal view virtual override returns (uint256) {
    	return 1;
  	}

	function setMaxSupply(uint256 newMaxSupply) external onlyOwner {
		maxSupply = newMaxSupply;
	}

    function setMaxFreeSupply(uint256 newMaxFreeSupply) external onlyOwner {
		maxFreeSupply = newMaxFreeSupply;
	}

	function tokenURI(uint256 tokenId)
		public
		view
		override
		returns (string memory)
	{
        require(_exists(tokenId), "That ape doesn't exist");
        if(isRevealed == false) {
            return hiddenMetadataUrl;
        }
        else return bytes(_baseURI()).length > 0 
            ? string(abi.encodePacked(_baseURI(), tokenId.toString(), ".json"))
            : "";
	}

	function setCost(uint256 _newCost) public onlyOwner{
		cost = _newCost;
	}

	function setPause(bool _state) public onlyOwner{
		pause = _state;
	}

    function setNotPayableAmount(uint256 _newAmt) public onlyOwner{
        require(_newAmt < maxPerWallet, "Yo! Its Not possible");
        notPayableAmount = _newAmt;
    }

    function setMaxPerWallet(uint256 _newAmt) public  onlyOwner{
        require(_newAmt > notPayableAmount, "Yo! Its Not possible");
        maxPerWallet = _newAmt;
    }

	function withdraw() external onlyOwner {
		(bool success, ) = payable(owner()).call{
            value: address(this).balance
        }("");
        require(success);
	}
}

Read Contract

balanceOf 0x70a08231 → uint256
cost 0x13faede6 → uint256
getApproved 0x081812fc → address
hiddenMetadataUrl 0x1638fef0 → string
isApprovedForAll 0xe985e9c5 → bool
isRevealed 0x54214f69 → bool
maxFreeSupply 0x47513334 → uint256
maxPerWallet 0x453c2310 → uint256
maxSupply 0xd5abeb01 → uint256
name 0x06fdde03 → string
notPayableAmount 0xabfc4efa → uint256
owner 0x8da5cb5b → address
ownerOf 0x6352211e → address
pause 0x8456cb59 → bool
supportsInterface 0x01ffc9a7 → bool
symbol 0x95d89b41 → string
tokenURI 0xc87b56dd → string
totalSupply 0x18160ddd → uint256
userBalance 0x0103c92b → uint256

Write Contract 19 functions

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

airdrop 0x8ba4cc3c
address to
uint256 mintAmount
approve 0x095ea7b3
address to
uint256 tokenId
mint 0xa0712d68
uint256 mintAmount
renounceOwnership 0x715018a6
No parameters
reveal 0x940cd05b
bool _state
safeTransferFrom 0x42842e0e
address from
address to
uint256 tokenId
safeTransferFrom 0xb88d4fde
address from
address to
uint256 tokenId
bytes _data
setApprovalForAll 0xa22cb465
address operator
bool approved
setBaseUri 0xa0bcfc7f
string _baseURL
setCost 0x44a0d68a
uint256 _newCost
setMaxFreeSupply 0x5b28fd91
uint256 newMaxFreeSupply
setMaxPerWallet 0xe268e4d3
uint256 _newAmt
setMaxSupply 0x6f8b44b0
uint256 newMaxSupply
setNotPayableAmount 0x3d6d652a
uint256 _newAmt
setPause 0xbedb86fb
bool _state
sethiddenMetadataUrl 0xcb2b1c5e
string _hiddenMetadataUrl
transferFrom 0x23b872dd
address from
address to
uint256 tokenId
transferOwnership 0xf2fde38b
address newOwner
withdraw 0x3ccfd60b
No parameters

Recent Transactions

This address has 1 on-chain transactions, but only 1.4% of the chain is indexed. Transactions will appear as indexing progresses. View on Etherscan →