Cryo Explorer Ethereum Mainnet

Address Contract Verified

Address 0x6D7c44773C52D396F43c2D511B81aa168E9a7a42
Balance 203.7011 ETH
Nonce 1
Code Size 14509 bytes
Indexed Transactions 5 (24,414,24124,414,299)
Gas Used (indexed) 899,214
External Etherscan · Sourcify

Contract Bytecode

14509 bytes
0x60806040526004361061033e5760003560e01c80636fe9f44c116101b0578063b3ffb760116100ec578063c90b871411610095578063e4e87e3b1161006f578063e4e87e3b14611123578063e92f94d114611156578063f2fde38b14611199578063f7cfaad0146111cc5761033e565b8063c90b8714146110cc578063daa26499146110e1578063dce96bf5146110f65761033e565b8063c306b378116100c6578063c306b37814610ec7578063c47c35c114610f45578063c8f94f4e14610fd05761033e565b8063b3ffb76014610e3e578063b567858814610e78578063ba50b63214610eb25761033e565b80638da5cb5b11610159578063a11b071211610133578063a11b071214610dcc578063a6d23e1014610de1578063af231a5814610df6578063b23afc2614610e295761033e565b80638da5cb5b14610c7e5780639041a0ec14610c935780639c883af214610d995761033e565b80637f3582301161018a5780637f35823014610bdf57806384a608e214610c12578063859b97fe14610c455761033e565b80636fe9f44c14610b75578063715018a614610ba05780637a54479214610bb55761033e565b8063299a0e1e1161027f5780633bc3d9be116102285780635138b08c116102025780635138b08c14610a1d578063534665e914610a565780636240cd1c14610b4b5780636b534ed014610b605761033e565b80633bc3d9be146109c657806348626b90146109db5780634c94c90c14610a085761033e565b80632c740844116102595780632c7408441461085d5780633492e5a814610890578063369679a4146108c35761033e565b8063299a0e1e1461073f5780632a2a326c146107ad5780632c419053146107e05761033e565b80630e519ef9116102ec578063155a56b1116102c6578063155a56b114610657578063176ab4401461066c5780631a2ac30f1461069f57806321ede0321461070c5761033e565b80630e519ef9146105d65780630f2b2532146105eb57806310f797891461062d5761033e565b80630a5c4ed51161031d5780630a5c4ed5146104855780630bcba09d146104ac5780630cd87c68146104c15761033e565b80629d9aa9146103435780630141c59014610374578063060d9eeb14610389575b600080fd5b34801561034f57600080fd5b5061035861120f565b604080516001600160a01b039092168252519081900360200190f35b34801561038057600080fd5b5061035861121e565b34801561039557600080fd5b50610483600480360360e08110156103ac57600080fd5b6001600160a01b03823581169260208101359260408201359092169160608201359160808101359181019060c0810160a08201356401000000008111156103f257600080fd5b82018360208201111561040457600080fd5b8035906020019184602083028401116401000000008311171561042657600080fd5b91939092909160208101903564010000000081111561044457600080fd5b82018360208201111561045657600080fd5b8035906020019184602083028401116401000000008311171561047857600080fd5b50909250905061122d565b005b34801561049157600080fd5b5061049a611467565b60408051918252519081900360200190f35b3480156104b857600080fd5b5061035861146d565b3480156104cd57600080fd5b506104fa600480360360408110156104e457600080fd5b506001600160a01b03813516906020013561147c565b604051808a6001600160a01b03168152602001898152602001888152602001878152602001866001600160a01b031681526020018581526020018481526020018060200180602001838103835285818151815260200191508051906020019060200280838360005b8381101561057a578181015183820152602001610562565b50505050905001838103825284818151815260200191508051906020019060200280838360005b838110156105b95781810151838201526020016105a1565b505050509050019b50505050505050505050505060405180910390f35b3480156105e257600080fd5b5061049a61162a565b610483600480360360a081101561060157600080fd5b506001600160a01b03813581169160208101359160408201351690606081013590608001351515611630565b34801561063957600080fd5b506104836004803603602081101561065057600080fd5b50356117a2565b34801561066357600080fd5b5061049a611809565b34801561067857600080fd5b506104836004803603602081101561068f57600080fd5b50356001600160a01b031661180e565b3480156106ab57600080fd5b506106e2600480360360608110156106c257600080fd5b506001600160a01b038135811691602081013591604090910135166118a5565b604080516001600160a01b0394851681529290931660208301528183015290519081900360600190f35b34801561071857600080fd5b506104836004803603602081101561072f57600080fd5b50356001600160a01b03166118e4565b34801561074b57600080fd5b506107786004803603604081101561076257600080fd5b506001600160a01b03813516906020013561197b565b604080516001600160a01b0395861681529390941660208401528284019190915260ff16606082015290519081900360800190f35b3480156107b957600080fd5b50610483600480360360208110156107d057600080fd5b50356001600160a01b03166119bd565b3480156107ec57600080fd5b506108236004803603606081101561080357600080fd5b506001600160a01b03813581169160208101359160409091013516611a54565b604080516001600160a01b03909616865260208601949094528484019290925260ff16606084015215156080830152519081900360a00190f35b34801561086957600080fd5b506104836004803603602081101561088057600080fd5b50356001600160a01b0316611aa2565b34801561089c57600080fd5b50610483600480360360208110156108b357600080fd5b50356001600160a01b0316611b39565b3480156108cf57600080fd5b50610906600480360360608110156108e657600080fd5b506001600160a01b03813581169160208101359160409091013516611bd0565b60405180866001600160a01b03168152602001856001600160a01b031681526020018481526020018060200180602001838103835285818151815260200191508051906020019060200280838360005b8381101561096e578181015183820152602001610956565b50505050905001838103825284818151815260200191508051906020019060200280838360005b838110156109ad578181015183820152602001610995565b5050505090500197505050505050505060405180910390f35b3480156109d257600080fd5b50610358611d36565b3480156109e757600080fd5b50610483600480360360208110156109fe57600080fd5b503560ff16611d45565b348015610a1457600080fd5b50610358611dc7565b348015610a2957600080fd5b5061048360048036036040811015610a4057600080fd5b506001600160a01b038135169060200135611dd6565b348015610a6257600080fd5b50610483600480360360c0811015610a7957600080fd5b6001600160a01b0382358116926020810135926040820135909216916060820135919081019060a081016080820135640100000000811115610aba57600080fd5b820183602082011115610acc57600080fd5b80359060200191846020830284011164010000000083111715610aee57600080fd5b919390929091602081019035640100000000811115610b0c57600080fd5b820183602082011115610b1e57600080fd5b80359060200191846020830284011164010000000083111715610b4057600080fd5b509092509050611f2b565b348015610b5757600080fd5b5061035861211f565b348015610b6c57600080fd5b5061035861212e565b348015610b8157600080fd5b50610b8a61213d565b6040805160ff9092168252519081900360200190f35b348015610bac57600080fd5b5061048361214d565b348015610bc157600080fd5b5061048360048036036020811015610bd857600080fd5b50356121f9565b348015610beb57600080fd5b5061048360048036036020811015610c0257600080fd5b50356001600160a01b0316612260565b348015610c1e57600080fd5b5061048360048036036020811015610c3557600080fd5b50356001600160a01b03166122f7565b348015610c5157600080fd5b5061048360048036036040811015610c6857600080fd5b506001600160a01b03813516906020013561238e565b348015610c8a57600080fd5b50610358612423565b348015610c9f57600080fd5b506104836004803603610120811015610cb757600080fd5b8135916001600160a01b0360208201358116926040830135926060810135926080820135169160a08201359160c081013591810190610100810160e0820135640100000000811115610d0857600080fd5b820183602082011115610d1a57600080fd5b80359060200191846020830284011164010000000083111715610d3c57600080fd5b919390929091602081019035640100000000811115610d5a57600080fd5b820183602082011115610d6c57600080fd5b80359060200191846020830284011164010000000083111715610d8e57600080fd5b509092509050612432565b348015610da557600080fd5b5061048360048036036020811015610dbc57600080fd5b50356001600160a01b0316612641565b348015610dd857600080fd5b506103586126d8565b348015610ded57600080fd5b506103586126e7565b348015610e0257600080fd5b5061048360048036036020811015610e1957600080fd5b50356001600160a01b03166126f6565b348015610e3557600080fd5b5061049a61278d565b61048360048036036080811015610e5457600080fd5b506001600160a01b03813581169160208101359160408201351690606001356127b1565b61048360048036036080811015610e8e57600080fd5b506001600160a01b0381358116916020810135916040820135169060600135612917565b348015610ebe57600080fd5b506103586129bb565b348015610ed357600080fd5b506104836004803603610140811015610eeb57600080fd5b506001600160a01b038135811691602081013582169160408201358116916060810135821691608082013581169160a081013582169160c082013581169160e08101358216916101008201358116916101200135166129ca565b348015610f5157600080fd5b50610f7e60048036036040811015610f6857600080fd5b506001600160a01b038135169060200135612bf3565b60405180886001600160a01b03168152602001878152602001868152602001858152602001846001600160a01b0316815260200183815260200182815260200197505050505050505060405180910390f35b348015610fdc57600080fd5b50610483600480360360e0811015610ff357600080fd5b6001600160a01b038235811692602081013592604082013583169260608301359260808101359091169181019060c0810160a082013564010000000081111561103b57600080fd5b82018360208201111561104d57600080fd5b8035906020019184602083028401116401000000008311171561106f57600080fd5b91939092909160208101903564010000000081111561108d57600080fd5b82018360208201111561109f57600080fd5b803590602001918460208302840111640100000000831117156110c157600080fd5b509092509050612c47565b3480156110d857600080fd5b5061049a612d86565b3480156110ed57600080fd5b5061049a612daa565b34801561110257600080fd5b506104836004803603602081101561111957600080fd5b503560ff16612db0565b34801561112f57600080fd5b506104836004803603602081101561114657600080fd5b50356001600160a01b0316612e1a565b34801561116257600080fd5b506104836004803603606081101561117957600080fd5b506001600160a01b03813581169160208101359160409091013516612eb1565b3480156111a557600080fd5b50610483600480360360208110156111bc57600080fd5b50356001600160a01b0316613012565b3480156111d857600080fd5b50610483600480360360608110156111ef57600080fd5b506001600160a01b03813581169160208101359160409091013516613115565b609f546001600160a01b031681565b609a546001600160a01b031681565b60006060609b60009054906101000a90046001600160a01b03166001600160a01b031663060d9eeb60e01b8c8c8c8c8c8c8c8c8c604051602401808a6001600160a01b03168152602001898152602001886001600160a01b0316815260200187815260200186815260200180602001806020018381038352878782818152602001925060200280828437600083820152601f01601f19169091018481038352858152602090810191508690860280828437600081840152601f19601f8201169050808301925050509b505050505050505050505050604051602081830303815290604052906001600160e01b0319166020820180516001600160e01b0383818316178352505050506040518082805190602001908083835b602083106113645780518252601f199092019160209182019101611345565b6001836020036101000a038019825116818451168082178552505050505050905001915050600060405180830381855af49150503d80600081146113c4576040519150601f19603f3d011682016040523d82523d6000602084013e6113c9565b606091505b50915091508181906114595760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b8381101561141e578181015183820152602001611406565b50505050905090810190601f16801561144b5780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050505050505050505050565b60a35481565b609c546001600160a01b031681565b60008060008060008060006060806114926136e5565b6001600160a01b03808d16600090815260a6602090815260408083208f84528252918290208251610120810184528154851681526001820154818401526002820154818501526003820154606082015260048201549094166080850152600581015460a0850152600681015460c0850152600781018054845181850281018501909552808552919360e086019390929083018282801561155b57602002820191906000526020600020905b81546001600160a01b0316815260019091019060200180831161153d575b50505050508152602001600882018054806020026020016040519081016040528092919081815260200182805480156115d157602002820191906000526020600020906000905b825461010083900a900460ff168152602060019283018181049485019490930390920291018084116115a25790505b5050505050815250509050806000015181602001518260400151836060015184608001518560a001518660c001518760e00151886101000151995099509950995099509950995099509950509295985092959850929598565b60a15481565b609a54604080516001600160a01b0388811660248301526044820188905286811660648301526084820186905284151560a4808401919091528351808403909101815260c490920183526020820180516001600160e01b03167f0f2b253200000000000000000000000000000000000000000000000000000000178152925182516000956060959316939282918083835b602083106116e05780518252601f1990920191602091820191016116c1565b6001836020036101000a038019825116818451168082178552505050505050905001915050600060405180830381855af49150503d8060008114611740576040519150601f19603f3d011682016040523d82523d6000602084013e611745565b606091505b50915091508181906117985760405162461bcd60e51b815260206004820181815283516024840152835190928392604490910191908501908083836000831561141e578181015183820152602001611406565b5050505050505050565b6117aa613344565b6001600160a01b03166117bb612423565b6001600160a01b031614611804576040805162461bcd60e51b81526020600482018190526024820152600080516020613858833981519152604482015290519081900360640190fd5b60a255565b600081565b611816613344565b6001600160a01b0316611827612423565b6001600160a01b031614611870576040805162461bcd60e51b81526020600482018190526024820152600080516020613858833981519152604482015290519081900360640190fd5b6001600160a01b03811661188357600080fd5b609780546001600160a01b0319166001600160a01b0392909216919091179055565b60a46020908152600093845260408085208252928452828420905282529020805460018201546002909201546001600160a01b03918216929091169083565b6118ec613344565b6001600160a01b03166118fd612423565b6001600160a01b031614611946576040805162461bcd60e51b81526020600482018190526024820152600080516020613858833981519152604482015290519081900360640190fd5b6001600160a01b03811661195957600080fd5b609980546001600160a01b0319166001600160a01b0392909216919091179055565b60a760209081526000928352604080842090915290825290208054600182015460028301546003909301546001600160a01b0392831693919092169160ff1684565b6119c5613344565b6001600160a01b03166119d6612423565b6001600160a01b031614611a1f576040805162461bcd60e51b81526020600482018190526024820152600080516020613858833981519152604482015290519081900360640190fd5b6001600160a01b038116611a3257600080fd5b609b80546001600160a01b0319166001600160a01b0392909216919091179055565b60a560209081526000938452604080852082529284528284209052825290208054600182015460028301546003909301546001600160a01b0390921692909160ff8082169161010090041685565b611aaa613344565b6001600160a01b0316611abb612423565b6001600160a01b031614611b04576040805162461bcd60e51b81526020600482018190526024820152600080516020613858833981519152604482015290519081900360640190fd5b6001600160a01b038116611b1757600080fd5b609f80546001600160a01b0319166001600160a01b0392909216919091179055565b611b41613344565b6001600160a01b0316611b52612423565b6001600160a01b031614611b9b576040805162461bcd60e51b81526020600482018190526024820152600080516020613858833981519152604482015290519081900360640190fd5b6001600160a01b038116611bae57600080fd5b60a080546001600160a01b0319166001600160a01b0392909216919091179055565b6000806000606080611be0613746565b6001600160a01b03808a16600090815260a4602090815260408083208c845282528083208b85168452825291829020825160a08101845281548516815260018201549094168483015260028101548484015260038101805484518185028101850190955280855291936060860193909290830182828015611c8a57602002820191906000526020600020905b81546001600160a01b03168152600190910190602001808311611c6c575b5050505050815260200160048201805480602002602001604051908101604052809291908181526020018280548015611d0057602002820191906000526020600020906000905b825461010083900a900460ff16815260206001928301818104948501949093039092029101808411611cd15790505b5050509190925250508151602083015160408401516060850151608090950151929e919d509b5092995097509095505050505050565b609b546001600160a01b031681565b611d4d613344565b6001600160a01b0316611d5e612423565b6001600160a01b031614611da7576040805162461bcd60e51b81526020600482018190526024820152600080516020613858833981519152604482015290519081900360640190fd5b60a0805460ff909216600160a01b0260ff60a01b19909216919091179055565b6099546001600160a01b031681565b609b54604080516001600160a01b038581166024830152604480830186905283518084039091018152606490920183526020820180516001600160e01b03167f5138b08c00000000000000000000000000000000000000000000000000000000178152925182516000956060959316939282918083835b60208310611e6c5780518252601f199092019160209182019101611e4d565b6001836020036101000a038019825116818451168082178552505050505050905001915050600060405180830381855af49150503d8060008114611ecc576040519150601f19603f3d011682016040523d82523d6000602084013e611ed1565b606091505b5091509150818190611f245760405162461bcd60e51b815260206004820181815283516024840152835190928392604490910191908501908083836000831561141e578181015183820152602001611406565b5050505050565b60006060609a60009054906101000a90046001600160a01b03166001600160a01b031663534665e960e01b8b8b8b8b8b8b8b8b60405160240180896001600160a01b03168152602001888152602001876001600160a01b0316815260200186815260200180602001806020018381038352878782818152602001925060200280828437600083820152601f01601f19169091018481038352858152602090810191508690860280828437600081840152601f19601f8201169050808301925050509a5050505050505050505050604051602081830303815290604052906001600160e01b0319166020820180516001600160e01b0383818316178352505050506040518082805190602001908083835b6020831061205a5780518252601f19909201916020918201910161203b565b6001836020036101000a038019825116818451168082178552505050505050905001915050600060405180830381855af49150503d80600081146120ba576040519150601f19603f3d011682016040523d82523d6000602084013e6120bf565b606091505b50915091508181906121125760405162461bcd60e51b815260206004820181815283516024840152835190928392604490910191908501908083836000831561141e578181015183820152602001611406565b5050505050505050505050565b609d546001600160a01b031681565b60a0546001600160a01b031681565b60a054600160a01b900460ff1681565b612155613344565b6001600160a01b0316612166612423565b6001600160a01b0316146121af576040805162461bcd60e51b81526020600482018190526024820152600080516020613858833981519152604482015290519081900360640190fd5b6033546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3603380546001600160a01b0319169055565b612201613344565b6001600160a01b0316612212612423565b6001600160a01b03161461225b576040805162461bcd60e51b81526020600482018190526024820152600080516020613858833981519152604482015290519081900360640190fd5b60a355565b612268613344565b6001600160a01b0316612279612423565b6001600160a01b0316146122c2576040805162461bcd60e51b81526020600482018190526024820152600080516020613858833981519152604482015290519081900360640190fd5b6001600160a01b0381166122d557600080fd5b609c80546001600160a01b0319166001600160a01b0392909216919091179055565b6122ff613344565b6001600160a01b0316612310612423565b6001600160a01b031614612359576040805162461bcd60e51b81526020600482018190526024820152600080516020613858833981519152604482015290519081900360640190fd5b6001600160a01b03811661236c57600080fd5b609880546001600160a01b0319166001600160a01b0392909216919091179055565b609b54604080516001600160a01b038581166024830152604480830186905283518084039091018152606490920183526020820180516001600160e01b03167f859b97fe000000000000000000000000000000000000000000000000000000001781529251825160009560609593169392829180838360208310611e6c5780518252601f199092019160209182019101611e4d565b6033546001600160a01b031690565b60006060609b60009054906101000a90046001600160a01b03166001600160a01b0316639041a0ec60e01b8e8e8e8e8e8e8e8e8e8e8e604051602401808c81526020018b6001600160a01b031681526020018a8152602001898152602001886001600160a01b0316815260200187815260200186815260200180602001806020018381038352878782818152602001925060200280828437600083820152601f01601f19169091018481038352858152602090810191508690860280828437600081840152601f19601f8201169050808301925050509d5050505050505050505050505050604051602081830303815290604052906001600160e01b0319166020820180516001600160e01b0383818316178352505050506040518082805190602001908083835b602083106125795780518252601f19909201916020918201910161255a565b6001836020036101000a038019825116818451168082178552505050505050905001915050600060405180830381855af49150503d80600081146125d9576040519150601f19603f3d011682016040523d82523d6000602084013e6125de565b606091505b50915091508181906126315760405162461bcd60e51b815260206004820181815283516024840152835190928392604490910191908501908083836000831561141e578181015183820152602001611406565b5050505050505050505050505050565b612649613344565b6001600160a01b031661265a612423565b6001600160a01b0316146126a3576040805162461bcd60e51b81526020600482018190526024820152600080516020613858833981519152604482015290519081900360640190fd5b6001600160a01b0381166126b657600080fd5b609a80546001600160a01b0319166001600160a01b0392909216919091179055565b6098546001600160a01b031681565b609e546001600160a01b031681565b6126fe613344565b6001600160a01b031661270f612423565b6001600160a01b031614612758576040805162461bcd60e51b81526020600482018190526024820152600080516020613858833981519152604482015290519081900360640190fd5b6001600160a01b03811661276b57600080fd5b609e80546001600160a01b0319166001600160a01b0392909216919091179055565b7f5343484544554c45445f41554354494f4e00000000000000000000000000000081565b609a54604080516001600160a01b03878116602483015260448201879052858116606483015260848083018690528351808403909101815260a490920183526020820180516001600160e01b03167fb3ffb76000000000000000000000000000000000000000000000000000000000178152925182516000956060959316939282918083835b602083106128565780518252601f199092019160209182019101612837565b6001836020036101000a038019825116818451168082178552505050505050905001915050600060405180830381855af49150503d80600081146128b6576040519150601f19603f3d011682016040523d82523d6000602084013e6128bb565b606091505b509150915081819061290e5760405162461bcd60e51b815260206004820181815283516024840152835190928392604490910191908501908083836000831561141e578181015183820152602001611406565b50505050505050565b609b54604080516001600160a01b03878116602483015260448201879052858116606483015260848083018690528351808403909101815260a490920183526020820180516001600160e01b03167fb56785880000000000000000000000000000000000000000000000000000000017815292518251600095606095931693928291808383602083106128565780518252601f199092019160209182019101612837565b6097546001600160a01b031681565b600054610100900460ff16806129e357506129e3613348565b806129f1575060005460ff16155b612a2c5760405162461bcd60e51b815260040180806020018281038252602e81526020018061382a602e913960400191505060405180910390fd5b600054610100900460ff16158015612a57576000805460ff1961ff0019909116610100171660011790555b6001600160a01b038b16612a6a57600080fd5b6001600160a01b038a16612a7d57600080fd5b6001600160a01b038916612a9057600080fd5b6001600160a01b038816612aa357600080fd5b6001600160a01b038716612ab657600080fd5b6001600160a01b038616612ac957600080fd5b6001600160a01b038516612adc57600080fd5b6001600160a01b038416612aef57600080fd5b6001600160a01b038216612b0257600080fd5b609780546001600160a01b03199081166001600160a01b038e8116919091179092556098805482168d84161790556099805482168c8416179055609a805482168b8416179055609b805482168a8416179055609c80548216898416179055609d80548216888416179055609e80548216878416179055609f8054821686841617905560a080549091169184169190911760ff60a01b1916740a000000000000000000000000000000000000000017905562093a8060a15561038460a25561012c60a355612bcd613359565b612bd561340b565b8015612112576000805461ff00191690555050505050505050505050565b60a660209081526000928352604080842090915290825290208054600182015460028301546003840154600485015460058601546006909601546001600160a01b0395861696949593949293909116919087565b60006060609a60009054906101000a90046001600160a01b03166001600160a01b031663c8f94f4e60e01b8c8c8c8c8c8c8c8c8c604051602401808a6001600160a01b03168152602001898152602001886001600160a01b03168152602001878152602001866001600160a01b0316815260200180602001806020018381038352878782818152602001925060200280828437600083820152601f01601f19169091018481038352858152602090810191508690860280828437600081840152601f19601f8201169050808301925050509b505050505050505050505050604051602081830303815290604052906001600160e01b0319166020820180516001600160e01b038381831617835250505050604051808280519060200190808383602083106113645780518252601f199092019160209182019101611345565b7f434f4c4449455f41554354494f4e00000000000000000000000000000000000081565b60a25481565b612db8613344565b6001600160a01b0316612dc9612423565b6001600160a01b031614612e12576040805162461bcd60e51b81526020600482018190526024820152600080516020613858833981519152604482015290519081900360640190fd5b60ff1660a155565b612e22613344565b6001600160a01b0316612e33612423565b6001600160a01b031614612e7c576040805162461bcd60e51b81526020600482018190526024820152600080516020613858833981519152604482015290519081900360640190fd5b6001600160a01b038116612e8f57600080fd5b609d80546001600160a01b0319166001600160a01b0392909216919091179055565b609a54604080516001600160a01b0386811660248301526044820186905284811660648084019190915283518084039091018152608490920183526020820180516001600160e01b03167fe92f94d100000000000000000000000000000000000000000000000000000000178152925182516000956060959316939282918083835b60208310612f525780518252601f199092019160209182019101612f33565b6001836020036101000a038019825116818451168082178552505050505050905001915050600060405180830381855af49150503d8060008114612fb2576040519150601f19603f3d011682016040523d82523d6000602084013e612fb7565b606091505b509150915081819061300a5760405162461bcd60e51b815260206004820181815283516024840152835190928392604490910191908501908083836000831561141e578181015183820152602001611406565b505050505050565b61301a613344565b6001600160a01b031661302b612423565b6001600160a01b031614613074576040805162461bcd60e51b81526020600482018190526024820152600080516020613858833981519152604482015290519081900360640190fd5b6001600160a01b0381166130b95760405162461bcd60e51b81526004018080602001828103825260268152602001806137e06026913960400191505060405180910390fd5b6033546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3603380546001600160a01b0319166001600160a01b0392909216919091179055565b60008390506000816001600160a01b0316636352211e856040518263ffffffff1660e01b81526004018082815260200191505060206040518083038186803b15801561316057600080fd5b505afa158015613174573d6000803e3d6000fd5b505050506040513d602081101561318a57600080fd5b50519050336001600160a01b038216146131d55760405162461bcd60e51b81526004018080602001828103825260248152602001806138066024913960400191505060405180910390fd5b6001600160a01b03808616600090815260a4602090815260408083208884528252808320938716835292905290812080546001600160a01b03199081168255600182018054909116905560028101829055906132346003830182613787565b6132426004830160006137a5565b5050604080516000808252602080830182815283850194859052828552606084018390526080840189905260a0808501908152845160e0860181905293956001600160a01b038c16957fb6039ff1edf80efca6bc48b89f5415ba07fecb2d321058dae9ce6369b2ff964b95889586958e95939490939092909160c08601916101008701918691028083838c5b838110156132e65781810151838201526020016132ce565b50505050905001838103825284818151815260200191508051906020019060200280838360005b8381101561332557818101518382015260200161330d565b5050505090500197505050505050505060405180910390a35050505050565b3390565b6000613353306134a0565b15905090565b600054610100900460ff16806133725750613372613348565b80613380575060005460ff16155b6133bb5760405162461bcd60e51b815260040180806020018281038252602e81526020018061382a602e913960400191505060405180910390fd5b600054610100900460ff161580156133e6576000805460ff1961ff0019909116610100171660011790555b6133ee6134a6565b6133f6613546565b8015613408576000805461ff00191690555b50565b600054610100900460ff16806134245750613424613348565b80613432575060005460ff16155b61346d5760405162461bcd60e51b815260040180806020018281038252602e81526020018061382a602e913960400191505060405180910390fd5b600054610100900460ff16158015613498576000805460ff1961ff0019909116610100171660011790555b6133f661363f565b3b151590565b600054610100900460ff16806134bf57506134bf613348565b806134cd575060005460ff16155b6135085760405162461bcd60e51b815260040180806020018281038252602e81526020018061382a602e913960400191505060405180910390fd5b600054610100900460ff161580156133f6576000805460ff1961ff0019909116610100171660011790558015613408576000805461ff001916905550565b600054610100900460ff168061355f575061355f613348565b8061356d575060005460ff16155b6135a85760405162461bcd60e51b815260040180806020018281038252602e81526020018061382a602e913960400191505060405180910390fd5b600054610100900460ff161580156135d3576000805460ff1961ff0019909116610100171660011790555b60006135dd613344565b603380546001600160a01b0319166001600160a01b038316908117909155604051919250906000907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a3508015613408576000805461ff001916905550565b600054610100900460ff16806136585750613658613348565b80613666575060005460ff16155b6136a15760405162461bcd60e51b815260040180806020018281038252602e81526020018061382a602e913960400191505060405180910390fd5b600054610100900460ff161580156136cc576000805460ff1961ff0019909116610100171660011790555b60016065558015613408576000805461ff001916905550565b60405180610120016040528060006001600160a01b0316815260200160008152602001600081526020016000815260200160006001600160a01b03168152602001600081526020016000801916815260200160608152602001606081525090565b6040518060a0016040528060006001600160a01b0316815260200160006001600160a01b031681526020016000815260200160608152602001606081525090565b508054600082559060005260206000209081019061340891906137c6565b50805460008255601f01602090049060005260206000209081019061340891905b5b808211156137db57600081556001016137c7565b509056fe4f776e61626c653a206e6577206f776e657220697320746865207a65726f206164647265737372656d6f766553616c6550726963653a3a4d75737420626520746f6b656e4f776e65722e496e697469616c697a61626c653a20636f6e747261637420697320616c726561647920696e697469616c697a65644f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572a26469706673582212208451d83a43e679d12169f79667a3b9c0d5a82d52ddd51ecde92aa3688bf1a50264736f6c63430007030033

Verified Source Code Full Match

Compiler: v0.7.3+commit.9bfce1f6 EVM: istanbul Optimization: Yes (999 runs)
IPayments.sol 13 lines
// SPDX-License-Identifier: MIT
pragma solidity 0.7.3;

/// @author koloz
/// @title IPayments
/// @notice Interface for the Payments contract used.
interface IPayments {
    function refund(address _payee, uint256 _amount) external payable;

    function payout(address[] calldata _splits, uint256[] calldata _amounts)
        external
        payable;
}
SuperRareBazaar.sol 555 lines
// SPDX-License-Identifier: MIT
pragma solidity 0.7.3;

import "@openzeppelin/contracts-upgradeable-0.7.2/access/OwnableUpgradeable.sol";
import "@openzeppelin/contracts-upgradeable-0.7.2/utils/ReentrancyGuardUpgradeable.sol";
import "@openzeppelin/contracts-0.7.2/token/ERC721/IERC721.sol";
import "./storage/SuperRareBazaarStorage.sol";
import "./ISuperRareBazaar.sol";

/// @author koloz
/// @title SuperRareBazaar
/// @notice The unified contract for the bazaar logic (Marketplace and Auction House).
/// @dev All storage is inherrited and append only (no modifications) to make upgrade compliant.
contract SuperRareBazaar is
    ISuperRareBazaar,
    OwnableUpgradeable,
    ReentrancyGuardUpgradeable,
    SuperRareBazaarStorage
{
    /////////////////////////////////////////////////////////////////////////
    // Initializer
    /////////////////////////////////////////////////////////////////////////
    function initialize(
        address _marketplaceSettings,
        address _royaltyRegistry,
        address _royaltyEngine,
        address _superRareMarketplace,
        address _superRareAuctionHouse,
        address _spaceOperatorRegistry,
        address _approvedTokenRegistry,
        address _payments,
        address _stakingRegistry,
        address _networkBeneficiary
    ) public initializer {
        require(_marketplaceSettings != address(0));
        require(_royaltyRegistry != address(0));
        require(_royaltyEngine != address(0));
        require(_superRareMarketplace != address(0));
        require(_superRareAuctionHouse != address(0));
        require(_spaceOperatorRegistry != address(0));
        require(_approvedTokenRegistry != address(0));
        require(_payments != address(0));
        require(_networkBeneficiary != address(0));

        marketplaceSettings = IMarketplaceSettings(_marketplaceSettings);
        royaltyRegistry = IERC721CreatorRoyalty(_royaltyRegistry);
        royaltyEngine = IRoyaltyEngineV1(_royaltyEngine);
        superRareMarketplace = _superRareMarketplace;
        superRareAuctionHouse = _superRareAuctionHouse;
        spaceOperatorRegistry = ISpaceOperatorRegistry(_spaceOperatorRegistry);
        approvedTokenRegistry = IApprovedTokenRegistry(_approvedTokenRegistry);
        payments = IPayments(_payments);
        stakingRegistry = _stakingRegistry;
        networkBeneficiary = _networkBeneficiary;

        minimumBidIncreasePercentage = 10;
        maxAuctionLength = 7 days;
        auctionLengthExtension = 15 minutes;
        offerCancelationDelay = 5 minutes;

        __Ownable_init();
        __ReentrancyGuard_init();
    }

    /////////////////////////////////////////////////////////////////////////
    // Admin Functions
    /////////////////////////////////////////////////////////////////////////
    function setMarketplaceSettings(address _marketplaceSettings)
        external
        onlyOwner
    {
        require(_marketplaceSettings != address(0));
        marketplaceSettings = IMarketplaceSettings(_marketplaceSettings);
    }

    function setRoyaltyRegistry(address _royaltyRegistry) external onlyOwner {
        require(_royaltyRegistry != address(0));
        royaltyRegistry = IERC721CreatorRoyalty(_royaltyRegistry);
    }

    function setRoyaltyEngine(address _royaltyEngine) external onlyOwner {
        require(_royaltyEngine != address(0));
        royaltyEngine = IRoyaltyEngineV1(_royaltyEngine);
    }

    function setSuperRareMarketplace(address _superRareMarketplace)
        external
        onlyOwner
    {
        require(_superRareMarketplace != address(0));
        superRareMarketplace = _superRareMarketplace;
    }

    function setSuperRareAuctionHouse(address _superRareAuctionHouse)
        external
        onlyOwner
    {
        require(_superRareAuctionHouse != address(0));
        superRareAuctionHouse = _superRareAuctionHouse;
    }

    function setSpaceOperatorRegistry(address _spaceOperatorRegistry)
        external
        onlyOwner
    {
        require(_spaceOperatorRegistry != address(0));
        spaceOperatorRegistry = ISpaceOperatorRegistry(_spaceOperatorRegistry);
    }

    function setApprovedTokenRegistry(address _approvedTokenRegistry)
        external
        onlyOwner
    {
        require(_approvedTokenRegistry != address(0));
        approvedTokenRegistry = IApprovedTokenRegistry(_approvedTokenRegistry);
    }

    function setPayments(address _payments) external onlyOwner {
        require(_payments != address(0));
        payments = IPayments(_payments);
    }

    function setStakingRegistry(address _stakingRegistry) external onlyOwner {
        require(_stakingRegistry != address(0));
        stakingRegistry = _stakingRegistry;
    }

    function setNetworkBeneficiary(address _networkBeneficiary)
        external
        onlyOwner
    {
        require(_networkBeneficiary != address(0));
        networkBeneficiary = _networkBeneficiary;
    }

    function setMinimumBidIncreasePercentage(
        uint8 _minimumBidIncreasePercentage
    ) external onlyOwner {
        minimumBidIncreasePercentage = _minimumBidIncreasePercentage;
    }

    function setMaxAuctionLength(uint8 _maxAuctionLength) external onlyOwner {
        maxAuctionLength = _maxAuctionLength;
    }

    function setAuctionLengthExtension(uint256 _auctionLengthExtension)
        external
        onlyOwner
    {
        auctionLengthExtension = _auctionLengthExtension;
    }

    function setOfferCancelationDelay(uint256 _offerCancelationDelay)
        external
        onlyOwner
    {
        offerCancelationDelay = _offerCancelationDelay;
    }

    /////////////////////////////////////////////////////////////////////////
    // Marketplace Functions
    /////////////////////////////////////////////////////////////////////////

    /// @notice Place an offer for a given asset
    /// @dev Notice we need to verify that the msg sender has approved us to move funds on their behalf.
    /// @dev Covers use of any currency (0 address is eth).
    /// @dev _amount is the amount of the offer excluding the marketplace fee.
    /// @dev There can be multiple offers of different currencies, but only 1 per currency.
    /// @param _originContract Contract address of the asset being listed.
    /// @param _tokenId Token Id of the asset.
    /// @param _currencyAddress Address of the token being offered.
    /// @param _amount Amount being offered.
    /// @param _convertible If the offer can be converted into an auction
    function offer(
        address _originContract,
        uint256 _tokenId,
        address _currencyAddress,
        uint256 _amount,
        bool _convertible
    ) external payable override {
        (bool success, bytes memory data) = superRareMarketplace.delegatecall(
            abi.encodeWithSelector(
                this.offer.selector,
                _originContract,
                _tokenId,
                _currencyAddress,
                _amount,
                _convertible
            )
        );

        require(success, string(data));
    }

    /// @notice Purchases the token for the current sale price.
    /// @dev Covers use of any currency (0 address is eth).
    /// @dev Need to verify that the buyer (if not using eth) has the marketplace approved for _currencyContract.
    /// @dev Need to verify that the seller has the marketplace approved for _originContract.
    /// @param _originContract Contract address for asset being bought.
    /// @param _tokenId TokenId of asset being bought.
    /// @param _currencyAddress Currency address of asset being used to buy.
    /// @param _amount Amount the piece if being bought for (including marketplace fee).
    function buy(
        address _originContract,
        uint256 _tokenId,
        address _currencyAddress,
        uint256 _amount
    ) external payable override {
        (bool success, bytes memory data) = superRareMarketplace.delegatecall(
            abi.encodeWithSelector(
                this.buy.selector,
                _originContract,
                _tokenId,
                _currencyAddress,
                _amount
            )
        );

        require(success, string(data));
    }

    /// @notice Cancels an existing offer the sender has placed on a piece.
    /// @param _originContract Contract address of token.
    /// @param _tokenId TokenId that has an offer.
    /// @param _currencyAddress Currency address of the offer.
    function cancelOffer(
        address _originContract,
        uint256 _tokenId,
        address _currencyAddress
    ) external override {
        (bool success, bytes memory data) = superRareMarketplace.delegatecall(
            abi.encodeWithSelector(
                this.cancelOffer.selector,
                _originContract,
                _tokenId,
                _currencyAddress
            )
        );

        require(success, string(data));
    }

    /// @notice Sets a sale price for the given asset(s) directed at the _target address.
    /// @dev Covers use of any currency (0 address is eth).
    /// @dev Sale price for everyone is denoted as the 0 address.
    /// @dev Only 1 currency can be used for the sale price directed at a speicific target.
    /// @dev _listPrice of 0 signifies removing the list price for the provided currency.
    /// @dev This function can be used for counter offers as well.
    /// @param _originContract Contract address of the asset being listed.
    /// @param _tokenId Token Id of the asset.
    /// @param _currencyAddress Contract address of the currency asset is being listed for.
    /// @param _listPrice Amount of the currency the asset is being listed for (including all decimal points).
    /// @param _target Address of the person this sale price is target to.
    /// @param _splitAddresses Addresses to split the sellers commission with.
    /// @param _splitRatios The ratio for the split corresponding to each of the addresses being split with.
    function setSalePrice(
        address _originContract,
        uint256 _tokenId,
        address _currencyAddress,
        uint256 _listPrice,
        address _target,
        address payable[] calldata _splitAddresses,
        uint8[] calldata _splitRatios
    ) external override {
        (bool success, bytes memory data) = superRareMarketplace.delegatecall(
            abi.encodeWithSelector(
                this.setSalePrice.selector,
                _originContract,
                _tokenId,
                _currencyAddress,
                _listPrice,
                _target,
                _splitAddresses,
                _splitRatios
            )
        );

        require(success, string(data));
    }

    /// @notice Removes the current sale price of an asset for _target for the given currency.
    /// @dev Sale prices could still exist for different currencies.
    /// @dev Sale prices could still exist for different targets.
    /// @dev Zero address for _currency means that its listed in ether.
    /// @dev _target of zero address is the general sale price.
    /// @param _originContract The origin contract of the asset.
    /// @param _tokenId The tokenId of the asset within the _originContract.
    /// @param _target The address of the person
    function removeSalePrice(
        address _originContract,
        uint256 _tokenId,
        address _target
    ) external override {
        IERC721 erc721 = IERC721(_originContract);
        address tokenOwner = erc721.ownerOf(_tokenId);

        require(
            msg.sender == tokenOwner,
            "removeSalePrice::Must be tokenOwner."
        );

        delete tokenSalePrices[_originContract][_tokenId][_target];

        emit SetSalePrice(
            _originContract,
            address(0),
            address(0),
            0,
            _tokenId,
            new address payable[](0),
            new uint8[](0)
        );
    }

    /// @notice Accept an offer placed on _originContract : _tokenId.
    /// @dev Zero address for _currency means that the offer being accepted is in ether.
    /// @param _originContract Contract of the asset the offer was made on.
    /// @param _tokenId TokenId of the asset.
    /// @param _currencyAddress Address of the currency used for the offer.
    /// @param _amount Amount the offer was for/and is being accepted.
    /// @param _splitAddresses Addresses to split the sellers commission with.
    /// @param _splitRatios The ratio for the split corresponding to each of the addresses being split with.
    function acceptOffer(
        address _originContract,
        uint256 _tokenId,
        address _currencyAddress,
        uint256 _amount,
        address payable[] calldata _splitAddresses,
        uint8[] calldata _splitRatios
    ) external override {
        (bool success, bytes memory data) = superRareMarketplace.delegatecall(
            abi.encodeWithSelector(
                this.acceptOffer.selector,
                _originContract,
                _tokenId,
                _currencyAddress,
                _amount,
                _splitAddresses,
                _splitRatios
            )
        );

        require(success, string(data));
    }

    /////////////////////////////////////////////////////////////////////////
    // Auction House Functions
    /////////////////////////////////////////////////////////////////////////

    /// @notice Configures an Auction for a given asset.
    /// @dev If auction type is coldie (reserve) then _startingAmount cant be 0.
    /// @dev _currencyAddress equal to the zero address denotes eth.
    /// @dev All time related params are unix epoch timestamps.
    /// @param _auctionType The type of auction being configured.
    /// @param _originContract Contract address of the asset being put up for auction.
    /// @param _tokenId Token Id of the asset.
    /// @param _startingAmount The reserve price or min bid of an auction.
    /// @param _currencyAddress The currency the auction is being conducted in.
    /// @param _lengthOfAuction The amount of time in seconds that the auction is configured for.
    /// @param _splitAddresses Addresses to split the sellers commission with.
    /// @param _splitRatios The ratio for the split corresponding to each of the addresses being split with.
    function configureAuction(
        bytes32 _auctionType,
        address _originContract,
        uint256 _tokenId,
        uint256 _startingAmount,
        address _currencyAddress,
        uint256 _lengthOfAuction,
        uint256 _startTime,
        address payable[] calldata _splitAddresses,
        uint8[] calldata _splitRatios
    ) external override {
        (bool success, bytes memory data) = superRareAuctionHouse.delegatecall(
            abi.encodeWithSelector(
                this.configureAuction.selector,
                _auctionType,
                _originContract,
                _tokenId,
                _startingAmount,
                _currencyAddress,
                _lengthOfAuction,
                _startTime,
                _splitAddresses,
                _splitRatios
            )
        );

        require(success, string(data));
    }

    /// @notice Converts an offer into a coldie auction.
    /// @dev Covers use of any currency (0 address is eth).
    /// @dev Only covers converting an offer to a coldie auction.
    /// @dev Cant convert offer if an auction currently exists.
    /// @param _originContract Contract address of the asset.
    /// @param _tokenId Token Id of the asset.
    /// @param _currencyAddress Address of the currency being converted.
    /// @param _amount Amount being converted into an auction.
    /// @param _lengthOfAuction Number of seconds the auction will last.
    /// @param _splitAddresses Addresses that the sellers take in will be split amongst.
    /// @param _splitRatios Ratios that the take in will be split by.
    function convertOfferToAuction(
        address _originContract,
        uint256 _tokenId,
        address _currencyAddress,
        uint256 _amount,
        uint256 _lengthOfAuction,
        address payable[] calldata _splitAddresses,
        uint8[] calldata _splitRatios
    ) external override {
        (bool success, bytes memory data) = superRareAuctionHouse.delegatecall(
            abi.encodeWithSelector(
                this.convertOfferToAuction.selector,
                _originContract,
                _tokenId,
                _currencyAddress,
                _amount,
                _lengthOfAuction,
                _splitAddresses,
                _splitRatios
            )
        );

        require(success, string(data));
    }

    /// @notice Cancels a configured Auction that has not started.
    /// @dev Requires the person sending the message to be the auction creator or token owner.
    /// @param _originContract Contract address of the asset pending auction.
    /// @param _tokenId Token Id of the asset.
    function cancelAuction(address _originContract, uint256 _tokenId)
        external
        override
    {
        (bool success, bytes memory data) = superRareAuctionHouse.delegatecall(
            abi.encodeWithSelector(
                this.cancelAuction.selector,
                _originContract,
                _tokenId
            )
        );

        require(success, string(data));
    }

    /// @notice Places a bid on a valid auction.
    /// @dev Only the configured currency can be used (Zero address for eth)
    /// @param _originContract Contract address of asset being bid on.
    /// @param _tokenId Token Id of the asset.
    /// @param _currencyAddress Address of currency being used to bid.
    /// @param _amount Amount of the currency being used for the bid.
    function bid(
        address _originContract,
        uint256 _tokenId,
        address _currencyAddress,
        uint256 _amount
    ) external payable override {
        (bool success, bytes memory data) = superRareAuctionHouse.delegatecall(
            abi.encodeWithSelector(
                this.bid.selector,
                _originContract,
                _tokenId,
                _currencyAddress,
                _amount
            )
        );

        require(success, string(data));
    }

    /// @notice Settles an auction that has ended.
    /// @dev Anyone is able to settle an auction since non-input params are used.
    /// @param _originContract Contract address of asset.
    /// @param _tokenId Token Id of the asset.
    function settleAuction(address _originContract, uint256 _tokenId)
        external
        override
    {
        (bool success, bytes memory data) = superRareAuctionHouse.delegatecall(
            abi.encodeWithSelector(
                this.settleAuction.selector,
                _originContract,
                _tokenId
            )
        );

        require(success, string(data));
    }

    /// @notice Grabs the current auction details for a token.
    /// @param _originContract Contract address of asset.
    /// @param _tokenId Token Id of the asset.
    /** @return Auction Struct: creatorAddress, creationTime, startingTime, lengthOfAuction,
                currencyAddress, minimumBid, auctionType, splitRecipients array, and splitRatios array.
    */
    function getAuctionDetails(address _originContract, uint256 _tokenId)
        external
        view
        override
        returns (
            address,
            uint256,
            uint256,
            uint256,
            address,
            uint256,
            bytes32,
            address payable[] memory,
            uint8[] memory
        )
    {
        Auction memory auction = tokenAuctions[_originContract][_tokenId];

        return (
            auction.auctionCreator,
            auction.creationBlock,
            auction.startingTime,
            auction.lengthOfAuction,
            auction.currencyAddress,
            auction.minimumBid,
            auction.auctionType,
            auction.splitRecipients,
            auction.splitRatios
        );
    }

    function getSalePrice(
        address _originContract,
        uint256 _tokenId,
        address _target
    )
        external
        view
        override
        returns (
            address,
            address,
            uint256,
            address payable[] memory,
            uint8[] memory
        )
    {
        SalePrice memory sp = tokenSalePrices[_originContract][_tokenId][
            _target
        ];

        return (
            sp.seller,
            sp.currencyAddress,
            sp.amount,
            sp.splitRecipients,
            sp.splitRatios
        );
    }
}
ISuperRareBazaar.sol 196 lines
// SPDX-License-Identifier: MIT
pragma solidity 0.7.3;

/// @author koloz
/// @title ISuperRareBazaar
/// @notice Interface for the SuperRareBazaar Contract
interface ISuperRareBazaar {
    // Marketplace Functions
    // Buyer

    /// @notice Create an offer for a given asset
    /// @param _originContract Contract address of the asset being listed.
    /// @param _tokenId Token Id of the asset.
    /// @param _currencyAddress Address of the token being offered.
    /// @param _amount Amount being offered.
    /// @param _convertible If the offer can be converted into an auction
    function offer(
        address _originContract,
        uint256 _tokenId,
        address _currencyAddress,
        uint256 _amount,
        bool _convertible
    ) external payable;

    /// @notice Purchases the token for the current sale price.
    /// @param _originContract Contract address for asset being bought.
    /// @param _tokenId TokenId of asset being bought.
    /// @param _currencyAddress Currency address of asset being used to buy.
    /// @param _amount Amount the piece if being bought for.
    function buy(
        address _originContract,
        uint256 _tokenId,
        address _currencyAddress,
        uint256 _amount
    ) external payable;

    /// @notice Cancels an existing offer the sender has placed on a piece.
    /// @param _originContract Contract address of token.
    /// @param _tokenId TokenId that has an offer.
    /// @param _currencyAddress Currency address of the offer.
    function cancelOffer(
        address _originContract,
        uint256 _tokenId,
        address _currencyAddress
    ) external;

    // Seller

    /// @notice Sets a sale price for the given asset(s).
    /// @param _originContract Contract address of the asset being listed.
    /// @param _tokenId Token Id of the asset.
    /// @param _currencyAddress Contract address of the currency asset is being listed for.
    /// @param _listPrice Amount of the currency the asset is being listed for (including all decimal points).
    /// @param _target Address of the person this sale price is target to.
    /// @param _splitAddresses Addresses to split the sellers commission with.
    /// @param _splitRatios The ratio for the split corresponding to each of the addresses being split with.
    function setSalePrice(
        address _originContract,
        uint256 _tokenId,
        address _currencyAddress,
        uint256 _listPrice,
        address _target,
        address payable[] calldata _splitAddresses,
        uint8[] calldata _splitRatios
    ) external;

    /// @notice Removes the current sale price of an asset for the given currency.
    /// @param _originContract The origin contract of the asset.
    /// @param _tokenId The tokenId of the asset within the _originContract.
    /// @param _target The address of the person
    function removeSalePrice(
        address _originContract,
        uint256 _tokenId,
        address _target
    ) external;

    /// @notice Accept an offer placed on _originContract : _tokenId.
    /// @param _originContract Contract of the asset the offer was made on.
    /// @param _tokenId TokenId of the asset.
    /// @param _currencyAddress Address of the currency used for the offer.
    /// @param _amount Amount the offer was for/and is being accepted.
    /// @param _splitAddresses Addresses to split the sellers commission with.
    /// @param _splitRatios The ratio for the split corresponding to each of the addresses being split with.
    function acceptOffer(
        address _originContract,
        uint256 _tokenId,
        address _currencyAddress,
        uint256 _amount,
        address payable[] calldata _splitAddresses,
        uint8[] calldata _splitRatios
    ) external;

    // Auction House
    // Anyone

    /// @notice Settles an auction that has ended.
    /// @param _originContract Contract address of asset.
    /// @param _tokenId Token Id of the asset.
    function settleAuction(address _originContract, uint256 _tokenId) external;

    // Buyer

    /// @notice Places a bid on a valid auction.
    /// @param _originContract Contract address of asset being bid on.
    /// @param _tokenId Token Id of the asset.
    /// @param _currencyAddress Address of currency being used to bid.
    /// @param _amount Amount of the currency being used for the bid.
    function bid(
        address _originContract,
        uint256 _tokenId,
        address _currencyAddress,
        uint256 _amount
    ) external payable;

    // Seller

    /// @notice Configures an Auction for a given asset.
    /// @param _auctionType The type of auction being configured.
    /// @param _originContract Contract address of the asset being put up for auction.
    /// @param _tokenId Token Id of the asset.
    /// @param _startingAmount The reserve price or min bid of an auction.
    /// @param _currencyAddress The currency the auction is being conducted in.
    /// @param _lengthOfAuction The amount of time in seconds that the auction is configured for.
    /// @param _splitAddresses Addresses to split the sellers commission with.
    /// @param _splitRatios The ratio for the split corresponding to each of the addresses being split with.
    function configureAuction(
        bytes32 _auctionType,
        address _originContract,
        uint256 _tokenId,
        uint256 _startingAmount,
        address _currencyAddress,
        uint256 _lengthOfAuction,
        uint256 _startTime,
        address payable[] calldata _splitAddresses,
        uint8[] calldata _splitRatios
    ) external;

    /// @notice Cancels a configured Auction that has not started.
    /// @param _originContract Contract address of the asset pending auction.
    /// @param _tokenId Token Id of the asset.
    function cancelAuction(address _originContract, uint256 _tokenId) external;

    /// @notice Converts an offer into a coldie auction.
    /// @param _originContract Contract address of the asset.
    /// @param _tokenId Token Id of the asset.
    /// @param _currencyAddress Address of the currency being converted.
    /// @param _amount Amount being converted into an auction.
    /// @param _lengthOfAuction Number of seconds the auction will last.
    /// @param _splitAddresses Addresses that the sellers take in will be split amongst.
    /// @param _splitRatios Ratios that the take in will be split by.
    function convertOfferToAuction(
        address _originContract,
        uint256 _tokenId,
        address _currencyAddress,
        uint256 _amount,
        uint256 _lengthOfAuction,
        address payable[] calldata _splitAddresses,
        uint8[] calldata _splitRatios
    ) external;

    /// @notice Grabs the current auction details for a token.
    /// @param _originContract Contract address of asset.
    /// @param _tokenId Token Id of the asset.
    /** @return Auction Struct: creatorAddress, creationTime, startingTime, lengthOfAuction,
                currencyAddress, minimumBid, auctionType, splitRecipients array, and splitRatios array.
    */
    function getAuctionDetails(address _originContract, uint256 _tokenId)
        external
        view
        returns (
            address,
            uint256,
            uint256,
            uint256,
            address,
            uint256,
            bytes32,
            address payable[] calldata,
            uint8[] calldata
        );

    function getSalePrice(
        address _originContract,
        uint256 _tokenId,
        address _target
    )
        external
        view
        returns (
            address,
            address,
            uint256,
            address payable[] memory,
            uint8[] memory
        );
}
IRoyaltyEngine.sol 44 lines
// SPDX-License-Identifier: MIT
pragma solidity 0.7.3;

/// @author: manifold.xyz

/**
 * @dev Lookup engine interface
 */
interface IRoyaltyEngineV1 {
    /**
     * Get the royalty for a given token (address, id) and value amount.  Does not cache the bps/amounts.  Caches the spec for a given token address
     *
     * @param tokenAddress - The address of the token
     * @param tokenId      - The id of the token
     * @param value        - The value you wish to get the royalty of
     *
     * returns Two arrays of equal length, royalty recipients and the corresponding amount each recipient should get
     */
    function getRoyalty(
        address tokenAddress,
        uint256 tokenId,
        uint256 value
    )
        external
        returns (address payable[] memory recipients, uint256[] memory amounts);

    /**
     * View only version of getRoyalty
     *
     * @param tokenAddress - The address of the token
     * @param tokenId      - The id of the token
     * @param value        - The value you wish to get the royalty of
     *
     * returns Two arrays of equal length, royalty recipients and the corresponding amount each recipient should get
     */
    function getRoyaltyView(
        address tokenAddress,
        uint256 tokenId,
        uint256 value
    )
        external
        view
        returns (address payable[] memory recipients, uint256[] memory amounts);
}
IMarketplaceSettings.sol 96 lines
// SPDX-License-Identifier: MIT
pragma solidity 0.7.3;

/**
 * @title IMarketplaceSettings Settings governing a marketplace.
 */
interface IMarketplaceSettings {
    /////////////////////////////////////////////////////////////////////////
    // Marketplace Min and Max Values
    /////////////////////////////////////////////////////////////////////////
    /**
     * @dev Get the max value to be used with the marketplace.
     * @return uint256 wei value.
     */
    function getMarketplaceMaxValue() external view returns (uint256);

    /**
     * @dev Get the max value to be used with the marketplace.
     * @return uint256 wei value.
     */
    function getMarketplaceMinValue() external view returns (uint256);

    /////////////////////////////////////////////////////////////////////////
    // Marketplace Fee
    /////////////////////////////////////////////////////////////////////////
    /**
     * @dev Get the marketplace fee percentage.
     * @return uint8 wei fee.
     */
    function getMarketplaceFeePercentage() external view returns (uint8);

    /**
     * @dev Utility function for calculating the marketplace fee for given amount of wei.
     * @param _amount uint256 wei amount.
     * @return uint256 wei fee.
     */
    function calculateMarketplaceFee(uint256 _amount)
        external
        view
        returns (uint256);

    /////////////////////////////////////////////////////////////////////////
    // Primary Sale Fee
    /////////////////////////////////////////////////////////////////////////
    /**
     * @dev Get the primary sale fee percentage for a specific ERC721 contract.
     * @param _contractAddress address ERC721Contract address.
     * @return uint8 wei primary sale fee.
     */
    function getERC721ContractPrimarySaleFeePercentage(address _contractAddress)
        external
        view
        returns (uint8);

    /**
     * @dev Utility function for calculating the primary sale fee for given amount of wei
     * @param _contractAddress address ERC721Contract address.
     * @param _amount uint256 wei amount.
     * @return uint256 wei fee.
     */
    function calculatePrimarySaleFee(address _contractAddress, uint256 _amount)
        external
        view
        returns (uint256);

    /**
     * @dev Check whether the ERC721 token has sold at least once.
     * @param _contractAddress address ERC721Contract address.
     * @param _tokenId uint256 token ID.
     * @return bool of whether the token has sold.
     */
    function hasERC721TokenSold(address _contractAddress, uint256 _tokenId)
        external
        view
        returns (bool);

    /**
     * @dev Mark a token as sold.
     * Requirements:
     *
     * - `_contractAddress` cannot be the zero address.
     * @param _contractAddress address ERC721Contract address.
     * @param _tokenId uint256 token ID.
     * @param _hasSold bool of whether the token should be marked sold or not.
     */
    function markERC721Token(
        address _contractAddress,
        uint256 _tokenId,
        bool _hasSold
    ) external;

    function setERC721ContractPrimarySaleFeePercentage(
        address _contractAddress,
        uint8 _percentage
    ) external;
}
IERC721TokenCreator.sol 9 lines
// SPDX-License-Identifier: MIT
pragma solidity 0.7.3;

interface IERC721TokenCreator {
    function tokenCreator(address _contractAddress, uint256 _tokenId)
        external
        view
        returns (address payable);
}
SuperRareBazaarStorage.sol 231 lines
// SPDX-License-Identifier: MIT
pragma solidity 0.7.3;

import "../../marketplace/IMarketplaceSettings.sol";
import "../../royalty/creator/IERC721CreatorRoyalty.sol";
import "../../payments/IPayments.sol";
import "../../registry/spaces/ISpaceOperatorRegistry.sol";
import "../../registry/token/IApprovedTokenRegistry.sol";
import "../../royalty/creator/IRoyaltyEngine.sol";

/// @author koloz
/// @title SuperRareBazaar Storage Contract
/// @dev STORAGE CAN ONLY BE APPENDED NOT INSERTED OR MODIFIED
contract SuperRareBazaarStorage {
    /////////////////////////////////////////////////////////////////////////
    // Constants
    /////////////////////////////////////////////////////////////////////////

    // Auction Types
    bytes32 public constant COLDIE_AUCTION = "COLDIE_AUCTION";
    bytes32 public constant SCHEDULED_AUCTION = "SCHEDULED_AUCTION";
    bytes32 public constant NO_AUCTION = bytes32(0);

    /////////////////////////////////////////////////////////////////////////
    // Structs
    /////////////////////////////////////////////////////////////////////////

    // The Offer truct for a given token:
    // buyer - address of person making the offer
    // currencyAddress - address of the erc20 token used for an offer
    //                   or the zero address for eth
    // amount - offer in wei/full erc20 value
    // marketplaceFee - the amount that is taken by the network on offer acceptance.
    struct Offer {
        address payable buyer;
        uint256 amount;
        uint256 timestamp;
        uint8 marketplaceFee;
        bool convertible;
    }

    // The Sale Price struct for a given token:
    // seller - address of the person selling the token
    // currencyAddress - address of the erc20 token used for an offer
    //                   or the zero address for eth
    // amount - offer in wei/full erc20 value
    struct SalePrice {
        address payable seller;
        address currencyAddress;
        uint256 amount;
        address payable[] splitRecipients;
        uint8[] splitRatios;
    }

    // Structure of an Auction:
    // auctionCreator - creator of the auction
    // creationBlock - time that the auction was created/configured
    // startingBlock - time that the auction starts on
    // lengthOfAuction - how long the auction is
    // currencyAddress - address of the erc20 token used for an offer
    //                   or the zero address for eth
    // minimumBid - min amount a bidder can bid at the start of an auction.
    // auctionType - type of auction, represented as the formatted bytes 32 string
    struct Auction {
        address payable auctionCreator;
        uint256 creationBlock;
        uint256 startingTime;
        uint256 lengthOfAuction;
        address currencyAddress;
        uint256 minimumBid;
        bytes32 auctionType;
        address payable[] splitRecipients;
        uint8[] splitRatios;
    }

    struct Bid {
        address payable bidder;
        address currencyAddress;
        uint256 amount;
        uint8 marketplaceFee;
    }

    /////////////////////////////////////////////////////////////////////////
    // Events
    /////////////////////////////////////////////////////////////////////////
    event Sold(
        address indexed _originContract,
        address indexed _buyer,
        address indexed _seller,
        address _currencyAddress,
        uint256 _amount,
        uint256 _tokenId
    );

    event SetSalePrice(
        address indexed _originContract,
        address indexed _currencyAddress,
        address _target,
        uint256 _amount,
        uint256 _tokenId,
        address payable[] _splitRecipients,
        uint8[] _splitRatios
    );

    event OfferPlaced(
        address indexed _originContract,
        address indexed _bidder,
        address indexed _currencyAddress,
        uint256 _amount,
        uint256 _tokenId,
        bool _convertible
    );

    event AcceptOffer(
        address indexed _originContract,
        address indexed _bidder,
        address indexed _seller,
        address _currencyAddress,
        uint256 _amount,
        uint256 _tokenId,
        address payable[] _splitAddresses,
        uint8[] _splitRatios
    );

    event CancelOffer(
        address indexed _originContract,
        address indexed _bidder,
        address indexed _currencyAddress,
        uint256 _amount,
        uint256 _tokenId
    );

    event NewAuction(
        address indexed _contractAddress,
        uint256 indexed _tokenId,
        address indexed _auctionCreator,
        address _currencyAddress,
        uint256 _startingTime,
        uint256 _minimumBid,
        uint256 _lengthOfAuction
    );

    event CancelAuction(
        address indexed _contractAddress,
        uint256 indexed _tokenId,
        address indexed _auctionCreator
    );

    event AuctionBid(
        address indexed _contractAddress,
        address indexed _bidder,
        uint256 indexed _tokenId,
        address _currencyAddress,
        uint256 _amount,
        bool _startedAuction,
        uint256 _newAuctionLength,
        address _previousBidder
    );

    event AuctionSettled(
        address indexed _contractAddress,
        address indexed _bidder,
        address _seller,
        uint256 indexed _tokenId,
        address _currencyAddress,
        uint256 _amount
    );

    /////////////////////////////////////////////////////////////////////////
    // State Variables
    /////////////////////////////////////////////////////////////////////////

    // Current marketplace settings implementation to be used
    IMarketplaceSettings public marketplaceSettings;

    // Current creator royalty implementation to be used
    IERC721CreatorRoyalty public royaltyRegistry;

    // Address of the global royalty engine being used.
    IRoyaltyEngineV1 public royaltyEngine;

    // Current SuperRareMarketplace implementation to be used
    address public superRareMarketplace;

    // Current SuperRareAuctionHouse implementation to be used
    address public superRareAuctionHouse;

    // Current SpaceOperatorRegistry implementation to be used.
    ISpaceOperatorRegistry public spaceOperatorRegistry;

    // Current ApprovedTokenRegistry implementation being used for currencies.
    IApprovedTokenRegistry public approvedTokenRegistry;

    // Current payments contract to use
    IPayments public payments;

    // Address to be used for staking registry.
    address public stakingRegistry;

    // Address of the network beneficiary
    address public networkBeneficiary;

    // A minimum increase in bid amount when out bidding someone.
    uint8 public minimumBidIncreasePercentage; // 10 = 10%

    // Maximum length that an auction can be.
    uint256 public maxAuctionLength;

    // Extension length for an auction
    uint256 public auctionLengthExtension;

    // Offer cancellation delay
    uint256 public offerCancelationDelay;

    // Mapping from contract to mapping of tokenId to mapping of target to sale price.
    mapping(address => mapping(uint256 => mapping(address => SalePrice)))
        public tokenSalePrices;

    // Mapping from contract to mapping of tokenId to mapping of currency address to Current Offer.
    mapping(address => mapping(uint256 => mapping(address => Offer)))
        public tokenCurrentOffers;

    // Mapping from contract to mapping of tokenId to Auction.
    mapping(address => mapping(uint256 => Auction)) public tokenAuctions;

    // Mapping from contract to mapping of tokenId to Bid.
    mapping(address => mapping(uint256 => Bid)) public auctionBids;

    uint256[50] private __gap;
    /// ALL NEW STORAGE MUST COME AFTER THIS
}
IApprovedTokenRegistry.sol 24 lines
// SPDX-License-Identifier: MIT
pragma solidity 0.7.3;

interface IApprovedTokenRegistry {
    /// @notice Returns if a token has been approved or not.
    /// @param _tokenContract Contract of token being checked.
    /// @return True if the token is allowed, false otherwise.
    function isApprovedToken(address _tokenContract)
        external
        view
        returns (bool);

    /// @notice Adds a token to the list of approved tokens.
    /// @param _tokenContract Contract of token being approved.
    function addApprovedToken(address _tokenContract) external;

    /// @notice Removes a token from the approved tokens list.
    /// @param _tokenContract Contract of token being approved.
    function removeApprovedToken(address _tokenContract) external;

    /// @notice Sets whether all token contracts should be approved.
    /// @param _allTokensApproved Bool denoting if all tokens should be approved.
    function setAllTokensApproved(bool _allTokensApproved) external;
}
IERC721CreatorRoyalty.sol 43 lines
// SPDX-License-Identifier: MIT
pragma solidity 0.7.3;

import "../../token/ERC721/IERC721TokenCreator.sol";

/**
 * @title IERC721CreatorRoyalty Token level royalty interface.
 */
interface IERC721CreatorRoyalty is IERC721TokenCreator {
    /**
     * @dev Get the royalty fee percentage for a specific ERC721 contract.
     * @param _contractAddress address ERC721Contract address.
     * @param _tokenId uint256 token ID.
     * @return uint8 wei royalty fee.
     */
    function getERC721TokenRoyaltyPercentage(
        address _contractAddress,
        uint256 _tokenId
    ) external view returns (uint8);

    /**
     * @dev Utililty function to calculate the royalty fee for a token.
     * @param _contractAddress address ERC721Contract address.
     * @param _tokenId uint256 token ID.
     * @param _amount uint256 wei amount.
     * @return uint256 wei fee.
     */
    function calculateRoyaltyFee(
        address _contractAddress,
        uint256 _tokenId,
        uint256 _amount
    ) external view returns (uint256);

    /**
     * @dev Utililty function to set the royalty percentage for a specific ERC721 contract.
     * @param _contractAddress address ERC721Contract address.
     * @param _percentage percentage for royalty
     */
    function setPercentageForSetERC721ContractRoyalty(
        address _contractAddress,
        uint8 _percentage
    ) external;
}
ISpaceOperatorRegistry.sol 23 lines
// SPDX-License-Identifier: MIT
pragma solidity 0.7.3;

/// @author koloz
/// @title ISpaceOperatorRegistry
/// @notice The interface for the SpaceOperatorRegistry
interface ISpaceOperatorRegistry {
    function getPlatformCommission(address _operator)
        external
        view
        returns (uint8);

    function setPlatformCommission(address _operator, uint8 _commission)
        external;

    function isApprovedSpaceOperator(address _operator)
        external
        view
        returns (bool);

    function setSpaceOperatorApproved(address _operator, bool _approved)
        external;
}
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;
}
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);
}
Initializable.sol 55 lines
// SPDX-License-Identifier: MIT

// solhint-disable-next-line compiler-version
pragma solidity >=0.4.24 <0.8.0;

import "../utils/AddressUpgradeable.sol";

/**
 * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed
 * behind a proxy. Since a proxied contract can't have a constructor, it's common to move constructor logic to an
 * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer
 * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.
 *
 * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as
 * possible by providing the encoded function call as the `_data` argument to {UpgradeableProxy-constructor}.
 *
 * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure
 * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.
 */
abstract contract Initializable {

    /**
     * @dev Indicates that the contract has been initialized.
     */
    bool private _initialized;

    /**
     * @dev Indicates that the contract is in the process of being initialized.
     */
    bool private _initializing;

    /**
     * @dev Modifier to protect an initializer function from being invoked twice.
     */
    modifier initializer() {
        require(_initializing || _isConstructor() || !_initialized, "Initializable: contract is already initialized");

        bool isTopLevelCall = !_initializing;
        if (isTopLevelCall) {
            _initializing = true;
            _initialized = true;
        }

        _;

        if (isTopLevelCall) {
            _initializing = false;
        }
    }

    /// @dev Returns true if and only if the function is running in the constructor
    function _isConstructor() private view returns (bool) {
        return !AddressUpgradeable.isContract(address(this));
    }
}
AddressUpgradeable.sol 165 lines
// SPDX-License-Identifier: MIT

pragma solidity ^0.7.0;

/**
 * @dev Collection of functions related to the address type
 */
library AddressUpgradeable {
    /**
     * @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);
    }

    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);
            }
        }
    }
}
ContextUpgradeable.sol 32 lines
// SPDX-License-Identifier: MIT

pragma solidity >=0.6.0 <0.8.0;
import "../proxy/Initializable.sol";

/*
 * @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 ContextUpgradeable is Initializable {
    function __Context_init() internal initializer {
        __Context_init_unchained();
    }

    function __Context_init_unchained() internal initializer {
    }
    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;
    }
    uint256[50] private __gap;
}
OwnableUpgradeable.sol 75 lines
// SPDX-License-Identifier: MIT

pragma solidity ^0.7.0;

import "../utils/ContextUpgradeable.sol";
import "../proxy/Initializable.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 OwnableUpgradeable is Initializable, ContextUpgradeable {
    address private _owner;

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

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    function __Ownable_init() internal initializer {
        __Context_init_unchained();
        __Ownable_init_unchained();
    }

    function __Ownable_init_unchained() internal initializer {
        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;
    }
    uint256[49] private __gap;
}
ReentrancyGuardUpgradeable.sol 68 lines
// SPDX-License-Identifier: MIT

pragma solidity ^0.7.0;
import "../proxy/Initializable.sol";

/**
 * @dev Contract module that helps prevent reentrant calls to a function.
 *
 * Inheriting from `ReentrancyGuard` will make the {nonReentrant} modifier
 * available, which can be applied to functions to make sure there are no nested
 * (reentrant) calls to them.
 *
 * Note that because there is a single `nonReentrant` guard, functions marked as
 * `nonReentrant` may not call one another. This can be worked around by making
 * those functions `private`, and then adding `external` `nonReentrant` entry
 * points to them.
 *
 * TIP: If you would like to learn more about reentrancy and alternative ways
 * to protect against it, check out our blog post
 * https://blog.openzeppelin.com/reentrancy-after-istanbul/[Reentrancy After Istanbul].
 */
abstract contract ReentrancyGuardUpgradeable is Initializable {
    // Booleans are more expensive than uint256 or any type that takes up a full
    // word because each write operation emits an extra SLOAD to first read the
    // slot's contents, replace the bits taken up by the boolean, and then write
    // back. This is the compiler's defense against contract upgrades and
    // pointer aliasing, and it cannot be disabled.

    // The values being non-zero value makes deployment a bit more expensive,
    // but in exchange the refund on every call to nonReentrant will be lower in
    // amount. Since refunds are capped to a percentage of the total
    // transaction's gas, it is best to keep them low in cases like this one, to
    // increase the likelihood of the full refund coming into effect.
    uint256 private constant _NOT_ENTERED = 1;
    uint256 private constant _ENTERED = 2;

    uint256 private _status;

    function __ReentrancyGuard_init() internal initializer {
        __ReentrancyGuard_init_unchained();
    }

    function __ReentrancyGuard_init_unchained() internal initializer {
        _status = _NOT_ENTERED;
    }

    /**
     * @dev Prevents a contract from calling itself, directly or indirectly.
     * Calling a `nonReentrant` function from another `nonReentrant`
     * function is not supported. It is possible to prevent this from happening
     * by making the `nonReentrant` function external, and make it call a
     * `private` function that does the actual work.
     */
    modifier nonReentrant() {
        // On the first call to nonReentrant, _notEntered will be true
        require(_status != _ENTERED, "ReentrancyGuard: reentrant call");

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

        _;

        // By storing the original value once again, a refund is triggered (see
        // https://eips.ethereum.org/EIPS/eip-2200)
        _status = _NOT_ENTERED;
    }
    uint256[49] private __gap;
}

Read Contract

COLDIE_AUCTION 0xc90b8714 → bytes32
NO_AUCTION 0x155a56b1 → bytes32
SCHEDULED_AUCTION 0xb23afc26 → bytes32
approvedTokenRegistry 0x6240cd1c → address
auctionBids 0x299a0e1e → address, address, uint256, uint8
auctionLengthExtension 0xdaa26499 → uint256
getAuctionDetails 0x0cd87c68 → address, uint256, uint256, uint256, address, uint256, bytes32, address[], uint8[]
getSalePrice 0x369679a4 → address, address, uint256, address[], uint8[]
marketplaceSettings 0xba50b632 → address
maxAuctionLength 0x0e519ef9 → uint256
minimumBidIncreasePercentage 0x6fe9f44c → uint8
networkBeneficiary 0x6b534ed0 → address
offerCancelationDelay 0x0a5c4ed5 → uint256
owner 0x8da5cb5b → address
payments 0xa6d23e10 → address
royaltyEngine 0x4c94c90c → address
royaltyRegistry 0xa11b0712 → address
spaceOperatorRegistry 0x0bcba09d → address
stakingRegistry 0x009d9aa9 → address
superRareAuctionHouse 0x3bc3d9be → address
superRareMarketplace 0x0141c590 → address
tokenAuctions 0xc47c35c1 → address, uint256, uint256, uint256, address, uint256, bytes32
tokenCurrentOffers 0x2c419053 → address, uint256, uint256, uint8, bool
tokenSalePrices 0x1a2ac30f → address, address, uint256

Write Contract 28 functions

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

acceptOffer 0x534665e9
address _originContract
uint256 _tokenId
address _currencyAddress
uint256 _amount
address[] _splitAddresses
uint8[] _splitRatios
bid 0xb5678588
address _originContract
uint256 _tokenId
address _currencyAddress
uint256 _amount
buy 0xb3ffb760
address _originContract
uint256 _tokenId
address _currencyAddress
uint256 _amount
cancelAuction 0x859b97fe
address _originContract
uint256 _tokenId
cancelOffer 0xe92f94d1
address _originContract
uint256 _tokenId
address _currencyAddress
configureAuction 0x9041a0ec
bytes32 _auctionType
address _originContract
uint256 _tokenId
uint256 _startingAmount
address _currencyAddress
uint256 _lengthOfAuction
uint256 _startTime
address[] _splitAddresses
uint8[] _splitRatios
convertOfferToAuction 0x060d9eeb
address _originContract
uint256 _tokenId
address _currencyAddress
uint256 _amount
uint256 _lengthOfAuction
address[] _splitAddresses
uint8[] _splitRatios
initialize 0xc306b378
address _marketplaceSettings
address _royaltyRegistry
address _royaltyEngine
address _superRareMarketplace
address _superRareAuctionHouse
address _spaceOperatorRegistry
address _approvedTokenRegistry
address _payments
address _stakingRegistry
address _networkBeneficiary
offer 0x0f2b2532
address _originContract
uint256 _tokenId
address _currencyAddress
uint256 _amount
bool _convertible
removeSalePrice 0xf7cfaad0
address _originContract
uint256 _tokenId
address _target
renounceOwnership 0x715018a6
No parameters
setApprovedTokenRegistry 0xe4e87e3b
address _approvedTokenRegistry
setAuctionLengthExtension 0x10f79789
uint256 _auctionLengthExtension
setMarketplaceSettings 0x176ab440
address _marketplaceSettings
setMaxAuctionLength 0xdce96bf5
uint8 _maxAuctionLength
setMinimumBidIncreasePercentage 0x48626b90
uint8 _minimumBidIncreasePercentage
setNetworkBeneficiary 0x3492e5a8
address _networkBeneficiary
setOfferCancelationDelay 0x7a544792
uint256 _offerCancelationDelay
setPayments 0xaf231a58
address _payments
setRoyaltyEngine 0x21ede032
address _royaltyEngine
setRoyaltyRegistry 0x84a608e2
address _royaltyRegistry
setSalePrice 0xc8f94f4e
address _originContract
uint256 _tokenId
address _currencyAddress
uint256 _listPrice
address _target
address[] _splitAddresses
uint8[] _splitRatios
setSpaceOperatorRegistry 0x7f358230
address _spaceOperatorRegistry
setStakingRegistry 0x2c740844
address _stakingRegistry
setSuperRareAuctionHouse 0x2a2a326c
address _superRareAuctionHouse
setSuperRareMarketplace 0x9c883af2
address _superRareMarketplace
settleAuction 0x5138b08c
address _originContract
uint256 _tokenId
transferOwnership 0xf2fde38b
address newOwner

Top Interactions

AddressTxnsSentReceived
0x006D85f6...dB39 5 5

Recent Transactions

CSV
|
Hash Method Block Age From/To Value Txn Fee Type
0x9f2a02d2...0577b5 Fail 0x9041a0ec 24,414,299 IN 0x006D85f6...dB39 0 ETH EIP-1559
0x4602238f...a9741d 0x9041a0ec 24,414,298 IN 0x006D85f6...dB39 0 ETH EIP-1559
0x4d19703a...32bb98 0x859b97fe 24,414,250 IN 0x006D85f6...dB39 0 ETH EIP-1559
0x0de60d78...dcd886 0x9041a0ec 24,414,247 IN 0x006D85f6...dB39 0 ETH EIP-1559
0x6d3c4529...f0d50a 0x859b97fe 24,414,241 IN 0x006D85f6...dB39 0 ETH EIP-1559