Address Contract Verified
Address
0xD27fAEb97Af584B55fAA03Ed6AB70632d3B90Aaa
Balance
0 ETH
Nonce
1
Code Size
22733 bytes
Creator
0x2411376F...6C1a at tx 0x6fd43e70...0530a5
Indexed Transactions
0
Contract Bytecode
22733 bytes
0x60806040526004361061027d5760003560e01c8063715018a61161014f578063a22cb465116100c1578063e5e958e11161007a578063e5e958e114610947578063e6e2173014610972578063e985e9c5146109af578063f2fde38b146109ec578063fb79f4ee14610a15578063fbfa77cf14610a405761027d565b8063a22cb46514610839578063b88d4fde14610862578063c87b56dd1461088b578063d9b39a11146108c8578063dab17d7a146108f3578063e0c752841461090a5761027d565b8063853828b611610113578063853828b6146107695780638da5cb5b1461077357806395d89b411461079e5780639727151a146107c9578063a035b1fe146107f2578063a0712d681461081d5761027d565b8063715018a6146106985780637a70f35f146106af5780637e4831d3146106d8578063819b25ba146107035780638462151c1461072c5761027d565b80632e1a7d4d116101f357806355f804b3116101ac57806355f804b3146105975780635b70ea9f146105c05780636352211e146105ca5780636817031b146106075780636c0360eb1461063057806370a082311461065b5761027d565b80632e1a7d4d146104655780632f745c591461048e5780633dc40e2a146104cb57806342842e0e1461050857806342966c68146105315780634f6ccce71461055a5761027d565b806307062df71161024557806307062df714610369578063081812fc14610380578063095ea7b3146103bd5780630b24f435146103e657806318160ddd1461041157806323b872dd1461043c5761027d565b806301ffc9a71461028257806302329a29146102bf57806302d7948e146102e8578063060426bc1461031357806306fdde031461033e575b600080fd5b34801561028e57600080fd5b506102a960048036038101906102a4919061407f565b610a6b565b6040516102b691906150b7565b60405180910390f35b3480156102cb57600080fd5b506102e660048036038101906102e1919061402d565b610ad2565b005b3480156102f457600080fd5b506102fd610b85565b60405161030a919061554f565b60405180910390f35b34801561031f57600080fd5b50610328610b8b565b604051610335919061554f565b60405180910390f35b34801561034a57600080fd5b50610353610b91565b60405161036091906150ed565b60405180910390f35b34801561037557600080fd5b5061037e610c33565b005b34801561038c57600080fd5b506103a760048036038101906103a2919061414e565b610cd4565b6040516103b49190614fea565b60405180910390f35b3480156103c957600080fd5b506103e460048036038101906103df9190613ff1565b610d59565b005b3480156103f257600080fd5b506103fb610e71565b60405161040891906150b7565b60405180910390f35b34801561041d57600080fd5b50610426610e84565b604051610433919061554f565b60405180910390f35b34801561044857600080fd5b50610463600480360381019061045e9190613eeb565b610e95565b005b34801561047157600080fd5b5061048c6004803603810190610487919061414e565b610ef5565b005b34801561049a57600080fd5b506104b560048036038101906104b09190613ff1565b611066565b6040516104c2919061554f565b60405180910390f35b3480156104d757600080fd5b506104f260048036038101906104ed9190613e86565b6110c1565b6040516104ff91906150b7565b60405180910390f35b34801561051457600080fd5b5061052f600480360381019061052a9190613eeb565b6110e1565b005b34801561053d57600080fd5b506105586004803603810190610553919061414e565b611101565b005b34801561056657600080fd5b50610581600480360381019061057c919061414e565b61115d565b60405161058e919061554f565b60405180910390f35b3480156105a357600080fd5b506105be60048036038101906105b9919061410d565b611180565b005b6105c8611208565b005b3480156105d657600080fd5b506105f160048036038101906105ec919061414e565b61158e565b6040516105fe9190614fea565b60405180910390f35b34801561061357600080fd5b5061062e60048036038101906106299190613e86565b6115c5565b005b34801561063c57600080fd5b50610645611685565b60405161065291906150ed565b60405180910390f35b34801561066757600080fd5b50610682600480360381019061067d9190613e86565b611727565b60405161068f919061554f565b60405180910390f35b3480156106a457600080fd5b506106ad6117e6565b005b3480156106bb57600080fd5b506106d660048036038101906106d19190613e86565b611864565b005b3480156106e457600080fd5b506106ed611946565b6040516106fa91906150b7565b60405180910390f35b34801561070f57600080fd5b5061072a6004803603810190610725919061414e565b611959565b005b34801561073857600080fd5b50610753600480360381019061074e9190613e86565b611a6e565b6040516107609190615095565b60405180910390f35b610771611b67565b005b34801561077f57600080fd5b50610788611cd7565b6040516107959190614fea565b60405180910390f35b3480156107aa57600080fd5b506107b3611d01565b6040516107c091906150ed565b60405180910390f35b3480156107d557600080fd5b506107f060048036038101906107eb91906140d1565b611da3565b005b3480156107fe57600080fd5b50610807611f2f565b604051610814919061554f565b60405180910390f35b6108376004803603810190610832919061414e565b611f35565b005b34801561084557600080fd5b50610860600480360381019061085b9190613fb5565b612128565b005b34801561086e57600080fd5b5061088960048036038101906108849190613f3a565b6122a9565b005b34801561089757600080fd5b506108b260048036038101906108ad919061414e565b61230b565b6040516108bf91906150ed565b60405180910390f35b3480156108d457600080fd5b506108dd61248e565b6040516108ea919061554f565b60405180910390f35b3480156108ff57600080fd5b50610908612494565b005b34801561091657600080fd5b50610931600480360381019061092c9190613e86565b612520565b60405161093e91906150b7565b60405180910390f35b34801561095357600080fd5b5061095c61267a565b604051610969919061554f565b60405180910390f35b34801561097e57600080fd5b506109996004803603810190610994919061414e565b612680565b6040516109a691906150d2565b60405180910390f35b3480156109bb57600080fd5b506109d660048036038101906109d19190613eaf565b6126bc565b6040516109e391906150b7565b60405180910390f35b3480156109f857600080fd5b50610a136004803603810190610a0e9190613e86565b612750565b005b348015610a2157600080fd5b50610a2a6128fc565b604051610a37919061554f565b60405180910390f35b348015610a4c57600080fd5b50610a55612902565b604051610a629190614fea565b60405180910390f35b6000806000837bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19167bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916815260200190815260200160002060009054906101000a900460ff169050919050565b610ada612928565b73ffffffffffffffffffffffffffffffffffffffff16610af8611cd7565b73ffffffffffffffffffffffffffffffffffffffff1614610b4e576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610b45906153cf565b60405180910390fd5b80600a60146101000a81548160ff02191690831515021790555080600a60156101000a81548160ff02191690831515021790555050565b600e5481565b600f5481565b606060068054600181600116156101000203166002900480601f016020809104026020016040519081016040528092919081815260200182805460018160011615610100020316600290048015610c295780601f10610bfe57610100808354040283529160200191610c29565b820191906000526020600020905b815481529060010190602001808311610c0c57829003601f168201915b5050505050905090565b610c3b612928565b73ffffffffffffffffffffffffffffffffffffffff16610c59611cd7565b73ffffffffffffffffffffffffffffffffffffffff1614610caf576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610ca6906153cf565b60405180910390fd5b6000600e819055506000600a60156101000a81548160ff021916908315150217905550565b6000610cdf82612930565b610d1e576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610d15906153af565b60405180910390fd5b6004600083815260200190815260200160002060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050919050565b6000610d648261158e565b90508073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff161415610dd5576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610dcc9061544f565b60405180910390fd5b8073ffffffffffffffffffffffffffffffffffffffff16610df4612928565b73ffffffffffffffffffffffffffffffffffffffff161480610e235750610e2281610e1d612928565b6126bc565b5b610e62576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610e59906152cf565b60405180910390fd5b610e6c838361294d565b505050565b600a60159054906101000a900460ff1681565b6000610e906002612a06565b905090565b610ea6610ea0612928565b82612a1b565b610ee5576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610edc906154af565b60405180910390fd5b610ef0838383612af9565b505050565b610efd612928565b73ffffffffffffffffffffffffffffffffffffffff16610f1b611cd7565b73ffffffffffffffffffffffffffffffffffffffff1614610f71576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610f68906153cf565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff16600c60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff161415611003576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610ffa9061534f565b60405180910390fd5b600c60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc829081150290604051600060405180830381858888f1935050505061106357600080fd5b50565b60006110b982600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020612d1090919063ffffffff16565b905092915050565b60106020528060005260406000206000915054906101000a900460ff1681565b6110fc838383604051806020016040528060008152506122a9565b505050565b61111261110c612928565b82612a1b565b611151576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016111489061552f565b60405180910390fd5b61115a81612d2a565b50565b600080611174836002612e6490919063ffffffff16565b50905080915050919050565b611188612928565b73ffffffffffffffffffffffffffffffffffffffff166111a6611cd7565b73ffffffffffffffffffffffffffffffffffffffff16146111fc576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016111f3906153cf565b60405180910390fd5b61120581612e90565b50565b600a60159054906101000a900460ff1615611258576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161124f9061512f565b60405180910390fd5b601060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16156112e5576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016112dc9061520f565b60405180910390fd5b6122b861130360016112f5610e84565b612eaa90919063ffffffff16565b1115611344576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161133b9061542f565b60405180910390fd5b6103e861135d6001600e54612eaa90919063ffffffff16565b111561139e576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016113959061548f565b60405180910390fd5b6000805b600b8054905081101561148c576001600b82815481106113be57fe5b9060005260206000200160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166370a08231336040518263ffffffff1660e01b81526004016114219190615005565b60206040518083038186803b15801561143957600080fd5b505afa15801561144d573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906114719190614177565b1061147f576001915061148c565b80806001019150506113a2565b50806114cd576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016114c49061550f565b60405180910390fd5b600e600081548092919060010191905055506103e8600e541061151c576001600a60156101000a81548160ff0219169083151502179055506000600e81905550600b600061151b9190613c30565b5b6001601060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff021916908315150217905550600061157e610e84565b905061158a3382612eff565b5050565b60006115be8260405180606001604052806029815260200161586f602991396002612f1d9092919063ffffffff16565b9050919050565b6115cd612928565b73ffffffffffffffffffffffffffffffffffffffff166115eb611cd7565b73ffffffffffffffffffffffffffffffffffffffff1614611641576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611638906153cf565b60405180910390fd5b80600c60006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b606060098054600181600116156101000203166002900480601f01602080910402602001604051908101604052809291908181526020018280546001816001161561010002031660029004801561171d5780601f106116f25761010080835404028352916020019161171d565b820191906000526020600020905b81548152906001019060200180831161170057829003601f168201915b5050505050905090565b60008073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff161415611798576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161178f906152ef565b60405180910390fd5b6117df600160008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020612f3c565b9050919050565b6117ee612928565b73ffffffffffffffffffffffffffffffffffffffff1661180c611cd7565b73ffffffffffffffffffffffffffffffffffffffff1614611862576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611859906153cf565b60405180910390fd5b565b61186c612928565b73ffffffffffffffffffffffffffffffffffffffff1661188a611cd7565b73ffffffffffffffffffffffffffffffffffffffff16146118e0576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016118d7906153cf565b60405180910390fd5b600b819080600181540180825580915050600190039060005260206000200160009091909190916101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b600a60149054906101000a900460ff1681565b611961612928565b73ffffffffffffffffffffffffffffffffffffffff1661197f611cd7565b73ffffffffffffffffffffffffffffffffffffffff16146119d5576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016119cc906153cf565b60405180910390fd5b60006119df610e84565b905060586119fd836119ef610e84565b612eaa90919063ffffffff16565b1115611a3e576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611a359061510f565b60405180910390fd5b60005b82811015611a6957611a5c611a54611cd7565b828401612eff565b8080600101915050611a41565b505050565b60606000611a7b83611727565b90506000811415611ad657600067ffffffffffffffff81118015611a9e57600080fd5b50604051908082528060200260200182016040528015611acd5781602001602082028036833780820191505090505b50915050611b62565b60608167ffffffffffffffff81118015611aef57600080fd5b50604051908082528060200260200182016040528015611b1e5781602001602082028036833780820191505090505b50905060005b82811015611b5b57611b368582611066565b828281518110611b4257fe5b6020026020010181815250508080600101915050611b24565b8193505050505b919050565b611b6f612928565b73ffffffffffffffffffffffffffffffffffffffff16611b8d611cd7565b73ffffffffffffffffffffffffffffffffffffffff1614611be3576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611bda906153cf565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff16600c60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff161415611c75576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611c6c9061534f565b60405180910390fd5b600c60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc479081150290604051600060405180830381858888f19350505050611cd557600080fd5b565b6000600a60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b606060078054600181600116156101000203166002900480601f016020809104026020016040519081016040528092919081815260200182805460018160011615610100020316600290048015611d995780601f10611d6e57610100808354040283529160200191611d99565b820191906000526020600020905b815481529060010190602001808311611d7c57829003601f168201915b5050505050905090565b611dab612928565b73ffffffffffffffffffffffffffffffffffffffff16611dc9611cd7565b73ffffffffffffffffffffffffffffffffffffffff1614611e1f576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611e16906153cf565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff16600c60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff161415611e7b57600080fd5b8173ffffffffffffffffffffffffffffffffffffffff1663a9059cbb600c60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16836040518363ffffffff1660e01b8152600401611ed892919061506c565b602060405180830381600087803b158015611ef257600080fd5b505af1158015611f06573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611f2a9190614056565b505050565b600d5481565b600a60149054906101000a900460ff1615611f85576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611f7c906154ef565b60405180910390fd5b600081118015611f96575060038111155b611fd5576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611fcc9061516f565b60405180910390fd5b6122b8611ff282611fe4610e84565b612eaa90919063ffffffff16565b1115612033576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161202a906152af565b60405180910390fd5b6112c061204b82600f54612eaa90919063ffffffff16565b111561208c576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016120839061546f565b60405180910390fd5b6120a181600d54612f5190919063ffffffff16565b3410156120e3576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016120da9061538f565b60405180910390fd5b60005b8181101561212457600f60008154809291906001019190505550600061210a610e84565b90506121163382612eff565b5080806001019150506120e6565b5050565b612130612928565b73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16141561219e576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016121959061524f565b60405180910390fd5b80600560006121ab612928565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055508173ffffffffffffffffffffffffffffffffffffffff16612258612928565b73ffffffffffffffffffffffffffffffffffffffff167f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c318360405161229d91906150b7565b60405180910390a35050565b6122ba6122b4612928565b83612a1b565b6122f9576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016122f0906154af565b60405180910390fd5b61230584848484612fc1565b50505050565b606061231682612930565b612355576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161234c9061540f565b60405180910390fd5b6060600860008481526020019081526020016000208054600181600116156101000203166002900480601f0160208091040260200160405190810160405280929190818152602001828054600181600116156101000203166002900480156123fe5780601f106123d3576101008083540402835291602001916123fe565b820191906000526020600020905b8154815290600101906020018083116123e157829003601f168201915b50505050509050606061240f611685565b9050600081511415612425578192505050612489565b60008251111561245a578082604051602001612442929190614fc6565b60405160208183030381529060405292505050612489565b806124648561301d565b604051602001612475929190614fc6565b604051602081830303815290604052925050505b919050565b6112c081565b61249c612928565b73ffffffffffffffffffffffffffffffffffffffff166124ba611cd7565b73ffffffffffffffffffffffffffffffffffffffff1614612510576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612507906153cf565b60405180910390fd5b600b600061251e9190613c30565b565b60008060009050601060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16156125825780915050612675565b60005b600b8054905081101561266f576001600b82815481106125a157fe5b9060005260206000200160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166370a08231866040518263ffffffff1660e01b81526004016126049190614fea565b60206040518083038186803b15801561261c57600080fd5b505afa158015612630573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906126549190614177565b10612662576001915061266f565b8080600101915050612585565b50809150505b919050565b6103e881565b600b818154811061268d57fe5b906000526020600020016000915054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b6000600560008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16905092915050565b612758612928565b73ffffffffffffffffffffffffffffffffffffffff16612776611cd7565b73ffffffffffffffffffffffffffffffffffffffff16146127cc576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016127c3906153cf565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff16141561283c576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612833906151af565b60405180910390fd5b8073ffffffffffffffffffffffffffffffffffffffff16600a60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a380600a60006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b6122b881565b600c60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b600033905090565b600061294682600261316490919063ffffffff16565b9050919050565b816004600083815260200190815260200160002060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550808273ffffffffffffffffffffffffffffffffffffffff166129c08361158e565b73ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92560405160405180910390a45050565b6000612a148260000161317e565b9050919050565b6000612a2682612930565b612a65576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612a5c9061528f565b60405180910390fd5b6000612a708361158e565b90508073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff161480612adf57508373ffffffffffffffffffffffffffffffffffffffff16612ac784610cd4565b73ffffffffffffffffffffffffffffffffffffffff16145b80612af05750612aef81856126bc565b5b91505092915050565b8273ffffffffffffffffffffffffffffffffffffffff16612b198261158e565b73ffffffffffffffffffffffffffffffffffffffff1614612b6f576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612b66906153ef565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff161415612bdf576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612bd69061522f565b60405180910390fd5b612bea83838361318f565b612bf560008261294d565b612c4681600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002061319490919063ffffffff16565b50612c9881600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206131ae90919063ffffffff16565b50612caf818360026131c89092919063ffffffff16565b50808273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a4505050565b6000612d1f83600001836131fd565b60001c905092915050565b6000612d358261158e565b9050612d438160008461318f565b612d4e60008361294d565b60006008600084815260200190815260200160002080546001816001161561010002031660029004905014612d9d57600860008381526020019081526020016000206000612d9c9190613c51565b5b612dee82600160008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002061319490919063ffffffff16565b50612e0382600261326a90919063ffffffff16565b5081600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a45050565b600080600080612e778660000186613284565b915091508160001c8160001c9350935050509250929050565b8060099080519060200190612ea6929190613c99565b5050565b600080828401905083811015612ef5576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612eec906151ef565b60405180910390fd5b8091505092915050565b612f19828260405180602001604052806000815250613307565b5050565b6000612f30846000018460001b84613362565b60001c90509392505050565b6000612f4a826000016133f3565b9050919050565b600080831415612f645760009050612fbb565b6000828402905082848281612f7557fe5b0414612fb6576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612fad9061536f565b60405180910390fd5b809150505b92915050565b612fcc848484612af9565b612fd884848484613404565b613017576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161300e9061518f565b60405180910390fd5b50505050565b60606000821415613065576040518060400160405280600181526020017f3000000000000000000000000000000000000000000000000000000000000000815250905061315f565b600082905060005b6000821461308f578080600101915050600a828161308757fe5b04915061306d565b60608167ffffffffffffffff811180156130a857600080fd5b506040519080825280601f01601f1916602001820160405280156130db5781602001600182028036833780820191505090505b50905060006001830390508593505b6000841461315757600a84816130fc57fe5b0660300160f81b8282806001900393508151811061311657fe5b60200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a905350600a848161314f57fe5b0493506130ea565b819450505050505b919050565b6000613176836000018360001b613568565b905092915050565b600081600001805490509050919050565b505050565b60006131a6836000018360001b61358b565b905092915050565b60006131c0836000018360001b613673565b905092915050565b60006131f4846000018460001b8473ffffffffffffffffffffffffffffffffffffffff1660001b6136e3565b90509392505050565b600081836000018054905011613248576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161323f9061514f565b60405180910390fd5b82600001828154811061325757fe5b9060005260206000200154905092915050565b600061327c836000018360001b6137bf565b905092915050565b600080828460000180549050116132d0576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016132c79061530f565b60405180910390fd5b60008460000184815481106132e157fe5b906000526020600020906002020190508060000154816001015492509250509250929050565b61331183836138d8565b61331e6000848484613404565b61335d576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016133549061518f565b60405180910390fd5b505050565b600080846001016000858152602001908152602001600020549050600081141583906133c4576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016133bb91906150ed565b60405180910390fd5b508460000160018203815481106133d757fe5b9060005260206000209060020201600101549150509392505050565b600081600001805490509050919050565b60006134258473ffffffffffffffffffffffffffffffffffffffff16613a66565b6134325760019050613560565b60606134f963150b7a0260e01b613447612928565b88878760405160240161345d9493929190615020565b604051602081830303815290604052907bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19166020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff838183161783525050505060405180606001604052806032815260200161583d603291398773ffffffffffffffffffffffffffffffffffffffff16613a799092919063ffffffff16565b905060008180602001905181019061351191906140a8565b905063150b7a0260e01b7bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916817bffffffffffffffffffffffffffffffffffffffffffffffffffffffff191614925050505b949350505050565b600080836001016000848152602001908152602001600020541415905092915050565b6000808360010160008481526020019081526020016000205490506000811461366757600060018203905060006001866000018054905003905060008660000182815481106135d657fe5b90600052602060002001549050808760000184815481106135f357fe5b906000526020600020018190555060018301876001016000838152602001908152602001600020819055508660000180548061362b57fe5b6001900381819060005260206000200160009055905586600101600087815260200190815260200160002060009055600194505050505061366d565b60009150505b92915050565b600061367f8383613a91565b6136d85782600001829080600181540180825580915050600190039060005260206000200160009091909190915055826000018054905083600101600084815260200190815260200160002081905550600190506136dd565b600090505b92915050565b600080846001016000858152602001908152602001600020549050600081141561378a578460000160405180604001604052808681526020018581525090806001815401808255809150506001900390600052602060002090600202016000909190919091506000820151816000015560208201518160010155505084600001805490508560010160008681526020019081526020016000208190555060019150506137b8565b8285600001600183038154811061379d57fe5b90600052602060002090600202016001018190555060009150505b9392505050565b600080836001016000848152602001908152602001600020549050600081146138cc576000600182039050600060018660000180549050039050600086600001828154811061380a57fe5b906000526020600020906002020190508087600001848154811061382a57fe5b906000526020600020906002020160008201548160000155600182015481600101559050506001830187600101600083600001548152602001908152602001600020819055508660000180548061387d57fe5b60019003818190600052602060002090600202016000808201600090556001820160009055505090558660010160008781526020019081526020016000206000905560019450505050506138d2565b60009150505b92915050565b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff161415613948576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161393f9061532f565b60405180910390fd5b61395181612930565b15613991576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401613988906151cf565b60405180910390fd5b61399d6000838361318f565b6139ee81600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206131ae90919063ffffffff16565b50613a05818360026131c89092919063ffffffff16565b50808273ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a45050565b600080823b905060008111915050919050565b6060613a888484600085613ab4565b90509392505050565b600080836001016000848152602001908152602001600020541415905092915050565b606082471015613af9576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401613af09061526f565b60405180910390fd5b613b0285613a66565b613b41576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401613b38906154cf565b60405180910390fd5b600060608673ffffffffffffffffffffffffffffffffffffffff168587604051613b6b9190614faf565b60006040518083038185875af1925050503d8060008114613ba8576040519150601f19603f3d011682016040523d82523d6000602084013e613bad565b606091505b5091509150613bbd828286613bc9565b92505050949350505050565b60608315613bd957829050613c29565b600083511115613bec5782518084602001fd5b816040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401613c2091906150ed565b60405180910390fd5b9392505050565b5080546000825590600052602060002090810190613c4e9190613d19565b50565b50805460018160011615610100020316600290046000825580601f10613c775750613c96565b601f016020900490600052602060002090810190613c959190613d19565b5b50565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f10613cda57805160ff1916838001178555613d08565b82800160010185558215613d08579182015b82811115613d07578251825591602001919060010190613cec565b5b509050613d159190613d19565b5090565b5b80821115613d32576000816000905550600101613d1a565b5090565b600081359050613d45816157c9565b92915050565b600081359050613d5a816157e0565b92915050565b600081519050613d6f816157e0565b92915050565b600081359050613d84816157f7565b92915050565b600081519050613d99816157f7565b92915050565b600082601f830112613db057600080fd5b8135613dc3613dbe8261559b565b61556a565b91508082526020830160208301858383011115613ddf57600080fd5b613dea838284615774565b50505092915050565b600081359050613e028161580e565b92915050565b600082601f830112613e1957600080fd5b8135613e2c613e27826155cb565b61556a565b91508082526020830160208301858383011115613e4857600080fd5b613e53838284615774565b50505092915050565b600081359050613e6b81615825565b92915050565b600081519050613e8081615825565b92915050565b600060208284031215613e9857600080fd5b6000613ea684828501613d36565b91505092915050565b60008060408385031215613ec257600080fd5b6000613ed085828601613d36565b9250506020613ee185828601613d36565b9150509250929050565b600080600060608486031215613f0057600080fd5b6000613f0e86828701613d36565b9350506020613f1f86828701613d36565b9250506040613f3086828701613e5c565b9150509250925092565b60008060008060808587031215613f5057600080fd5b6000613f5e87828801613d36565b9450506020613f6f87828801613d36565b9350506040613f8087828801613e5c565b925050606085013567ffffffffffffffff811115613f9d57600080fd5b613fa987828801613d9f565b91505092959194509250565b60008060408385031215613fc857600080fd5b6000613fd685828601613d36565b9250506020613fe785828601613d4b565b9150509250929050565b6000806040838503121561400457600080fd5b600061401285828601613d36565b925050602061402385828601613e5c565b9150509250929050565b60006020828403121561403f57600080fd5b600061404d84828501613d4b565b91505092915050565b60006020828403121561406857600080fd5b600061407684828501613d60565b91505092915050565b60006020828403121561409157600080fd5b600061409f84828501613d75565b91505092915050565b6000602082840312156140ba57600080fd5b60006140c884828501613d8a565b91505092915050565b600080604083850312156140e457600080fd5b60006140f285828601613df3565b925050602061410385828601613e5c565b9150509250929050565b60006020828403121561411f57600080fd5b600082013567ffffffffffffffff81111561413957600080fd5b61414584828501613e08565b91505092915050565b60006020828403121561416057600080fd5b600061416e84828501613e5c565b91505092915050565b60006020828403121561418957600080fd5b600061419784828501613e71565b91505092915050565b60006141ac8383614f91565b60208301905092915050565b6141c18161571a565b82525050565b6141d081615694565b82525050565b6141df81615682565b82525050565b60006141f08261560b565b6141fa8185615639565b9350614205836155fb565b8060005b8381101561423657815161421d88826141a0565b97506142288361562c565b925050600181019050614209565b5085935050505092915050565b61424c816156a6565b82525050565b600061425d82615616565b614267818561564a565b9350614277818560208601615783565b614280816157b8565b840191505092915050565b600061429682615616565b6142a0818561565b565b93506142b0818560208601615783565b80840191505092915050565b6142c58161572c565b82525050565b60006142d682615621565b6142e08185615666565b93506142f0818560208601615783565b6142f9816157b8565b840191505092915050565b600061430f82615621565b6143198185615677565b9350614329818560208601615783565b80840191505092915050565b6000614342601883615666565b91507f457863656564656420726573657276656420737570706c7900000000000000006000830152602082019050919050565b6000614382601f83615666565b91507f4672656520506172726f7450617373206d696e74696e67207061757365642e006000830152602082019050919050565b60006143c2602283615666565b91507f456e756d657261626c655365743a20696e646578206f7574206f6620626f756e60008301527f64730000000000000000000000000000000000000000000000000000000000006020830152604082019050919050565b6000614428603483615666565b91507f596f752063616e206d696e74206e6f206d6f7265207468616e2033205061727260008301527f6f742050617373657320617420612074696d652e0000000000000000000000006020830152604082019050919050565b600061448e603283615666565b91507f4552433732313a207472616e7366657220746f206e6f6e20455243373231526560008301527f63656976657220696d706c656d656e74657200000000000000000000000000006020830152604082019050919050565b60006144f4602683615666565b91507f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160008301527f64647265737300000000000000000000000000000000000000000000000000006020830152604082019050919050565b600061455a601c83615666565b91507f4552433732313a20746f6b656e20616c7265616479206d696e746564000000006000830152602082019050919050565b600061459a601b83615666565b91507f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006000830152602082019050919050565b60006145da602f83615666565b91507f416464726573732068617320616c726561647920636c61696d6564206120667260008301527f656520706172726f7420706173732e00000000000000000000000000000000006020830152604082019050919050565b6000614640602483615666565b91507f4552433732313a207472616e7366657220746f20746865207a65726f2061646460008301527f72657373000000000000000000000000000000000000000000000000000000006020830152604082019050919050565b60006146a6601983615666565b91507f4552433732313a20617070726f766520746f2063616c6c6572000000000000006000830152602082019050919050565b60006146e6602683615666565b91507f416464726573733a20696e73756666696369656e742062616c616e636520666f60008301527f722063616c6c00000000000000000000000000000000000000000000000000006020830152604082019050919050565b600061474c602c83615666565b91507f4552433732313a206f70657261746f7220717565727920666f72206e6f6e657860008301527f697374656e7420746f6b656e00000000000000000000000000000000000000006020830152604082019050919050565b60006147b2604b83615666565b91507f4e6f7420656e6f75676820506172726f74506173736573206c65667420666f7260008301527f206d696e74696e672c20747279207265647563696e672074686520616d6f756e60208301527f7420796f752077616e742e0000000000000000000000000000000000000000006040830152606082019050919050565b600061483e603883615666565b91507f4552433732313a20617070726f76652063616c6c6572206973206e6f74206f7760008301527f6e6572206e6f7220617070726f76656420666f7220616c6c00000000000000006020830152604082019050919050565b60006148a4602a83615666565b91507f4552433732313a2062616c616e636520717565727920666f7220746865207a6560008301527f726f2061646472657373000000000000000000000000000000000000000000006020830152604082019050919050565b600061490a602283615666565b91507f456e756d657261626c654d61703a20696e646578206f7574206f6620626f756e60008301527f64730000000000000000000000000000000000000000000000000000000000006020830152604082019050919050565b6000614970602083615666565b91507f4552433732313a206d696e7420746f20746865207a65726f20616464726573736000830152602082019050919050565b60006149b0600883615666565b91507f6e6f207661756c740000000000000000000000000000000000000000000000006000830152602082019050919050565b60006149f0602183615666565b91507f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f60008301527f77000000000000000000000000000000000000000000000000000000000000006020830152604082019050919050565b6000614a56602283615666565b91507f45746865722076616c75652073656e74206973206e6f7420737566666963696560008301527f6e740000000000000000000000000000000000000000000000000000000000006020830152604082019050919050565b6000614abc602c83615666565b91507f4552433732313a20617070726f76656420717565727920666f72206e6f6e657860008301527f697374656e7420746f6b656e00000000000000000000000000000000000000006020830152604082019050919050565b6000614b22602083615666565b91507f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726000830152602082019050919050565b6000614b62602983615666565b91507f4552433732313a207472616e73666572206f6620746f6b656e2074686174206960008301527f73206e6f74206f776e00000000000000000000000000000000000000000000006020830152604082019050919050565b6000614bc8602f83615666565b91507f4552433732314d657461646174613a2055524920717565727920666f72206e6f60008301527f6e6578697374656e7420746f6b656e00000000000000000000000000000000006020830152604082019050919050565b6000614c2e602383615666565b91507f4e6f7420656e6f75676820706173736573206c65667420666f72206d696e746960008301527f6e672e00000000000000000000000000000000000000000000000000000000006020830152604082019050919050565b6000614c94602183615666565b91507f4552433732313a20617070726f76616c20746f2063757272656e74206f776e6560008301527f72000000000000000000000000000000000000000000000000000000000000006020830152604082019050919050565b6000614cfa602883615666565b91507f4e6f7420656e6f756768207061696420706173736573206c65667420666f722060008301527f6d696e74696e672e0000000000000000000000000000000000000000000000006020830152604082019050919050565b6000614d60603583615666565b91507f4e6f7420656e6f756768206672656520706173736573206c65667420696e207460008301527f68697320726f756e64206f66206d696e74696e672e00000000000000000000006020830152604082019050919050565b6000614dc6603183615666565b91507f4552433732313a207472616e736665722063616c6c6572206973206e6f74206f60008301527f776e6572206e6f7220617070726f7665640000000000000000000000000000006020830152604082019050919050565b6000614e2c601d83615666565b91507f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006000830152602082019050919050565b6000614e6c601a83615666565b91507f506172726f7450617373206d696e74696e67207061757365642e0000000000006000830152602082019050919050565b6000614eac604183615666565b91507f596f7520646f6e74206f776e20616e79206f662074686520746f6b656e73206e60008301527f656564656420746f20636c61696d2061206672656520506172726f745061737360208301527f2e000000000000000000000000000000000000000000000000000000000000006040830152606082019050919050565b6000614f38603083615666565b91507f4552433732314275726e61626c653a2063616c6c6572206973206e6f74206f7760008301527f6e6572206e6f7220617070726f766564000000000000000000000000000000006020830152604082019050919050565b614f9a81615710565b82525050565b614fa981615710565b82525050565b6000614fbb828461428b565b915081905092915050565b6000614fd28285614304565b9150614fde8284614304565b91508190509392505050565b6000602082019050614fff60008301846141d6565b92915050565b600060208201905061501a60008301846141b8565b92915050565b600060808201905061503560008301876141c7565b61504260208301866141d6565b61504f6040830185614fa0565b81810360608301526150618184614252565b905095945050505050565b600060408201905061508160008301856141d6565b61508e6020830184614fa0565b9392505050565b600060208201905081810360008301526150af81846141e5565b905092915050565b60006020820190506150cc6000830184614243565b92915050565b60006020820190506150e760008301846142bc565b92915050565b6000602082019050818103600083015261510781846142cb565b905092915050565b6000602082019050818103600083015261512881614335565b9050919050565b6000602082019050818103600083015261514881614375565b9050919050565b60006020820190508181036000830152615168816143b5565b9050919050565b600060208201905081810360008301526151888161441b565b9050919050565b600060208201905081810360008301526151a881614481565b9050919050565b600060208201905081810360008301526151c8816144e7565b9050919050565b600060208201905081810360008301526151e88161454d565b9050919050565b600060208201905081810360008301526152088161458d565b9050919050565b60006020820190508181036000830152615228816145cd565b9050919050565b6000602082019050818103600083015261524881614633565b9050919050565b6000602082019050818103600083015261526881614699565b9050919050565b60006020820190508181036000830152615288816146d9565b9050919050565b600060208201905081810360008301526152a88161473f565b9050919050565b600060208201905081810360008301526152c8816147a5565b9050919050565b600060208201905081810360008301526152e881614831565b9050919050565b6000602082019050818103600083015261530881614897565b9050919050565b60006020820190508181036000830152615328816148fd565b9050919050565b6000602082019050818103600083015261534881614963565b9050919050565b60006020820190508181036000830152615368816149a3565b9050919050565b60006020820190508181036000830152615388816149e3565b9050919050565b600060208201905081810360008301526153a881614a49565b9050919050565b600060208201905081810360008301526153c881614aaf565b9050919050565b600060208201905081810360008301526153e881614b15565b9050919050565b6000602082019050818103600083015261540881614b55565b9050919050565b6000602082019050818103600083015261542881614bbb565b9050919050565b6000602082019050818103600083015261544881614c21565b9050919050565b6000602082019050818103600083015261546881614c87565b9050919050565b6000602082019050818103600083015261548881614ced565b9050919050565b600060208201905081810360008301526154a881614d53565b9050919050565b600060208201905081810360008301526154c881614db9565b9050919050565b600060208201905081810360008301526154e881614e1f565b9050919050565b6000602082019050818103600083015261550881614e5f565b9050919050565b6000602082019050818103600083015261552881614e9f565b9050919050565b6000602082019050818103600083015261554881614f2b565b9050919050565b60006020820190506155646000830184614fa0565b92915050565b6000604051905081810181811067ffffffffffffffff82111715615591576155906157b6565b5b8060405250919050565b600067ffffffffffffffff8211156155b6576155b56157b6565b5b601f19601f8301169050602081019050919050565b600067ffffffffffffffff8211156155e6576155e56157b6565b5b601f19601f8301169050602081019050919050565b6000819050602082019050919050565b600081519050919050565b600081519050919050565b600081519050919050565b6000602082019050919050565b600082825260208201905092915050565b600082825260208201905092915050565b600081905092915050565b600082825260208201905092915050565b600081905092915050565b600061568d826156f0565b9050919050565b600061569f826156f0565b9050919050565b60008115159050919050565b60007fffffffff0000000000000000000000000000000000000000000000000000000082169050919050565b60006156e982615682565b9050919050565b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b6000819050919050565b600061572582615750565b9050919050565b60006157378261573e565b9050919050565b6000615749826156f0565b9050919050565b600061575b82615762565b9050919050565b600061576d826156f0565b9050919050565b82818337600083830152505050565b60005b838110156157a1578082015181840152602081019050615786565b838111156157b0576000848401525b50505050565bfe5b6000601f19601f8301169050919050565b6157d281615682565b81146157dd57600080fd5b50565b6157e9816156a6565b81146157f457600080fd5b50565b615800816156b2565b811461580b57600080fd5b50565b615817816156de565b811461582257600080fd5b50565b61582e81615710565b811461583957600080fd5b5056fe4552433732313a207472616e7366657220746f206e6f6e20455243373231526563656976657220696d706c656d656e7465724552433732313a206f776e657220717565727920666f72206e6f6e6578697374656e7420746f6b656ea2646970667358221220c5ddcac30d83fb85d3da79305e5a4a724537b308117f556384eb0fe4e03faff764736f6c63430007030033
Verified Source Code Full Match
Compiler: v0.7.3+commit.9bfce1f6
EVM: istanbul
Optimization: No
IERC721Receiver.sol 21 lines
// SPDX-License-Identifier: MIT
pragma solidity >=0.6.0 <0.8.0;
/**
* @title ERC721 token receiver interface
* @dev Interface for any contract that wants to support safeTransfers
* from ERC721 asset contracts.
*/
interface IERC721Receiver {
/**
* @dev Whenever an {IERC721} `tokenId` token is transferred to this contract via {IERC721-safeTransferFrom}
* by `operator` from `from`, this function is called.
*
* It must return its Solidity selector to confirm the token transfer.
* If any other value is returned or the interface is not implemented by the recipient, the transfer will be reverted.
*
* The selector can be obtained in Solidity with `IERC721.onERC721Received.selector`.
*/
function onERC721Received(address operator, address from, uint256 tokenId, bytes calldata data) external returns (bytes4);
}
SafeMath.sol 214 lines
// SPDX-License-Identifier: MIT
pragma solidity >=0.6.0 <0.8.0;
/**
* @dev Wrappers over Solidity's arithmetic operations with added overflow
* checks.
*
* Arithmetic operations in Solidity wrap on overflow. This can easily result
* in bugs, because programmers usually assume that an overflow raises an
* error, which is the standard behavior in high level programming languages.
* `SafeMath` restores this intuition by reverting the transaction when an
* operation overflows.
*
* Using this library instead of the unchecked operations eliminates an entire
* class of bugs, so it's recommended to use it always.
*/
library SafeMath {
/**
* @dev Returns the addition of two unsigned integers, with an overflow flag.
*
* _Available since v3.4._
*/
function tryAdd(uint256 a, uint256 b) internal pure returns (bool, uint256) {
uint256 c = a + b;
if (c < a) return (false, 0);
return (true, c);
}
/**
* @dev Returns the substraction of two unsigned integers, with an overflow flag.
*
* _Available since v3.4._
*/
function trySub(uint256 a, uint256 b) internal pure returns (bool, uint256) {
if (b > a) return (false, 0);
return (true, a - b);
}
/**
* @dev Returns the multiplication of two unsigned integers, with an overflow flag.
*
* _Available since v3.4._
*/
function tryMul(uint256 a, uint256 b) internal pure returns (bool, uint256) {
// Gas optimization: this is cheaper than requiring 'a' not being zero, but the
// benefit is lost if 'b' is also tested.
// See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522
if (a == 0) return (true, 0);
uint256 c = a * b;
if (c / a != b) return (false, 0);
return (true, c);
}
/**
* @dev Returns the division of two unsigned integers, with a division by zero flag.
*
* _Available since v3.4._
*/
function tryDiv(uint256 a, uint256 b) internal pure returns (bool, uint256) {
if (b == 0) return (false, 0);
return (true, a / b);
}
/**
* @dev Returns the remainder of dividing two unsigned integers, with a division by zero flag.
*
* _Available since v3.4._
*/
function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) {
if (b == 0) return (false, 0);
return (true, a % b);
}
/**
* @dev Returns the addition of two unsigned integers, reverting on
* overflow.
*
* Counterpart to Solidity's `+` operator.
*
* Requirements:
*
* - Addition cannot overflow.
*/
function add(uint256 a, uint256 b) internal pure returns (uint256) {
uint256 c = a + b;
require(c >= a, "SafeMath: addition overflow");
return c;
}
/**
* @dev Returns the subtraction of two unsigned integers, reverting on
* overflow (when the result is negative).
*
* Counterpart to Solidity's `-` operator.
*
* Requirements:
*
* - Subtraction cannot overflow.
*/
function sub(uint256 a, uint256 b) internal pure returns (uint256) {
require(b <= a, "SafeMath: subtraction overflow");
return a - b;
}
/**
* @dev Returns the multiplication of two unsigned integers, reverting on
* overflow.
*
* Counterpart to Solidity's `*` operator.
*
* Requirements:
*
* - Multiplication cannot overflow.
*/
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;
}
/**
* @dev Returns the integer division of two unsigned integers, reverting on
* division by zero. The result is rounded towards zero.
*
* Counterpart to Solidity's `/` operator. Note: this function uses a
* `revert` opcode (which leaves remaining gas untouched) while Solidity
* uses an invalid opcode to revert (consuming all remaining gas).
*
* Requirements:
*
* - The divisor cannot be zero.
*/
function div(uint256 a, uint256 b) internal pure returns (uint256) {
require(b > 0, "SafeMath: division by zero");
return a / b;
}
/**
* @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
* reverting when dividing by zero.
*
* Counterpart to Solidity's `%` operator. This function uses a `revert`
* opcode (which leaves remaining gas untouched) while Solidity uses an
* invalid opcode to revert (consuming all remaining gas).
*
* Requirements:
*
* - The divisor cannot be zero.
*/
function mod(uint256 a, uint256 b) internal pure returns (uint256) {
require(b > 0, "SafeMath: modulo by zero");
return a % b;
}
/**
* @dev Returns the subtraction of two unsigned integers, reverting with custom message on
* overflow (when the result is negative).
*
* CAUTION: This function is deprecated because it requires allocating memory for the error
* message unnecessarily. For custom revert reasons use {trySub}.
*
* Counterpart to Solidity's `-` operator.
*
* Requirements:
*
* - Subtraction cannot overflow.
*/
function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
require(b <= a, errorMessage);
return a - b;
}
/**
* @dev Returns the integer division of two unsigned integers, reverting with custom message on
* division by zero. The result is rounded towards zero.
*
* CAUTION: This function is deprecated because it requires allocating memory for the error
* message unnecessarily. For custom revert reasons use {tryDiv}.
*
* Counterpart to Solidity's `/` operator. Note: this function uses a
* `revert` opcode (which leaves remaining gas untouched) while Solidity
* uses an invalid opcode to revert (consuming all remaining gas).
*
* Requirements:
*
* - The divisor cannot be zero.
*/
function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
require(b > 0, errorMessage);
return a / b;
}
/**
* @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
* reverting with custom message when dividing by zero.
*
* CAUTION: This function is deprecated because it requires allocating memory for the error
* message unnecessarily. For custom revert reasons use {tryMod}.
*
* Counterpart to Solidity's `%` operator. This function uses a `revert`
* opcode (which leaves remaining gas untouched) while Solidity uses an
* invalid opcode to revert (consuming all remaining gas).
*
* Requirements:
*
* - The divisor cannot be zero.
*/
function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
require(b > 0, errorMessage);
return a % b;
}
}
EnumerableSet.sol 297 lines
// SPDX-License-Identifier: MIT
pragma solidity >=0.6.0 <0.8.0;
/**
* @dev Library for managing
* https://en.wikipedia.org/wiki/Set_(abstract_data_type)[sets] of primitive
* types.
*
* Sets have the following properties:
*
* - Elements are added, removed, and checked for existence in constant time
* (O(1)).
* - Elements are enumerated in O(n). No guarantees are made on the ordering.
*
* ```
* contract Example {
* // Add the library methods
* using EnumerableSet for EnumerableSet.AddressSet;
*
* // Declare a set state variable
* EnumerableSet.AddressSet private mySet;
* }
* ```
*
* As of v3.3.0, sets of type `bytes32` (`Bytes32Set`), `address` (`AddressSet`)
* and `uint256` (`UintSet`) are supported.
*/
library EnumerableSet {
// To implement this library for multiple types with as little code
// repetition as possible, we write it in terms of a generic Set type with
// bytes32 values.
// The Set implementation uses private functions, and user-facing
// implementations (such as AddressSet) are just wrappers around the
// underlying Set.
// This means that we can only create new EnumerableSets for types that fit
// in bytes32.
struct Set {
// Storage of set values
bytes32[] _values;
// Position of the value in the `values` array, plus 1 because index 0
// means a value is not in the set.
mapping (bytes32 => uint256) _indexes;
}
/**
* @dev Add a value to a set. O(1).
*
* Returns true if the value was added to the set, that is if it was not
* already present.
*/
function _add(Set storage set, bytes32 value) private returns (bool) {
if (!_contains(set, value)) {
set._values.push(value);
// The value is stored at length-1, but we add 1 to all indexes
// and use 0 as a sentinel value
set._indexes[value] = set._values.length;
return true;
} else {
return false;
}
}
/**
* @dev Removes a value from a set. O(1).
*
* Returns true if the value was removed from the set, that is if it was
* present.
*/
function _remove(Set storage set, bytes32 value) private returns (bool) {
// We read and store the value's index to prevent multiple reads from the same storage slot
uint256 valueIndex = set._indexes[value];
if (valueIndex != 0) { // Equivalent to contains(set, value)
// To delete an element from the _values array in O(1), we swap the element to delete with the last one in
// the array, and then remove the last element (sometimes called as 'swap and pop').
// This modifies the order of the array, as noted in {at}.
uint256 toDeleteIndex = valueIndex - 1;
uint256 lastIndex = set._values.length - 1;
// When the value to delete is the last one, the swap operation is unnecessary. However, since this occurs
// so rarely, we still do the swap anyway to avoid the gas cost of adding an 'if' statement.
bytes32 lastvalue = set._values[lastIndex];
// Move the last value to the index where the value to delete is
set._values[toDeleteIndex] = lastvalue;
// Update the index for the moved value
set._indexes[lastvalue] = toDeleteIndex + 1; // All indexes are 1-based
// Delete the slot where the moved value was stored
set._values.pop();
// Delete the index for the deleted slot
delete set._indexes[value];
return true;
} else {
return false;
}
}
/**
* @dev Returns true if the value is in the set. O(1).
*/
function _contains(Set storage set, bytes32 value) private view returns (bool) {
return set._indexes[value] != 0;
}
/**
* @dev Returns the number of values on the set. O(1).
*/
function _length(Set storage set) private view returns (uint256) {
return set._values.length;
}
/**
* @dev Returns the value stored at position `index` in the set. O(1).
*
* Note that there are no guarantees on the ordering of values inside the
* array, and it may change when more values are added or removed.
*
* Requirements:
*
* - `index` must be strictly less than {length}.
*/
function _at(Set storage set, uint256 index) private view returns (bytes32) {
require(set._values.length > index, "EnumerableSet: index out of bounds");
return set._values[index];
}
// Bytes32Set
struct Bytes32Set {
Set _inner;
}
/**
* @dev Add a value to a set. O(1).
*
* Returns true if the value was added to the set, that is if it was not
* already present.
*/
function add(Bytes32Set storage set, bytes32 value) internal returns (bool) {
return _add(set._inner, value);
}
/**
* @dev Removes a value from a set. O(1).
*
* Returns true if the value was removed from the set, that is if it was
* present.
*/
function remove(Bytes32Set storage set, bytes32 value) internal returns (bool) {
return _remove(set._inner, value);
}
/**
* @dev Returns true if the value is in the set. O(1).
*/
function contains(Bytes32Set storage set, bytes32 value) internal view returns (bool) {
return _contains(set._inner, value);
}
/**
* @dev Returns the number of values in the set. O(1).
*/
function length(Bytes32Set storage set) internal view returns (uint256) {
return _length(set._inner);
}
/**
* @dev Returns the value stored at position `index` in the set. O(1).
*
* Note that there are no guarantees on the ordering of values inside the
* array, and it may change when more values are added or removed.
*
* Requirements:
*
* - `index` must be strictly less than {length}.
*/
function at(Bytes32Set storage set, uint256 index) internal view returns (bytes32) {
return _at(set._inner, index);
}
// AddressSet
struct AddressSet {
Set _inner;
}
/**
* @dev Add a value to a set. O(1).
*
* Returns true if the value was added to the set, that is if it was not
* already present.
*/
function add(AddressSet storage set, address value) internal returns (bool) {
return _add(set._inner, bytes32(uint256(uint160(value))));
}
/**
* @dev Removes a value from a set. O(1).
*
* Returns true if the value was removed from the set, that is if it was
* present.
*/
function remove(AddressSet storage set, address value) internal returns (bool) {
return _remove(set._inner, bytes32(uint256(uint160(value))));
}
/**
* @dev Returns true if the value is in the set. O(1).
*/
function contains(AddressSet storage set, address value) internal view returns (bool) {
return _contains(set._inner, bytes32(uint256(uint160(value))));
}
/**
* @dev Returns the number of values in the set. O(1).
*/
function length(AddressSet storage set) internal view returns (uint256) {
return _length(set._inner);
}
/**
* @dev Returns the value stored at position `index` in the set. O(1).
*
* Note that there are no guarantees on the ordering of values inside the
* array, and it may change when more values are added or removed.
*
* Requirements:
*
* - `index` must be strictly less than {length}.
*/
function at(AddressSet storage set, uint256 index) internal view returns (address) {
return address(uint160(uint256(_at(set._inner, index))));
}
// UintSet
struct UintSet {
Set _inner;
}
/**
* @dev Add a value to a set. O(1).
*
* Returns true if the value was added to the set, that is if it was not
* already present.
*/
function add(UintSet storage set, uint256 value) internal returns (bool) {
return _add(set._inner, bytes32(value));
}
/**
* @dev Removes a value from a set. O(1).
*
* Returns true if the value was removed from the set, that is if it was
* present.
*/
function remove(UintSet storage set, uint256 value) internal returns (bool) {
return _remove(set._inner, bytes32(value));
}
/**
* @dev Returns true if the value is in the set. O(1).
*/
function contains(UintSet storage set, uint256 value) internal view returns (bool) {
return _contains(set._inner, bytes32(value));
}
/**
* @dev Returns the number of values on the set. O(1).
*/
function length(UintSet storage set) internal view returns (uint256) {
return _length(set._inner);
}
/**
* @dev Returns the value stored at position `index` in the set. O(1).
*
* Note that there are no guarantees on the ordering of values inside the
* array, and it may change when more values are added or removed.
*
* Requirements:
*
* - `index` must be strictly less than {length}.
*/
function at(UintSet storage set, uint256 index) internal view returns (uint256) {
return uint256(_at(set._inner, index));
}
}
Context.sol 24 lines
// SPDX-License-Identifier: MIT
pragma solidity >=0.6.0 <0.8.0;
/*
* @dev Provides information about the current execution context, including the
* sender of the transaction and its data. While these are generally available
* via msg.sender and msg.data, they should not be accessed in such a direct
* manner, since when dealing with GSN meta-transactions the account sending and
* paying for execution may not be the actual sender (as far as an application
* is concerned).
*
* This contract is only required for intermediate, library-like contracts.
*/
abstract contract Context {
function _msgSender() internal view virtual returns (address payable) {
return msg.sender;
}
function _msgData() internal view virtual returns (bytes memory) {
this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691
return msg.data;
}
}
EnumerableMap.sol 266 lines
// SPDX-License-Identifier: MIT
pragma solidity >=0.6.0 <0.8.0;
/**
* @dev Library for managing an enumerable variant of Solidity's
* https://solidity.readthedocs.io/en/latest/types.html#mapping-types[`mapping`]
* type.
*
* Maps have the following properties:
*
* - Entries are added, removed, and checked for existence in constant time
* (O(1)).
* - Entries are enumerated in O(n). No guarantees are made on the ordering.
*
* ```
* contract Example {
* // Add the library methods
* using EnumerableMap for EnumerableMap.UintToAddressMap;
*
* // Declare a set state variable
* EnumerableMap.UintToAddressMap private myMap;
* }
* ```
*
* As of v3.0.0, only maps of type `uint256 -> address` (`UintToAddressMap`) are
* supported.
*/
library EnumerableMap {
// To implement this library for multiple types with as little code
// repetition as possible, we write it in terms of a generic Map type with
// bytes32 keys and values.
// The Map implementation uses private functions, and user-facing
// implementations (such as Uint256ToAddressMap) are just wrappers around
// the underlying Map.
// This means that we can only create new EnumerableMaps for types that fit
// in bytes32.
struct MapEntry {
bytes32 _key;
bytes32 _value;
}
struct Map {
// Storage of map keys and values
MapEntry[] _entries;
// Position of the entry defined by a key in the `entries` array, plus 1
// because index 0 means a key is not in the map.
mapping (bytes32 => uint256) _indexes;
}
/**
* @dev Adds a key-value pair to a map, or updates the value for an existing
* key. O(1).
*
* Returns true if the key was added to the map, that is if it was not
* already present.
*/
function _set(Map storage map, bytes32 key, bytes32 value) private returns (bool) {
// We read and store the key's index to prevent multiple reads from the same storage slot
uint256 keyIndex = map._indexes[key];
if (keyIndex == 0) { // Equivalent to !contains(map, key)
map._entries.push(MapEntry({ _key: key, _value: value }));
// The entry is stored at length-1, but we add 1 to all indexes
// and use 0 as a sentinel value
map._indexes[key] = map._entries.length;
return true;
} else {
map._entries[keyIndex - 1]._value = value;
return false;
}
}
/**
* @dev Removes a key-value pair from a map. O(1).
*
* Returns true if the key was removed from the map, that is if it was present.
*/
function _remove(Map storage map, bytes32 key) private returns (bool) {
// We read and store the key's index to prevent multiple reads from the same storage slot
uint256 keyIndex = map._indexes[key];
if (keyIndex != 0) { // Equivalent to contains(map, key)
// To delete a key-value pair from the _entries array in O(1), we swap the entry to delete with the last one
// in the array, and then remove the last entry (sometimes called as 'swap and pop').
// This modifies the order of the array, as noted in {at}.
uint256 toDeleteIndex = keyIndex - 1;
uint256 lastIndex = map._entries.length - 1;
// When the entry to delete is the last one, the swap operation is unnecessary. However, since this occurs
// so rarely, we still do the swap anyway to avoid the gas cost of adding an 'if' statement.
MapEntry storage lastEntry = map._entries[lastIndex];
// Move the last entry to the index where the entry to delete is
map._entries[toDeleteIndex] = lastEntry;
// Update the index for the moved entry
map._indexes[lastEntry._key] = toDeleteIndex + 1; // All indexes are 1-based
// Delete the slot where the moved entry was stored
map._entries.pop();
// Delete the index for the deleted slot
delete map._indexes[key];
return true;
} else {
return false;
}
}
/**
* @dev Returns true if the key is in the map. O(1).
*/
function _contains(Map storage map, bytes32 key) private view returns (bool) {
return map._indexes[key] != 0;
}
/**
* @dev Returns the number of key-value pairs in the map. O(1).
*/
function _length(Map storage map) private view returns (uint256) {
return map._entries.length;
}
/**
* @dev Returns the key-value pair stored at position `index` in the map. O(1).
*
* Note that there are no guarantees on the ordering of entries inside the
* array, and it may change when more entries are added or removed.
*
* Requirements:
*
* - `index` must be strictly less than {length}.
*/
function _at(Map storage map, uint256 index) private view returns (bytes32, bytes32) {
require(map._entries.length > index, "EnumerableMap: index out of bounds");
MapEntry storage entry = map._entries[index];
return (entry._key, entry._value);
}
/**
* @dev Tries to returns the value associated with `key`. O(1).
* Does not revert if `key` is not in the map.
*/
function _tryGet(Map storage map, bytes32 key) private view returns (bool, bytes32) {
uint256 keyIndex = map._indexes[key];
if (keyIndex == 0) return (false, 0); // Equivalent to contains(map, key)
return (true, map._entries[keyIndex - 1]._value); // All indexes are 1-based
}
/**
* @dev Returns the value associated with `key`. O(1).
*
* Requirements:
*
* - `key` must be in the map.
*/
function _get(Map storage map, bytes32 key) private view returns (bytes32) {
uint256 keyIndex = map._indexes[key];
require(keyIndex != 0, "EnumerableMap: nonexistent key"); // Equivalent to contains(map, key)
return map._entries[keyIndex - 1]._value; // All indexes are 1-based
}
/**
* @dev Same as {_get}, with a custom error message when `key` is not in the map.
*
* CAUTION: This function is deprecated because it requires allocating memory for the error
* message unnecessarily. For custom revert reasons use {_tryGet}.
*/
function _get(Map storage map, bytes32 key, string memory errorMessage) private view returns (bytes32) {
uint256 keyIndex = map._indexes[key];
require(keyIndex != 0, errorMessage); // Equivalent to contains(map, key)
return map._entries[keyIndex - 1]._value; // All indexes are 1-based
}
// UintToAddressMap
struct UintToAddressMap {
Map _inner;
}
/**
* @dev Adds a key-value pair to a map, or updates the value for an existing
* key. O(1).
*
* Returns true if the key was added to the map, that is if it was not
* already present.
*/
function set(UintToAddressMap storage map, uint256 key, address value) internal returns (bool) {
return _set(map._inner, bytes32(key), bytes32(uint256(uint160(value))));
}
/**
* @dev Removes a value from a set. O(1).
*
* Returns true if the key was removed from the map, that is if it was present.
*/
function remove(UintToAddressMap storage map, uint256 key) internal returns (bool) {
return _remove(map._inner, bytes32(key));
}
/**
* @dev Returns true if the key is in the map. O(1).
*/
function contains(UintToAddressMap storage map, uint256 key) internal view returns (bool) {
return _contains(map._inner, bytes32(key));
}
/**
* @dev Returns the number of elements in the map. O(1).
*/
function length(UintToAddressMap storage map) internal view returns (uint256) {
return _length(map._inner);
}
/**
* @dev Returns the element stored at position `index` in the set. O(1).
* Note that there are no guarantees on the ordering of values inside the
* array, and it may change when more values are added or removed.
*
* Requirements:
*
* - `index` must be strictly less than {length}.
*/
function at(UintToAddressMap storage map, uint256 index) internal view returns (uint256, address) {
(bytes32 key, bytes32 value) = _at(map._inner, index);
return (uint256(key), address(uint160(uint256(value))));
}
/**
* @dev Tries to returns the value associated with `key`. O(1).
* Does not revert if `key` is not in the map.
*
* _Available since v3.4._
*/
function tryGet(UintToAddressMap storage map, uint256 key) internal view returns (bool, address) {
(bool success, bytes32 value) = _tryGet(map._inner, bytes32(key));
return (success, address(uint160(uint256(value))));
}
/**
* @dev Returns the value associated with `key`. O(1).
*
* Requirements:
*
* - `key` must be in the map.
*/
function get(UintToAddressMap storage map, uint256 key) internal view returns (address) {
return address(uint160(uint256(_get(map._inner, bytes32(key)))));
}
/**
* @dev Same as {get}, with a custom error message when `key` is not in the map.
*
* CAUTION: This function is deprecated because it requires allocating memory for the error
* message unnecessarily. For custom revert reasons use {tryGet}.
*/
function get(UintToAddressMap storage map, uint256 key, string memory errorMessage) internal view returns (address) {
return address(uint160(uint256(_get(map._inner, bytes32(key), errorMessage))));
}
}
ParrotPass.sol 198 lines
// Parrot Passes
//
// 8888 Parrot Pass NFTs
// https://www.parrotpasses.com
//
//
// SPDX-License-Identifier: MIT
pragma solidity ^0.7.3;
pragma experimental ABIEncoderV2;
import '@openzeppelin/contracts/token/ERC721/ERC721Burnable.sol';
import '@openzeppelin/contracts/access/Ownable.sol';
import '@openzeppelin/contracts/token/ERC20/IERC20.sol';
contract ParrotPass is ERC721Burnable, Ownable {
using SafeMath for uint256;
using SafeMath for uint8;
uint256 public constant MAX_PARROT_PASSES = 8888;
uint256 public constant MAX_FREE_PASSES_PER_ROUND = 1000;
uint256 public constant MAX_PAID_MINT = 4800;
bool public mintPaused = true;
bool public freeMintPaused = true;
IERC721[] public currentFreeMintTokens;
address public vault;
uint256 public price = 2 * 10**16; //0.02 ETH;
uint256 public freePassesMinted = 0;
uint256 public paidPassesMinted = 0;
mapping (address => bool) public claimedFreePass;
constructor(string memory name, string memory symbol)
ERC721(name, symbol)
{}
function mint(uint256 numPasses) public payable {
require(!mintPaused, 'ParrotPass minting paused.');
require(
numPasses > 0 && numPasses <= 3,
'You can mint no more than 3 Parrot Passes at a time.'
);
require(
totalSupply().add(numPasses) <= MAX_PARROT_PASSES,
'Not enough ParrotPasses left for minting, try reducing the amount you want.'
);
require(
paidPassesMinted.add(numPasses) <= MAX_PAID_MINT,
'Not enough paid passes left for minting.'
);
require(
msg.value >= price.mul(numPasses),
'Ether value sent is not sufficient'
);
for (uint256 i = 0; i < numPasses; i++) {
paidPassesMinted++;
uint256 mintIndex = totalSupply();
_safeMint(msg.sender, mintIndex);
}
}
// one free token per wallet
function freeMint() public payable {
require(!freeMintPaused, 'Free ParrotPass minting paused.');
require(!claimedFreePass[msg.sender], 'Address has already claimed a free parrot pass.');
require(
totalSupply().add(1) <= MAX_PARROT_PASSES,
'Not enough passes left for minting.'
);
require(
freePassesMinted.add(1) <= MAX_FREE_PASSES_PER_ROUND,
'Not enough free passes left in this round of minting.'
);
bool walletHasFreeMintToken = false;
for (uint256 i=0; i<currentFreeMintTokens.length; i++) {
if (currentFreeMintTokens[i].balanceOf(msg.sender) >= 1) {
walletHasFreeMintToken = true;
break;
}
}
require(
walletHasFreeMintToken,
'You dont own any of the tokens needed to claim a free ParrotPass.'
);
freePassesMinted++;
if (freePassesMinted >= MAX_FREE_PASSES_PER_ROUND) {
freeMintPaused = true;
freePassesMinted = 0;
delete currentFreeMintTokens;
}
claimedFreePass[msg.sender] = true;
uint256 mintIndex = totalSupply();
_safeMint(msg.sender, mintIndex);
}
function tokensOfOwner(address _owner)
external
view
returns (uint256[] memory)
{
uint256 tokenCount = balanceOf(_owner);
if (tokenCount == 0) {
// Return an empty array
return new uint256[](0);
} else {
uint256[] memory result = new uint256[](tokenCount);
uint256 index;
for (index = 0; index < tokenCount; index++) {
result[index] = tokenOfOwnerByIndex(_owner, index);
}
return result;
}
}
function walletCanFreeMint(address _wallet)
external
view
returns (bool canFreeMint)
{
bool canMint = false;
if (claimedFreePass[_wallet]) {
return canMint;
}
for (uint256 i=0; i<currentFreeMintTokens.length; i++) {
if (currentFreeMintTokens[i].balanceOf(_wallet) >= 1) {
canMint = true;
break;
}
}
return canMint;
}
/*
* Only the owner can do these things
*/
function setBaseURI(string memory _newBaseURI) public onlyOwner {
_setBaseURI(_newBaseURI);
}
function addFreeMintToken(address _newTokenAddress) public onlyOwner {
currentFreeMintTokens.push(IERC721(_newTokenAddress));
}
function clearFreeMintTokens() public onlyOwner {
delete currentFreeMintTokens;
}
function pause(bool val) public onlyOwner {
mintPaused = val;
freeMintPaused = val;
}
function startNextFreeMintingRound() public onlyOwner {
freePassesMinted = 0;
freeMintPaused = false;
}
function setVault(address _newVaultAddress) public onlyOwner {
vault = _newVaultAddress;
}
function withdraw(uint256 _amount) public onlyOwner {
require(address(vault) != address(0), 'no vault');
require(payable(vault).send(_amount));
}
function withdrawAll() public payable onlyOwner {
require(address(vault) != address(0), 'no vault');
require(payable(vault).send(address(this).balance));
}
function forwardERC20s(IERC20 _token, uint256 _amount) public onlyOwner {
require(address(vault) != address(0));
_token.transfer(vault, _amount);
}
function reserve(uint256 _numPasses) public onlyOwner {
uint256 currentSupply = totalSupply();
require(
totalSupply().add(_numPasses) <= 88,
'Exceeded reserved supply'
);
uint256 index;
for (index = 0; index < _numPasses; index++) {
_safeMint(owner(), currentSupply + index);
}
}
function renounceOwnership() public override onlyOwner {}
}
IERC20.sol 77 lines
// SPDX-License-Identifier: MIT
pragma solidity >=0.6.0 <0.8.0;
/**
* @dev Interface of the ERC20 standard as defined in the EIP.
*/
interface IERC20 {
/**
* @dev Returns the amount of tokens in existence.
*/
function totalSupply() external view returns (uint256);
/**
* @dev Returns the amount of tokens owned by `account`.
*/
function balanceOf(address account) external view returns (uint256);
/**
* @dev Moves `amount` tokens from the caller's account to `recipient`.
*
* Returns a boolean value indicating whether the operation succeeded.
*
* Emits a {Transfer} event.
*/
function transfer(address recipient, uint256 amount) external returns (bool);
/**
* @dev Returns the remaining number of tokens that `spender` will be
* allowed to spend on behalf of `owner` through {transferFrom}. This is
* zero by default.
*
* This value changes when {approve} or {transferFrom} are called.
*/
function allowance(address owner, address spender) external view returns (uint256);
/**
* @dev Sets `amount` as the allowance of `spender` over the caller's tokens.
*
* Returns a boolean value indicating whether the operation succeeded.
*
* IMPORTANT: Beware that changing an allowance with this method brings the risk
* that someone may use both the old and the new allowance by unfortunate
* transaction ordering. One possible solution to mitigate this race
* condition is to first reduce the spender's allowance to 0 and set the
* desired value afterwards:
* https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
*
* Emits an {Approval} event.
*/
function approve(address spender, uint256 amount) external returns (bool);
/**
* @dev Moves `amount` tokens from `sender` to `recipient` using the
* allowance mechanism. `amount` is then deducted from the caller's
* allowance.
*
* Returns a boolean value indicating whether the operation succeeded.
*
* Emits a {Transfer} event.
*/
function transferFrom(address sender, address recipient, uint256 amount) external returns (bool);
/**
* @dev Emitted when `value` tokens are moved from one account (`from`) to
* another (`to`).
*
* Note that `value` may be zero.
*/
event Transfer(address indexed from, address indexed to, uint256 value);
/**
* @dev Emitted when the allowance of a `spender` for an `owner` is set by
* a call to {approve}. `value` is the new allowance.
*/
event Approval(address indexed owner, address indexed spender, uint256 value);
}
IERC721Enumerable.sol 29 lines
// SPDX-License-Identifier: MIT
pragma solidity >=0.6.2 <0.8.0;
import "./IERC721.sol";
/**
* @title ERC-721 Non-Fungible Token Standard, optional enumeration extension
* @dev See https://eips.ethereum.org/EIPS/eip-721
*/
interface IERC721Enumerable is IERC721 {
/**
* @dev Returns the total amount of tokens stored by the contract.
*/
function totalSupply() external view returns (uint256);
/**
* @dev Returns a token ID owned by `owner` at a given `index` of its token list.
* Use along with {balanceOf} to enumerate all of ``owner``'s tokens.
*/
function tokenOfOwnerByIndex(address owner, uint256 index) external view returns (uint256 tokenId);
/**
* @dev Returns a token ID at a given `index` of all the tokens stored by the contract.
* Use along with {totalSupply} to enumerate all tokens.
*/
function tokenByIndex(uint256 index) external view returns (uint256);
}
Strings.sol 34 lines
// SPDX-License-Identifier: MIT
pragma solidity >=0.6.0 <0.8.0;
/**
* @dev String operations.
*/
library Strings {
/**
* @dev Converts a `uint256` to its ASCII `string` representation.
*/
function toString(uint256 value) internal pure returns (string memory) {
// Inspired by OraclizeAPI's implementation - MIT licence
// https://github.com/oraclize/ethereum-api/blob/b42146b063c7d6ee1358846c198246239e9360e8/oraclizeAPI_0.4.25.sol
if (value == 0) {
return "0";
}
uint256 temp = value;
uint256 digits;
while (temp != 0) {
digits++;
temp /= 10;
}
bytes memory buffer = new bytes(digits);
uint256 index = digits - 1;
temp = value;
while (temp != 0) {
buffer[index--] = bytes1(uint8(48 + temp % 10));
temp /= 10;
}
return string(buffer);
}
}
IERC165.sol 24 lines
// SPDX-License-Identifier: MIT
pragma solidity >=0.6.0 <0.8.0;
/**
* @dev Interface of the ERC165 standard, as defined in the
* https://eips.ethereum.org/EIPS/eip-165[EIP].
*
* Implementers can declare support of contract interfaces, which can then be
* queried by others ({ERC165Checker}).
*
* For an implementation, see {ERC165}.
*/
interface IERC165 {
/**
* @dev Returns true if this contract implements the interface defined by
* `interfaceId`. See the corresponding
* https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]
* to learn more about how these ids are created.
*
* This function call must use less than 30 000 gas.
*/
function supportsInterface(bytes4 interfaceId) external view returns (bool);
}
Address.sol 189 lines
// SPDX-License-Identifier: MIT
pragma solidity >=0.6.2 <0.8.0;
/**
* @dev Collection of functions related to the address type
*/
library Address {
/**
* @dev Returns true if `account` is a contract.
*
* [IMPORTANT]
* ====
* It is unsafe to assume that an address for which this function returns
* false is an externally-owned account (EOA) and not a contract.
*
* Among others, `isContract` will return false for the following
* types of addresses:
*
* - an externally-owned account
* - a contract in construction
* - an address where a contract will be created
* - an address where a contract lived, but was destroyed
* ====
*/
function isContract(address account) internal view returns (bool) {
// This method relies on extcodesize, which returns 0 for contracts in
// construction, since the code is only stored at the end of the
// constructor execution.
uint256 size;
// solhint-disable-next-line no-inline-assembly
assembly { size := extcodesize(account) }
return size > 0;
}
/**
* @dev Replacement for Solidity's `transfer`: sends `amount` wei to
* `recipient`, forwarding all available gas and reverting on errors.
*
* https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost
* of certain opcodes, possibly making contracts go over the 2300 gas limit
* imposed by `transfer`, making them unable to receive funds via
* `transfer`. {sendValue} removes this limitation.
*
* https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].
*
* IMPORTANT: because control is transferred to `recipient`, care must be
* taken to not create reentrancy vulnerabilities. Consider using
* {ReentrancyGuard} or the
* https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].
*/
function sendValue(address payable recipient, uint256 amount) internal {
require(address(this).balance >= amount, "Address: insufficient balance");
// solhint-disable-next-line avoid-low-level-calls, avoid-call-value
(bool success, ) = recipient.call{ value: amount }("");
require(success, "Address: unable to send value, recipient may have reverted");
}
/**
* @dev Performs a Solidity function call using a low level `call`. A
* plain`call` is an unsafe replacement for a function call: use this
* function instead.
*
* If `target` reverts with a revert reason, it is bubbled up by this
* function (like regular Solidity function calls).
*
* Returns the raw returned data. To convert to the expected return value,
* use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].
*
* Requirements:
*
* - `target` must be a contract.
* - calling `target` with `data` must not revert.
*
* _Available since v3.1._
*/
function functionCall(address target, bytes memory data) internal returns (bytes memory) {
return functionCall(target, data, "Address: low-level call failed");
}
/**
* @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with
* `errorMessage` as a fallback revert reason when `target` reverts.
*
* _Available since v3.1._
*/
function functionCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) {
return functionCallWithValue(target, data, 0, errorMessage);
}
/**
* @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
* but also transferring `value` wei to `target`.
*
* Requirements:
*
* - the calling contract must have an ETH balance of at least `value`.
* - the called Solidity function must be `payable`.
*
* _Available since v3.1._
*/
function functionCallWithValue(address target, bytes memory data, uint256 value) internal returns (bytes memory) {
return functionCallWithValue(target, data, value, "Address: low-level call with value failed");
}
/**
* @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but
* with `errorMessage` as a fallback revert reason when `target` reverts.
*
* _Available since v3.1._
*/
function functionCallWithValue(address target, bytes memory data, uint256 value, string memory errorMessage) internal returns (bytes memory) {
require(address(this).balance >= value, "Address: insufficient balance for call");
require(isContract(target), "Address: call to non-contract");
// solhint-disable-next-line avoid-low-level-calls
(bool success, bytes memory returndata) = target.call{ value: value }(data);
return _verifyCallResult(success, returndata, errorMessage);
}
/**
* @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
* but performing a static call.
*
* _Available since v3.3._
*/
function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {
return functionStaticCall(target, data, "Address: low-level static call failed");
}
/**
* @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
* but performing a static call.
*
* _Available since v3.3._
*/
function functionStaticCall(address target, bytes memory data, string memory errorMessage) internal view returns (bytes memory) {
require(isContract(target), "Address: static call to non-contract");
// solhint-disable-next-line avoid-low-level-calls
(bool success, bytes memory returndata) = target.staticcall(data);
return _verifyCallResult(success, returndata, errorMessage);
}
/**
* @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
* but performing a delegate call.
*
* _Available since v3.4._
*/
function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {
return functionDelegateCall(target, data, "Address: low-level delegate call failed");
}
/**
* @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
* but performing a delegate call.
*
* _Available since v3.4._
*/
function functionDelegateCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) {
require(isContract(target), "Address: delegate call to non-contract");
// solhint-disable-next-line avoid-low-level-calls
(bool success, bytes memory returndata) = target.delegatecall(data);
return _verifyCallResult(success, returndata, errorMessage);
}
function _verifyCallResult(bool success, bytes memory returndata, string memory errorMessage) private pure returns(bytes memory) {
if (success) {
return returndata;
} else {
// Look for revert reason and bubble it up if present
if (returndata.length > 0) {
// The easiest way to bubble the revert reason is using memory via assembly
// solhint-disable-next-line no-inline-assembly
assembly {
let returndata_size := mload(returndata)
revert(add(32, returndata), returndata_size)
}
} else {
revert(errorMessage);
}
}
}
}
ERC721Burnable.sol 25 lines
// SPDX-License-Identifier: MIT
pragma solidity >=0.6.0 <0.8.0;
import "../../utils/Context.sol";
import "./ERC721.sol";
/**
* @title ERC721 Burnable Token
* @dev ERC721 Token that can be irreversibly burned (destroyed).
*/
abstract contract ERC721Burnable is Context, ERC721 {
/**
* @dev Burns `tokenId`. See {ERC721-_burn}.
*
* Requirements:
*
* - The caller must own `tokenId` or be an approved operator.
*/
function burn(uint256 tokenId) public virtual {
//solhint-disable-next-line max-line-length
require(_isApprovedOrOwner(_msgSender(), tokenId), "ERC721Burnable: caller is not owner nor approved");
_burn(tokenId);
}
}
Ownable.sol 68 lines
// SPDX-License-Identifier: MIT
pragma solidity >=0.6.0 <0.8.0;
import "../utils/Context.sol";
/**
* @dev Contract module which provides a basic access control mechanism, where
* there is an account (an owner) that can be granted exclusive access to
* specific functions.
*
* By default, the owner account will be the one that deploys the contract. This
* can later be changed with {transferOwnership}.
*
* This module is used through inheritance. It will make available the modifier
* `onlyOwner`, which can be applied to your functions to restrict their use to
* the owner.
*/
abstract contract Ownable is Context {
address private _owner;
event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
/**
* @dev Initializes the contract setting the deployer as the initial owner.
*/
constructor () internal {
address msgSender = _msgSender();
_owner = msgSender;
emit OwnershipTransferred(address(0), msgSender);
}
/**
* @dev Returns the address of the current owner.
*/
function owner() public view virtual returns (address) {
return _owner;
}
/**
* @dev Throws if called by any account other than the owner.
*/
modifier onlyOwner() {
require(owner() == _msgSender(), "Ownable: caller is not the owner");
_;
}
/**
* @dev Leaves the contract without owner. It will not be possible to call
* `onlyOwner` functions anymore. Can only be called by the current owner.
*
* NOTE: Renouncing ownership will leave the contract without an owner,
* thereby removing any functionality that is only available to the owner.
*/
function renounceOwnership() public virtual onlyOwner {
emit OwnershipTransferred(_owner, address(0));
_owner = address(0);
}
/**
* @dev Transfers ownership of the contract to a new account (`newOwner`).
* Can only be called by the current owner.
*/
function transferOwnership(address newOwner) public virtual onlyOwner {
require(newOwner != address(0), "Ownable: new owner is the zero address");
emit OwnershipTransferred(_owner, newOwner);
_owner = newOwner;
}
}
ERC721.sol 473 lines
// SPDX-License-Identifier: MIT
pragma solidity >=0.6.0 <0.8.0;
import "../../utils/Context.sol";
import "./IERC721.sol";
import "./IERC721Metadata.sol";
import "./IERC721Enumerable.sol";
import "./IERC721Receiver.sol";
import "../../introspection/ERC165.sol";
import "../../math/SafeMath.sol";
import "../../utils/Address.sol";
import "../../utils/EnumerableSet.sol";
import "../../utils/EnumerableMap.sol";
import "../../utils/Strings.sol";
/**
* @title ERC721 Non-Fungible Token Standard basic implementation
* @dev see https://eips.ethereum.org/EIPS/eip-721
*/
contract ERC721 is Context, ERC165, IERC721, IERC721Metadata, IERC721Enumerable {
using SafeMath for uint256;
using Address for address;
using EnumerableSet for EnumerableSet.UintSet;
using EnumerableMap for EnumerableMap.UintToAddressMap;
using Strings for uint256;
// Equals to `bytes4(keccak256("onERC721Received(address,address,uint256,bytes)"))`
// which can be also obtained as `IERC721Receiver(0).onERC721Received.selector`
bytes4 private constant _ERC721_RECEIVED = 0x150b7a02;
// Mapping from holder address to their (enumerable) set of owned tokens
mapping (address => EnumerableSet.UintSet) private _holderTokens;
// Enumerable mapping from token ids to their owners
EnumerableMap.UintToAddressMap private _tokenOwners;
// Mapping from token ID to approved address
mapping (uint256 => address) private _tokenApprovals;
// Mapping from owner to operator approvals
mapping (address => mapping (address => bool)) private _operatorApprovals;
// Token name
string private _name;
// Token symbol
string private _symbol;
// Optional mapping for token URIs
mapping (uint256 => string) private _tokenURIs;
// Base URI
string private _baseURI;
/*
* bytes4(keccak256('balanceOf(address)')) == 0x70a08231
* bytes4(keccak256('ownerOf(uint256)')) == 0x6352211e
* bytes4(keccak256('approve(address,uint256)')) == 0x095ea7b3
* bytes4(keccak256('getApproved(uint256)')) == 0x081812fc
* bytes4(keccak256('setApprovalForAll(address,bool)')) == 0xa22cb465
* bytes4(keccak256('isApprovedForAll(address,address)')) == 0xe985e9c5
* bytes4(keccak256('transferFrom(address,address,uint256)')) == 0x23b872dd
* bytes4(keccak256('safeTransferFrom(address,address,uint256)')) == 0x42842e0e
* bytes4(keccak256('safeTransferFrom(address,address,uint256,bytes)')) == 0xb88d4fde
*
* => 0x70a08231 ^ 0x6352211e ^ 0x095ea7b3 ^ 0x081812fc ^
* 0xa22cb465 ^ 0xe985e9c5 ^ 0x23b872dd ^ 0x42842e0e ^ 0xb88d4fde == 0x80ac58cd
*/
bytes4 private constant _INTERFACE_ID_ERC721 = 0x80ac58cd;
/*
* bytes4(keccak256('name()')) == 0x06fdde03
* bytes4(keccak256('symbol()')) == 0x95d89b41
* bytes4(keccak256('tokenURI(uint256)')) == 0xc87b56dd
*
* => 0x06fdde03 ^ 0x95d89b41 ^ 0xc87b56dd == 0x5b5e139f
*/
bytes4 private constant _INTERFACE_ID_ERC721_METADATA = 0x5b5e139f;
/*
* bytes4(keccak256('totalSupply()')) == 0x18160ddd
* bytes4(keccak256('tokenOfOwnerByIndex(address,uint256)')) == 0x2f745c59
* bytes4(keccak256('tokenByIndex(uint256)')) == 0x4f6ccce7
*
* => 0x18160ddd ^ 0x2f745c59 ^ 0x4f6ccce7 == 0x780e9d63
*/
bytes4 private constant _INTERFACE_ID_ERC721_ENUMERABLE = 0x780e9d63;
/**
* @dev Initializes the contract by setting a `name` and a `symbol` to the token collection.
*/
constructor (string memory name_, string memory symbol_) public {
_name = name_;
_symbol = symbol_;
// register the supported interfaces to conform to ERC721 via ERC165
_registerInterface(_INTERFACE_ID_ERC721);
_registerInterface(_INTERFACE_ID_ERC721_METADATA);
_registerInterface(_INTERFACE_ID_ERC721_ENUMERABLE);
}
/**
* @dev See {IERC721-balanceOf}.
*/
function balanceOf(address owner) public view virtual override returns (uint256) {
require(owner != address(0), "ERC721: balance query for the zero address");
return _holderTokens[owner].length();
}
/**
* @dev See {IERC721-ownerOf}.
*/
function ownerOf(uint256 tokenId) public view virtual override returns (address) {
return _tokenOwners.get(tokenId, "ERC721: owner query for nonexistent token");
}
/**
* @dev See {IERC721Metadata-name}.
*/
function name() public view virtual override returns (string memory) {
return _name;
}
/**
* @dev See {IERC721Metadata-symbol}.
*/
function symbol() public view virtual override returns (string memory) {
return _symbol;
}
/**
* @dev See {IERC721Metadata-tokenURI}.
*/
function tokenURI(uint256 tokenId) public view virtual override returns (string memory) {
require(_exists(tokenId), "ERC721Metadata: URI query for nonexistent token");
string memory _tokenURI = _tokenURIs[tokenId];
string memory base = baseURI();
// If there is no base URI, return the token URI.
if (bytes(base).length == 0) {
return _tokenURI;
}
// If both are set, concatenate the baseURI and tokenURI (via abi.encodePacked).
if (bytes(_tokenURI).length > 0) {
return string(abi.encodePacked(base, _tokenURI));
}
// If there is a baseURI but no tokenURI, concatenate the tokenID to the baseURI.
return string(abi.encodePacked(base, tokenId.toString()));
}
/**
* @dev Returns the base URI set via {_setBaseURI}. This will be
* automatically added as a prefix in {tokenURI} to each token's URI, or
* to the token ID if no specific URI is set for that token ID.
*/
function baseURI() public view virtual returns (string memory) {
return _baseURI;
}
/**
* @dev See {IERC721Enumerable-tokenOfOwnerByIndex}.
*/
function tokenOfOwnerByIndex(address owner, uint256 index) public view virtual override returns (uint256) {
return _holderTokens[owner].at(index);
}
/**
* @dev See {IERC721Enumerable-totalSupply}.
*/
function totalSupply() public view virtual override returns (uint256) {
// _tokenOwners are indexed by tokenIds, so .length() returns the number of tokenIds
return _tokenOwners.length();
}
/**
* @dev See {IERC721Enumerable-tokenByIndex}.
*/
function tokenByIndex(uint256 index) public view virtual override returns (uint256) {
(uint256 tokenId, ) = _tokenOwners.at(index);
return tokenId;
}
/**
* @dev See {IERC721-approve}.
*/
function approve(address to, uint256 tokenId) public virtual override {
address owner = ERC721.ownerOf(tokenId);
require(to != owner, "ERC721: approval to current owner");
require(_msgSender() == owner || ERC721.isApprovedForAll(owner, _msgSender()),
"ERC721: approve caller is not owner nor approved for all"
);
_approve(to, tokenId);
}
/**
* @dev See {IERC721-getApproved}.
*/
function getApproved(uint256 tokenId) public view virtual override returns (address) {
require(_exists(tokenId), "ERC721: approved query for nonexistent token");
return _tokenApprovals[tokenId];
}
/**
* @dev See {IERC721-setApprovalForAll}.
*/
function setApprovalForAll(address operator, bool approved) public virtual override {
require(operator != _msgSender(), "ERC721: approve to caller");
_operatorApprovals[_msgSender()][operator] = approved;
emit ApprovalForAll(_msgSender(), operator, approved);
}
/**
* @dev See {IERC721-isApprovedForAll}.
*/
function isApprovedForAll(address owner, address operator) public view virtual override returns (bool) {
return _operatorApprovals[owner][operator];
}
/**
* @dev See {IERC721-transferFrom}.
*/
function transferFrom(address from, address to, uint256 tokenId) public virtual override {
//solhint-disable-next-line max-line-length
require(_isApprovedOrOwner(_msgSender(), tokenId), "ERC721: transfer caller is not owner nor approved");
_transfer(from, to, tokenId);
}
/**
* @dev See {IERC721-safeTransferFrom}.
*/
function safeTransferFrom(address from, address to, uint256 tokenId) public virtual override {
safeTransferFrom(from, to, tokenId, "");
}
/**
* @dev See {IERC721-safeTransferFrom}.
*/
function safeTransferFrom(address from, address to, uint256 tokenId, bytes memory _data) public virtual override {
require(_isApprovedOrOwner(_msgSender(), tokenId), "ERC721: transfer caller is not owner nor approved");
_safeTransfer(from, to, tokenId, _data);
}
/**
* @dev Safely transfers `tokenId` token from `from` to `to`, checking first that contract recipients
* are aware of the ERC721 protocol to prevent tokens from being forever locked.
*
* `_data` is additional data, it has no specified format and it is sent in call to `to`.
*
* This internal function is equivalent to {safeTransferFrom}, and can be used to e.g.
* implement alternative mechanisms to perform token transfer, such as signature-based.
*
* Requirements:
*
* - `from` cannot be the zero address.
* - `to` cannot be the zero address.
* - `tokenId` token must exist and be owned by `from`.
* - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.
*
* Emits a {Transfer} event.
*/
function _safeTransfer(address from, address to, uint256 tokenId, bytes memory _data) internal virtual {
_transfer(from, to, tokenId);
require(_checkOnERC721Received(from, to, tokenId, _data), "ERC721: transfer to non ERC721Receiver implementer");
}
/**
* @dev Returns whether `tokenId` exists.
*
* Tokens can be managed by their owner or approved accounts via {approve} or {setApprovalForAll}.
*
* Tokens start existing when they are minted (`_mint`),
* and stop existing when they are burned (`_burn`).
*/
function _exists(uint256 tokenId) internal view virtual returns (bool) {
return _tokenOwners.contains(tokenId);
}
/**
* @dev Returns whether `spender` is allowed to manage `tokenId`.
*
* Requirements:
*
* - `tokenId` must exist.
*/
function _isApprovedOrOwner(address spender, uint256 tokenId) internal view virtual returns (bool) {
require(_exists(tokenId), "ERC721: operator query for nonexistent token");
address owner = ERC721.ownerOf(tokenId);
return (spender == owner || getApproved(tokenId) == spender || ERC721.isApprovedForAll(owner, spender));
}
/**
* @dev Safely mints `tokenId` and transfers it to `to`.
*
* Requirements:
d*
* - `tokenId` must not exist.
* - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.
*
* Emits a {Transfer} event.
*/
function _safeMint(address to, uint256 tokenId) internal virtual {
_safeMint(to, tokenId, "");
}
/**
* @dev Same as {xref-ERC721-_safeMint-address-uint256-}[`_safeMint`], with an additional `data` parameter which is
* forwarded in {IERC721Receiver-onERC721Received} to contract recipients.
*/
function _safeMint(address to, uint256 tokenId, bytes memory _data) internal virtual {
_mint(to, tokenId);
require(_checkOnERC721Received(address(0), to, tokenId, _data), "ERC721: transfer to non ERC721Receiver implementer");
}
/**
* @dev Mints `tokenId` and transfers it to `to`.
*
* WARNING: Usage of this method is discouraged, use {_safeMint} whenever possible
*
* Requirements:
*
* - `tokenId` must not exist.
* - `to` cannot be the zero address.
*
* Emits a {Transfer} event.
*/
function _mint(address to, uint256 tokenId) internal virtual {
require(to != address(0), "ERC721: mint to the zero address");
require(!_exists(tokenId), "ERC721: token already minted");
_beforeTokenTransfer(address(0), to, tokenId);
_holderTokens[to].add(tokenId);
_tokenOwners.set(tokenId, to);
emit Transfer(address(0), to, tokenId);
}
/**
* @dev Destroys `tokenId`.
* The approval is cleared when the token is burned.
*
* Requirements:
*
* - `tokenId` must exist.
*
* Emits a {Transfer} event.
*/
function _burn(uint256 tokenId) internal virtual {
address owner = ERC721.ownerOf(tokenId); // internal owner
_beforeTokenTransfer(owner, address(0), tokenId);
// Clear approvals
_approve(address(0), tokenId);
// Clear metadata (if any)
if (bytes(_tokenURIs[tokenId]).length != 0) {
delete _tokenURIs[tokenId];
}
_holderTokens[owner].remove(tokenId);
_tokenOwners.remove(tokenId);
emit Transfer(owner, address(0), tokenId);
}
/**
* @dev Transfers `tokenId` from `from` to `to`.
* As opposed to {transferFrom}, this imposes no restrictions on msg.sender.
*
* Requirements:
*
* - `to` cannot be the zero address.
* - `tokenId` token must be owned by `from`.
*
* Emits a {Transfer} event.
*/
function _transfer(address from, address to, uint256 tokenId) internal virtual {
require(ERC721.ownerOf(tokenId) == from, "ERC721: transfer of token that is not own"); // internal owner
require(to != address(0), "ERC721: transfer to the zero address");
_beforeTokenTransfer(from, to, tokenId);
// Clear approvals from the previous owner
_approve(address(0), tokenId);
_holderTokens[from].remove(tokenId);
_holderTokens[to].add(tokenId);
_tokenOwners.set(tokenId, to);
emit Transfer(from, to, tokenId);
}
/**
* @dev Sets `_tokenURI` as the tokenURI of `tokenId`.
*
* Requirements:
*
* - `tokenId` must exist.
*/
function _setTokenURI(uint256 tokenId, string memory _tokenURI) internal virtual {
require(_exists(tokenId), "ERC721Metadata: URI set of nonexistent token");
_tokenURIs[tokenId] = _tokenURI;
}
/**
* @dev Internal function to set the base URI for all token IDs. It is
* automatically added as a prefix to the value returned in {tokenURI},
* or to the token ID if {tokenURI} is empty.
*/
function _setBaseURI(string memory baseURI_) internal virtual {
_baseURI = baseURI_;
}
/**
* @dev Internal function to invoke {IERC721Receiver-onERC721Received} on a target address.
* The call is not executed if the target address is not a contract.
*
* @param from address representing the previous owner of the given token ID
* @param to target address that will receive the tokens
* @param tokenId uint256 ID of the token to be transferred
* @param _data bytes optional data to send along with the call
* @return bool whether the call correctly returned the expected magic value
*/
function _checkOnERC721Received(address from, address to, uint256 tokenId, bytes memory _data)
private returns (bool)
{
if (!to.isContract()) {
return true;
}
bytes memory returndata = to.functionCall(abi.encodeWithSelector(
IERC721Receiver(to).onERC721Received.selector,
_msgSender(),
from,
tokenId,
_data
), "ERC721: transfer to non ERC721Receiver implementer");
bytes4 retval = abi.decode(returndata, (bytes4));
return (retval == _ERC721_RECEIVED);
}
function _approve(address to, uint256 tokenId) private {
_tokenApprovals[tokenId] = to;
emit Approval(ERC721.ownerOf(tokenId), to, tokenId); // internal owner
}
/**
* @dev Hook that is called before any token transfer. This includes minting
* and burning.
*
* Calling conditions:
*
* - When `from` and `to` are both non-zero, ``from``'s `tokenId` will be
* transferred to `to`.
* - When `from` is zero, `tokenId` will be minted for `to`.
* - When `to` is zero, ``from``'s `tokenId` will be burned.
* - `from` cannot be the zero address.
* - `to` cannot be the zero address.
*
* To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].
*/
function _beforeTokenTransfer(address from, address to, uint256 tokenId) internal virtual { }
}
IERC721.sol 129 lines
// SPDX-License-Identifier: MIT
pragma solidity >=0.6.2 <0.8.0;
import "../../introspection/IERC165.sol";
/**
* @dev Required interface of an ERC721 compliant contract.
*/
interface IERC721 is IERC165 {
/**
* @dev Emitted when `tokenId` token is transferred from `from` to `to`.
*/
event Transfer(address indexed from, address indexed to, uint256 indexed tokenId);
/**
* @dev Emitted when `owner` enables `approved` to manage the `tokenId` token.
*/
event Approval(address indexed owner, address indexed approved, uint256 indexed tokenId);
/**
* @dev Emitted when `owner` enables or disables (`approved`) `operator` to manage all of its assets.
*/
event ApprovalForAll(address indexed owner, address indexed operator, bool approved);
/**
* @dev Returns the number of tokens in ``owner``'s account.
*/
function balanceOf(address owner) external view returns (uint256 balance);
/**
* @dev Returns the owner of the `tokenId` token.
*
* Requirements:
*
* - `tokenId` must exist.
*/
function ownerOf(uint256 tokenId) external view returns (address owner);
/**
* @dev Safely transfers `tokenId` token from `from` to `to`, checking first that contract recipients
* are aware of the ERC721 protocol to prevent tokens from being forever locked.
*
* Requirements:
*
* - `from` cannot be the zero address.
* - `to` cannot be the zero address.
* - `tokenId` token must exist and be owned by `from`.
* - If the caller is not `from`, it must be have been allowed to move this token by either {approve} or {setApprovalForAll}.
* - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.
*
* Emits a {Transfer} event.
*/
function safeTransferFrom(address from, address to, uint256 tokenId) external;
/**
* @dev Transfers `tokenId` token from `from` to `to`.
*
* WARNING: Usage of this method is discouraged, use {safeTransferFrom} whenever possible.
*
* Requirements:
*
* - `from` cannot be the zero address.
* - `to` cannot be the zero address.
* - `tokenId` token must be owned by `from`.
* - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.
*
* Emits a {Transfer} event.
*/
function transferFrom(address from, address to, uint256 tokenId) external;
/**
* @dev Gives permission to `to` to transfer `tokenId` token to another account.
* The approval is cleared when the token is transferred.
*
* Only a single account can be approved at a time, so approving the zero address clears previous approvals.
*
* Requirements:
*
* - The caller must own the token or be an approved operator.
* - `tokenId` must exist.
*
* Emits an {Approval} event.
*/
function approve(address to, uint256 tokenId) external;
/**
* @dev Returns the account approved for `tokenId` token.
*
* Requirements:
*
* - `tokenId` must exist.
*/
function getApproved(uint256 tokenId) external view returns (address operator);
/**
* @dev Approve or remove `operator` as an operator for the caller.
* Operators can call {transferFrom} or {safeTransferFrom} for any token owned by the caller.
*
* Requirements:
*
* - The `operator` cannot be the caller.
*
* Emits an {ApprovalForAll} event.
*/
function setApprovalForAll(address operator, bool _approved) external;
/**
* @dev Returns if the `operator` is allowed to manage all of the assets of `owner`.
*
* See {setApprovalForAll}
*/
function isApprovedForAll(address owner, address operator) external view returns (bool);
/**
* @dev Safely transfers `tokenId` token from `from` to `to`.
*
* Requirements:
*
* - `from` cannot be the zero address.
* - `to` cannot be the zero address.
* - `tokenId` token must exist and be owned by `from`.
* - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.
* - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.
*
* Emits a {Transfer} event.
*/
function safeTransferFrom(address from, address to, uint256 tokenId, bytes calldata data) external;
}
IERC721Metadata.sol 27 lines
// SPDX-License-Identifier: MIT
pragma solidity >=0.6.2 <0.8.0;
import "./IERC721.sol";
/**
* @title ERC-721 Non-Fungible Token Standard, optional metadata extension
* @dev See https://eips.ethereum.org/EIPS/eip-721
*/
interface IERC721Metadata is IERC721 {
/**
* @dev Returns the token collection name.
*/
function name() external view returns (string memory);
/**
* @dev Returns the token collection symbol.
*/
function symbol() external view returns (string memory);
/**
* @dev Returns the Uniform Resource Identifier (URI) for `tokenId` token.
*/
function tokenURI(uint256 tokenId) external view returns (string memory);
}
ERC165.sol 54 lines
// SPDX-License-Identifier: MIT
pragma solidity >=0.6.0 <0.8.0;
import "./IERC165.sol";
/**
* @dev Implementation of the {IERC165} interface.
*
* Contracts may inherit from this and call {_registerInterface} to declare
* their support of an interface.
*/
abstract contract ERC165 is IERC165 {
/*
* bytes4(keccak256('supportsInterface(bytes4)')) == 0x01ffc9a7
*/
bytes4 private constant _INTERFACE_ID_ERC165 = 0x01ffc9a7;
/**
* @dev Mapping of interface ids to whether or not it's supported.
*/
mapping(bytes4 => bool) private _supportedInterfaces;
constructor () internal {
// Derived contracts need only register support for their own interfaces,
// we register support for ERC165 itself here
_registerInterface(_INTERFACE_ID_ERC165);
}
/**
* @dev See {IERC165-supportsInterface}.
*
* Time complexity O(1), guaranteed to always use less than 30 000 gas.
*/
function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {
return _supportedInterfaces[interfaceId];
}
/**
* @dev Registers the contract as an implementer of the interface defined by
* `interfaceId`. Support of the actual ERC165 interface is automatic and
* registering its interface id is not required.
*
* See {IERC165-supportsInterface}.
*
* Requirements:
*
* - `interfaceId` cannot be the ERC165 invalid interface (`0xffffffff`).
*/
function _registerInterface(bytes4 interfaceId) internal virtual {
require(interfaceId != 0xffffffff, "ERC165: invalid interface id");
_supportedInterfaces[interfaceId] = true;
}
}
Read Contract
MAX_FREE_PASSES_PER_ROUND 0xe5e958e1 → uint256
MAX_PAID_MINT 0xd9b39a11 → uint256
MAX_PARROT_PASSES 0xfb79f4ee → uint256
balanceOf 0x70a08231 → uint256
baseURI 0x6c0360eb → string
claimedFreePass 0x3dc40e2a → bool
currentFreeMintTokens 0xe6e21730 → address
freeMintPaused 0x0b24f435 → bool
freePassesMinted 0x02d7948e → uint256
getApproved 0x081812fc → address
isApprovedForAll 0xe985e9c5 → bool
mintPaused 0x7e4831d3 → bool
name 0x06fdde03 → string
owner 0x8da5cb5b → address
ownerOf 0x6352211e → address
paidPassesMinted 0x060426bc → uint256
price 0xa035b1fe → uint256
supportsInterface 0x01ffc9a7 → bool
symbol 0x95d89b41 → string
tokenByIndex 0x4f6ccce7 → uint256
tokenOfOwnerByIndex 0x2f745c59 → uint256
tokenURI 0xc87b56dd → string
tokensOfOwner 0x8462151c → uint256[]
totalSupply 0x18160ddd → uint256
vault 0xfbfa77cf → address
walletCanFreeMint 0xe0c75284 → bool
Write Contract 20 functions
These functions modify contract state and require a wallet transaction to execute.
addFreeMintToken 0x7a70f35f
address _newTokenAddress
approve 0x095ea7b3
address to
uint256 tokenId
burn 0x42966c68
uint256 tokenId
clearFreeMintTokens 0xdab17d7a
No parameters
forwardERC20s 0x9727151a
address _token
uint256 _amount
freeMint 0x5b70ea9f
No parameters
mint 0xa0712d68
uint256 numPasses
pause 0x02329a29
bool val
renounceOwnership 0x715018a6
No parameters
reserve 0x819b25ba
uint256 _numPasses
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 0x55f804b3
string _newBaseURI
setVault 0x6817031b
address _newVaultAddress
startNextFreeMintingRound 0x07062df7
No parameters
transferFrom 0x23b872dd
address from
address to
uint256 tokenId
transferOwnership 0xf2fde38b
address newOwner
withdraw 0x2e1a7d4d
uint256 _amount
withdrawAll 0x853828b6
No parameters
Recent Transactions
No transactions found for this address