Address Contract Verified
Address
0x6D7c44773C52D396F43c2D511B81aa168E9a7a42
Balance
203.7011 ETH
Nonce
1
Code Size
14509 bytes
Creator
0x0bbF6fbB...b22F at tx 0xcbaa7460...a7ffbe
Indexed Transactions
5 (24,414,241 → 24,414,299)
Gas Used (indexed)
899,214
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
| Address | Txns | Sent | Received |
|---|---|---|---|
| 0x006D85f6...dB39 | 5 | 5 |
Token Balances (2)
View Transfers →Recent Transactions
|
| Hash | Block | Age | From/To | Value | |
|---|---|---|---|---|---|
| 0x9f2a02d2...0577b5 Fail | 24,414,299 | IN | 0x006D85f6...dB39 | 0 ETH | |
| 0x4602238f...a9741d | 24,414,298 | IN | 0x006D85f6...dB39 | 0 ETH | |
| 0x4d19703a...32bb98 | 24,414,250 | IN | 0x006D85f6...dB39 | 0 ETH | |
| 0x0de60d78...dcd886 | 24,414,247 | IN | 0x006D85f6...dB39 | 0 ETH | |
| 0x6d3c4529...f0d50a | 24,414,241 | IN | 0x006D85f6...dB39 | 0 ETH |