Address Contract Partially Verified
Address
0x4dBFEBcff4ee03d80510494525EB16D2DA331bE8
Balance
0 ETH
Nonce
1
Code Size
11151 bytes
Creator
0xBC3fC851...BecB at tx 0x2645a239...bbda7c
Indexed Transactions
0
Contract Bytecode
11151 bytes
0x6080604052600436106102045760003560e01c8063720093e411610118578063b88d4fde116100a0578063e8376eb01161006f578063e8376eb01461060b578063e8a3d4851461061e578063e8cdea1114610633578063e985e9c514610653578063f2fde38b1461067357600080fd5b8063b88d4fde1461058b578063c87b56dd146105ab578063ccb4807b146105cb578063d547741f146105eb57600080fd5b806391d14854116100e757806391d148541461050157806395d89b4114610521578063a0bcfc7f14610536578063a217fddf14610556578063a22cb4651461056b57600080fd5b8063720093e4146104835780637836a925146104a35780638042853f146104c35780638da5cb5b146104e357600080fd5b80632f2ff15d1161019b5780636352211e1161016a5780636352211e146103ee57806365af37981461040e5780636ce3f6871461042e57806370a082311461044e578063715018a61461046e57600080fd5b80632f2ff15d1461035a57806336568abe1461037a57806337754d9a1461039a57806342842e0e146103ce57600080fd5b8063095ea7b3116101d7578063095ea7b3146102ba57806323b872dd146102da578063248a9ca3146102fa57806326232a2e1461033857600080fd5b806301ffc9a714610209578063068da6571461023e57806306fdde0314610260578063081812fc14610282575b600080fd5b34801561021557600080fd5b506102296102243660046125ec565b610693565b60405190151581526020015b60405180910390f35b34801561024a57600080fd5b5061025e61025936600461248d565b6106a4565b005b34801561026c57600080fd5b5061027561078c565b604051610235919061280a565b34801561028e57600080fd5b506102a261029d3660046125ae565b61081e565b6040516001600160a01b039091168152602001610235565b3480156102c657600080fd5b5061025e6102d5366004612582565b6108a6565b3480156102e657600080fd5b5061025e6102f53660046123cc565b6109b7565b34801561030657600080fd5b5061032a6103153660046125ae565b60009081526008602052604090206001015490565b604051908152602001610235565b34801561034457600080fd5b50600b5460405160ff9091168152602001610235565b34801561036657600080fd5b5061025e6103753660046125c7565b6109e8565b34801561038657600080fd5b5061025e6103953660046125c7565b610a0e565b3480156103a657600080fd5b5061032a7f413b964388ffbef8da45753e2ce53bd2bcc66055e28876253fbd02817f2b316581565b3480156103da57600080fd5b5061025e6103e93660046123cc565b610a8c565b3480156103fa57600080fd5b506102a26104093660046125ae565b610aa7565b34801561041a57600080fd5b5061025e61042936600461268c565b610b1e565b34801561043a57600080fd5b5061032a6104493660046125ae565b610b60565b34801561045a57600080fd5b5061032a610469366004612376565b610bc5565b34801561047a57600080fd5b5061025e610c4c565b34801561048f57600080fd5b5061025e61049e366004612582565b610c82565b3480156104af57600080fd5b5061025e6104be3660046126ae565b610d5c565b3480156104cf57600080fd5b5061025e6104de3660046126da565b610ede565b3480156104ef57600080fd5b506007546001600160a01b03166102a2565b34801561050d57600080fd5b5061022961051c3660046125c7565b610f1e565b34801561052d57600080fd5b50610275610f49565b34801561054257600080fd5b5061025e610551366004612643565b610f58565b34801561056257600080fd5b5061032a600081565b34801561057757600080fd5b5061025e61058636600461254f565b610f95565b34801561059757600080fd5b5061025e6105a636600461240d565b61105a565b3480156105b757600080fd5b506102756105c63660046125ae565b611092565b3480156105d757600080fd5b5061025e6105e6366004612643565b6111fc565b3480156105f757600080fd5b5061025e6106063660046125c7565b611239565b61025e6106193660046125ae565b61125f565b34801561062a57600080fd5b50610275611456565b34801561063f57600080fd5b5061025e61064e3660046125ae565b611465565b34801561065f57600080fd5b5061022961066e366004612393565b6114f6565b34801561067f57600080fd5b5061025e61068e366004612376565b6115a3565b600061069e8261163e565b92915050565b6007546001600160a01b031633146106d75760405162461bcd60e51b81526004016106ce9061289d565b60405180910390fd5b60005b8151811015610787576107058282815181106106f8576106f8612b02565b6020026020010151611663565b156107525760405162461bcd60e51b815260206004820152601f60248201527f436f6d70616e792068617320616c7265616479206265656e206d696e7465640060448201526064016106ce565b6107758383838151811061076857610768612b02565b6020026020010151611680565b8061077f81612aa7565b9150506106da565b505050565b60606000805461079b90612a6c565b80601f01602080910402602001604051908101604052809291908181526020018280546107c790612a6c565b80156108145780601f106107e957610100808354040283529160200191610814565b820191906000526020600020905b8154815290600101906020018083116107f757829003601f168201915b5050505050905090565b600061082982611663565b61088a5760405162461bcd60e51b815260206004820152602c60248201527f4552433732313a20617070726f76656420717565727920666f72206e6f6e657860448201526b34b9ba32b73a103a37b5b2b760a11b60648201526084016106ce565b506000908152600460205260409020546001600160a01b031690565b60006108b182610aa7565b9050806001600160a01b0316836001600160a01b0316141561091f5760405162461bcd60e51b815260206004820152602160248201527f4552433732313a20617070726f76616c20746f2063757272656e74206f776e656044820152603960f91b60648201526084016106ce565b336001600160a01b038216148061093b575061093b81336114f6565b6109ad5760405162461bcd60e51b815260206004820152603860248201527f4552433732313a20617070726f76652063616c6c6572206973206e6f74206f7760448201527f6e6572206e6f7220617070726f76656420666f7220616c6c000000000000000060648201526084016106ce565b61078783836117bf565b6109c1338261182d565b6109dd5760405162461bcd60e51b81526004016106ce90612917565b6107878383836118ef565b600082815260086020526040902060010154610a048133611a9a565b6107878383611afe565b6001600160a01b0381163314610a7e5760405162461bcd60e51b815260206004820152602f60248201527f416363657373436f6e74726f6c3a2063616e206f6e6c792072656e6f756e636560448201526e103937b632b9903337b91039b2b63360891b60648201526084016106ce565b610a888282611b84565b5050565b6107878383836040518060200160405280600081525061105a565b6000818152600260205260408120546001600160a01b03168061069e5760405162461bcd60e51b815260206004820152602960248201527f4552433732313a206f776e657220717565727920666f72206e6f6e657869737460448201526832b73a103a37b5b2b760b91b60648201526084016106ce565b33610b2883610aa7565b6001600160a01b031614610b4e5760405162461bcd60e51b81526004016106ce906128d2565b6000918252600c602052604090912055565b6000610b6b82611663565b610b875760405162461bcd60e51b81526004016106ce9061286f565b6000828152600c6020526040902054610bb25760405162461bcd60e51b81526004016106ce90612968565b506000908152600c602052604090205490565b60006001600160a01b038216610c305760405162461bcd60e51b815260206004820152602a60248201527f4552433732313a2062616c616e636520717565727920666f7220746865207a65604482015269726f206164647265737360b01b60648201526084016106ce565b506001600160a01b031660009081526003602052604090205490565b6007546001600160a01b03163314610c765760405162461bcd60e51b81526004016106ce9061289d565b610c806000611beb565b565b610cac7f413b964388ffbef8da45753e2ce53bd2bcc66055e28876253fbd02817f2b316533610f1e565b80610cbd5750610cbd600033610f1e565b610cfc5760405162461bcd60e51b815260206004820152601060248201526f20b1b1b2b9b9903337b93134b23232b760811b60448201526064016106ce565b610d0581611663565b15610d525760405162461bcd60e51b815260206004820152601f60248201527f436f6d70616e792068617320616c7265616479206265656e206d696e7465640060448201526064016106ce565b610a888282611680565b610d6583611663565b8015610d755750610d7582611663565b610dcd5760405162461bcd60e51b8152602060048201526024808201527f4f6e65206f662074686520636f6d70616e69657320646f6573206e6f7420657860448201526334b9ba1760e11b60648201526084016106ce565b33610dd784610aa7565b6001600160a01b0316148015610dfd575033610df283610aa7565b6001600160a01b0316145b610e5b5760405162461bcd60e51b815260206004820152602960248201527f596f7520617265206e6f74206f776e6572206f66206f6e65206f662074686520604482015268636f6d70616e69657360b81b60648201526084016106ce565b610e6481611663565b15610ec25760405162461bcd60e51b815260206004820152602860248201527f436f6d70616e792077697468206e657720746f6b656e20494420616c72656164604482015267792065786973747360c01b60648201526084016106ce565b610ecb83611c3d565b610ed482611c3d565b6107873382611680565b6007546001600160a01b03163314610f085760405162461bcd60e51b81526004016106ce9061289d565b600b805460ff191660ff92909216919091179055565b60009182526008602090815260408084206001600160a01b0393909316845291905290205460ff1690565b60606001805461079b90612a6c565b6007546001600160a01b03163314610f825760405162461bcd60e51b81526004016106ce9061289d565b8051610a8890600a90602084019061224f565b6001600160a01b038216331415610fee5760405162461bcd60e51b815260206004820152601960248201527f4552433732313a20617070726f766520746f2063616c6c65720000000000000060448201526064016106ce565b3360008181526005602090815260408083206001600160a01b03871680855290835292819020805460ff191686151590811790915590519081529192917f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31910160405180910390a35050565b611064338361182d565b6110805760405162461bcd60e51b81526004016106ce90612917565b61108c84848484611c7d565b50505050565b606061109d82611663565b6111035760405162461bcd60e51b815260206004820152603160248201527f45524337323155524953746f726167653a2055524920717565727920666f72206044820152703737b732bc34b9ba32b73a103a37b5b2b760791b60648201526084016106ce565b6000828152600660205260408120805461111c90612a6c565b80601f016020809104026020016040519081016040528092919081815260200182805461114890612a6c565b80156111955780601f1061116a57610100808354040283529160200191611195565b820191906000526020600020905b81548152906001019060200180831161117857829003601f168201915b5050505050905060006111a6611cb0565b90508051600014156111b9575092915050565b8151156111eb5780826040516020016111d3929190612729565b60405160208183030381529060405292505050919050565b6111f484611cbf565b949350505050565b6007546001600160a01b031633146112265760405162461bcd60e51b81526004016106ce9061289d565b8051610a8890600990602084019061224f565b6000828152600860205260409020600101546112558133611a9a565b6107878383611b84565b61126881611663565b6112845760405162461bcd60e51b81526004016106ce9061286f565b6000818152600c60205260409020546112af5760405162461bcd60e51b81526004016106ce90612968565b6000818152600c6020526040902054341461132b5760405162461bcd60e51b815260206004820152603660248201527f506c656173652070726f766964652073756666696369656e742045544820746f604482015275207075726368617365207468697320636f6d70616e7960501b60648201526084016106ce565b600b546000906064906113419060ff16346129f3565b61134b91906129df565b905061135f6007546001600160a01b031690565b6001600160a01b03166108fc829081150290604051600060405180830381858888f19350505050158015611397573d6000803e3d6000fd5b506113a182610aa7565b6001600160a01b03166108fc6113b78334612a12565b6040518115909202916000818181858888f193505050501580156113df573d6000803e3d6000fd5b506113f36113ec83610aa7565b33846118ef565b7fa831d161ab34fd077c450edfeeac91cd8cc4e1d8a3b07930cf05bf9c0a23d83e8261141e84610aa7565b604080519283526001600160a01b03919091166020830152338282015234606083015260808201849052519081900360a00190a15050565b60606009805461079b90612a6c565b61146e81611663565b61148a5760405162461bcd60e51b81526004016106ce9061286f565b6000818152600c60205260409020546114b55760405162461bcd60e51b81526004016106ce90612968565b336114bf82610aa7565b6001600160a01b0316146114e55760405162461bcd60e51b81526004016106ce906128d2565b6000908152600c6020526040812055565b600b5460405163c455279160e01b81526001600160a01b038481166004830152600092610100900481169190841690829063c45527919060240160206040518083038186803b15801561154857600080fd5b505afa15801561155c573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906115809190612626565b6001600160a01b0316141561159957600191505061069e565b6111f484846114f6565b6007546001600160a01b031633146115cd5760405162461bcd60e51b81526004016106ce9061289d565b6001600160a01b0381166116325760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016106ce565b61163b81611beb565b50565b60006001600160e01b03198216637965db0b60e01b148061069e575061069e82611d8a565b6000908152600260205260409020546001600160a01b0316151590565b6001600160a01b0382166116d65760405162461bcd60e51b815260206004820181905260248201527f4552433732313a206d696e7420746f20746865207a65726f206164647265737360448201526064016106ce565b6116df81611663565b1561172c5760405162461bcd60e51b815260206004820152601c60248201527f4552433732313a20746f6b656e20616c7265616479206d696e7465640000000060448201526064016106ce565b61173860008383611dda565b6001600160a01b03821660009081526003602052604081208054600192906117619084906129c7565b909155505060008181526002602052604080822080546001600160a01b0319166001600160a01b03861690811790915590518392907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908290a45050565b600081815260046020526040902080546001600160a01b0319166001600160a01b03841690811790915581906117f482610aa7565b6001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92560405160405180910390a45050565b600061183882611663565b6118995760405162461bcd60e51b815260206004820152602c60248201527f4552433732313a206f70657261746f7220717565727920666f72206e6f6e657860448201526b34b9ba32b73a103a37b5b2b760a11b60648201526084016106ce565b60006118a483610aa7565b9050806001600160a01b0316846001600160a01b031614806118df5750836001600160a01b03166118d48461081e565b6001600160a01b0316145b806111f457506111f481856114f6565b826001600160a01b031661190282610aa7565b6001600160a01b03161461196a5760405162461bcd60e51b815260206004820152602960248201527f4552433732313a207472616e73666572206f6620746f6b656e2074686174206960448201526839903737ba1037bbb760b91b60648201526084016106ce565b6001600160a01b0382166119cc5760405162461bcd60e51b8152602060048201526024808201527f4552433732313a207472616e7366657220746f20746865207a65726f206164646044820152637265737360e01b60648201526084016106ce565b6119d7838383611dda565b6119e26000826117bf565b6001600160a01b0383166000908152600360205260408120805460019290611a0b908490612a12565b90915550506001600160a01b0382166000908152600360205260408120805460019290611a399084906129c7565b909155505060008181526002602052604080822080546001600160a01b0319166001600160a01b0386811691821790925591518493918716917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef91a4505050565b611aa48282610f1e565b610a8857611abc816001600160a01b03166014611e01565b611ac7836020611e01565b604051602001611ad8929190612758565b60408051601f198184030181529082905262461bcd60e51b82526106ce9160040161280a565b611b088282610f1e565b610a885760008281526008602090815260408083206001600160a01b03851684529091529020805460ff19166001179055611b403390565b6001600160a01b0316816001600160a01b0316837f2f8788117e7eff1d82e926ec794901d17c78024a50270940304540a733656f0d60405160405180910390a45050565b611b8e8282610f1e565b15610a885760008281526008602090815260408083206001600160a01b0385168085529252808320805460ff1916905551339285917ff6391f5c32d9c69d2a47ea670b442974b53935d1edc7fd64eb21e047a839171b9190a45050565b600780546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b611c4681611f9d565b60008181526006602052604090208054611c5f90612a6c565b15905061163b57600081815260066020526040812061163b916122d3565b611c888484846118ef565b611c9484848484612044565b61108c5760405162461bcd60e51b81526004016106ce9061281d565b6060600a805461079b90612a6c565b6060611cca82611663565b611d2e5760405162461bcd60e51b815260206004820152602f60248201527f4552433732314d657461646174613a2055524920717565727920666f72206e6f60448201526e3732bc34b9ba32b73a103a37b5b2b760891b60648201526084016106ce565b6000611d38611cb0565b90506000815111611d585760405180602001604052806000815250611d83565b80611d6284612151565b604051602001611d73929190612729565b6040516020818303038152906040525b9392505050565b60006001600160e01b031982166380ac58cd60e01b1480611dbb57506001600160e01b03198216635b5e139f60e01b145b8061069e57506301ffc9a760e01b6001600160e01b031983161461069e565b6000818152600c602052604090205415610787576000908152600c60205260408120555050565b60606000611e108360026129f3565b611e1b9060026129c7565b67ffffffffffffffff811115611e3357611e33612b18565b6040519080825280601f01601f191660200182016040528015611e5d576020820181803683370190505b509050600360fc1b81600081518110611e7857611e78612b02565b60200101906001600160f81b031916908160001a905350600f60fb1b81600181518110611ea757611ea7612b02565b60200101906001600160f81b031916908160001a9053506000611ecb8460026129f3565b611ed69060016129c7565b90505b6001811115611f4e576f181899199a1a9b1b9c1cb0b131b232b360811b85600f1660108110611f0a57611f0a612b02565b1a60f81b828281518110611f2057611f20612b02565b60200101906001600160f81b031916908160001a90535060049490941c93611f4781612a55565b9050611ed9565b508315611d835760405162461bcd60e51b815260206004820181905260248201527f537472696e67733a20686578206c656e67746820696e73756666696369656e7460448201526064016106ce565b6000611fa882610aa7565b9050611fb681600084611dda565b611fc16000836117bf565b6001600160a01b0381166000908152600360205260408120805460019290611fea908490612a12565b909155505060008281526002602052604080822080546001600160a01b0319169055518391906001600160a01b038416907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908390a45050565b60006001600160a01b0384163b1561214657604051630a85bd0160e11b81526001600160a01b0385169063150b7a02906120889033908990889088906004016127cd565b602060405180830381600087803b1580156120a257600080fd5b505af19250505080156120d2575060408051601f3d908101601f191682019092526120cf91810190612609565b60015b61212c573d808015612100576040519150601f19603f3d011682016040523d82523d6000602084013e612105565b606091505b5080516121245760405162461bcd60e51b81526004016106ce9061281d565b805181602001fd5b6001600160e01b031916630a85bd0160e11b1490506111f4565b506001949350505050565b6060816121755750506040805180820190915260018152600360fc1b602082015290565b8160005b811561219f578061218981612aa7565b91506121989050600a836129df565b9150612179565b60008167ffffffffffffffff8111156121ba576121ba612b18565b6040519080825280601f01601f1916602001820160405280156121e4576020820181803683370190505b5090505b84156111f4576121f9600183612a12565b9150612206600a86612ac2565b6122119060306129c7565b60f81b81838151811061222657612226612b02565b60200101906001600160f81b031916908160001a905350612248600a866129df565b94506121e8565b82805461225b90612a6c565b90600052602060002090601f01602090048101928261227d57600085556122c3565b82601f1061229657805160ff19168380011785556122c3565b828001600101855582156122c3579182015b828111156122c35782518255916020019190600101906122a8565b506122cf929150612309565b5090565b5080546122df90612a6c565b6000825580601f106122ef575050565b601f01602090049060005260206000209081019061163b91905b5b808211156122cf576000815560010161230a565b600067ffffffffffffffff83111561233857612338612b18565b61234b601f8401601f1916602001612996565b905082815283838301111561235f57600080fd5b828260208301376000602084830101529392505050565b60006020828403121561238857600080fd5b8135611d8381612b2e565b600080604083850312156123a657600080fd5b82356123b181612b2e565b915060208301356123c181612b2e565b809150509250929050565b6000806000606084860312156123e157600080fd5b83356123ec81612b2e565b925060208401356123fc81612b2e565b929592945050506040919091013590565b6000806000806080858703121561242357600080fd5b843561242e81612b2e565b9350602085013561243e81612b2e565b925060408501359150606085013567ffffffffffffffff81111561246157600080fd5b8501601f8101871361247257600080fd5b6124818782356020840161231e565b91505092959194509250565b600080604083850312156124a057600080fd5b82356124ab81612b2e565b915060208381013567ffffffffffffffff808211156124c957600080fd5b818601915086601f8301126124dd57600080fd5b8135818111156124ef576124ef612b18565b8060051b9150612500848301612996565b8181528481019084860184860187018b101561251b57600080fd5b600095505b8386101561253e578035835260019590950194918601918601612520565b508096505050505050509250929050565b6000806040838503121561256257600080fd5b823561256d81612b2e565b9150602083013580151581146123c157600080fd5b6000806040838503121561259557600080fd5b82356125a081612b2e565b946020939093013593505050565b6000602082840312156125c057600080fd5b5035919050565b600080604083850312156125da57600080fd5b8235915060208301356123c181612b2e565b6000602082840312156125fe57600080fd5b8135611d8381612b43565b60006020828403121561261b57600080fd5b8151611d8381612b43565b60006020828403121561263857600080fd5b8151611d8381612b2e565b60006020828403121561265557600080fd5b813567ffffffffffffffff81111561266c57600080fd5b8201601f8101841361267d57600080fd5b6111f48482356020840161231e565b6000806040838503121561269f57600080fd5b50508035926020909101359150565b6000806000606084860312156126c357600080fd5b505081359360208301359350604090920135919050565b6000602082840312156126ec57600080fd5b813560ff81168114611d8357600080fd5b60008151808452612715816020860160208601612a29565b601f01601f19169290920160200192915050565b6000835161273b818460208801612a29565b83519083019061274f818360208801612a29565b01949350505050565b7f416363657373436f6e74726f6c3a206163636f756e7420000000000000000000815260008351612790816017850160208801612a29565b7001034b99036b4b9b9b4b733903937b6329607d1b60179184019182015283516127c1816028840160208801612a29565b01602801949350505050565b6001600160a01b0385811682528416602082015260408101839052608060608201819052600090612800908301846126fd565b9695505050505050565b602081526000611d8360208301846126fd565b60208082526032908201527f4552433732313a207472616e7366657220746f206e6f6e20455243373231526560408201527131b2b4bb32b91034b6b83632b6b2b73a32b960711b606082015260800190565b602080825260149082015273151bdad95b88191bd95cc81b9bdd08195e1a5cdd60621b604082015260600190565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60208082526025908201527f596f7520617265206e6f7420746865206f776e6572206f66207468697320636f6040820152646d70616e7960d81b606082015260800190565b60208082526031908201527f4552433732313a207472616e736665722063616c6c6572206973206e6f74206f6040820152701ddb995c881b9bdc88185c1c1c9bdd9959607a1b606082015260800190565b602080825260149082015273546f6b656e206973206e6f74206f6e2073616c6560601b604082015260600190565b604051601f8201601f1916810167ffffffffffffffff811182821017156129bf576129bf612b18565b604052919050565b600082198211156129da576129da612ad6565b500190565b6000826129ee576129ee612aec565b500490565b6000816000190483118215151615612a0d57612a0d612ad6565b500290565b600082821015612a2457612a24612ad6565b500390565b60005b83811015612a44578181015183820152602001612a2c565b8381111561108c5750506000910152565b600081612a6457612a64612ad6565b506000190190565b600181811c90821680612a8057607f821691505b60208210811415612aa157634e487b7160e01b600052602260045260246000fd5b50919050565b6000600019821415612abb57612abb612ad6565b5060010190565b600082612ad157612ad1612aec565b500690565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052601260045260246000fd5b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b6001600160a01b038116811461163b57600080fd5b6001600160e01b03198116811461163b57600080fdfea264697066735822122043cacffb993018e69efe8cda8a372bf95dc30e195e08c7c10a23c215bbc54d7164736f6c63430008070033
Verified Source Code Partial Match
Compiler: v0.8.7+commit.e28d00a7
EVM: london
Optimization: Yes (200 runs)
BlueWorld.sol 1023 lines
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
abstract contract Context {
function _msgSender() internal view virtual returns (address) {
return msg.sender;
}
function _msgData() internal view virtual returns (bytes calldata) {
return msg.data;
}
}
abstract contract Ownable is Context {
address private _owner;
event OwnershipTransferred(
address indexed previousOwner,
address indexed newOwner
);
constructor() {
_setOwner(_msgSender());
}
function owner() public view virtual returns (address) {
return _owner;
}
modifier onlyOwner() {
require(owner() == _msgSender(), "Ownable: caller is not the owner");
_;
}
function renounceOwnership() public virtual onlyOwner {
_setOwner(address(0));
}
function transferOwnership(address newOwner) public virtual onlyOwner {
require(
newOwner != address(0),
"Ownable: new owner is the zero address"
);
_setOwner(newOwner);
}
function _setOwner(address newOwner) private {
address oldOwner = _owner;
_owner = newOwner;
emit OwnershipTransferred(oldOwner, newOwner);
}
}
interface IERC165 {
function supportsInterface(bytes4 interfaceId) external view returns (bool);
}
abstract contract ERC165 is IERC165 {
function supportsInterface(bytes4 interfaceId)
public
view
virtual
override
returns (bool)
{
return interfaceId == type(IERC165).interfaceId;
}
}
interface IERC721 is IERC165 {
event Transfer(
address indexed from,
address indexed to,
uint256 indexed tokenId
);
event Approval(
address indexed owner,
address indexed approved,
uint256 indexed tokenId
);
event ApprovalForAll(
address indexed owner,
address indexed operator,
bool approved
);
function balanceOf(address owner) external view returns (uint256 balance);
function ownerOf(uint256 tokenId) external view returns (address owner);
function safeTransferFrom(
address from,
address to,
uint256 tokenId
) external;
function transferFrom(
address from,
address to,
uint256 tokenId
) external;
function approve(address to, uint256 tokenId) external;
function getApproved(uint256 tokenId)
external
view
returns (address operator);
function setApprovalForAll(address operator, bool _approved) external;
function isApprovedForAll(address owner, address operator)
external
view
returns (bool);
function safeTransferFrom(
address from,
address to,
uint256 tokenId,
bytes calldata data
) external;
}
interface IERC721Metadata is IERC721 {
function name() external view returns (string memory);
function symbol() external view returns (string memory);
function tokenURI(uint256 tokenId) external view returns (string memory);
}
library Address {
function isContract(address account) internal view returns (bool) {
uint256 size;
assembly {
size := extcodesize(account)
}
return size > 0;
}
function sendValue(address payable recipient, uint256 amount) internal {
require(
address(this).balance >= amount,
"Address: insufficient balance"
);
(bool success, ) = recipient.call{value: amount}("");
require(
success,
"Address: unable to send value, recipient may have reverted"
);
}
function functionCall(address target, bytes memory data)
internal
returns (bytes memory)
{
return functionCall(target, data, "Address: low-level call failed");
}
function functionCall(
address target,
bytes memory data,
string memory errorMessage
) internal returns (bytes memory) {
return functionCallWithValue(target, data, 0, errorMessage);
}
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"
);
}
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");
(bool success, bytes memory returndata) = target.call{value: value}(
data
);
return verifyCallResult(success, returndata, errorMessage);
}
function functionStaticCall(address target, bytes memory data)
internal
view
returns (bytes memory)
{
return
functionStaticCall(
target,
data,
"Address: low-level static call failed"
);
}
function functionStaticCall(
address target,
bytes memory data,
string memory errorMessage
) internal view returns (bytes memory) {
require(isContract(target), "Address: static call to non-contract");
(bool success, bytes memory returndata) = target.staticcall(data);
return verifyCallResult(success, returndata, errorMessage);
}
function functionDelegateCall(address target, bytes memory data)
internal
returns (bytes memory)
{
return
functionDelegateCall(
target,
data,
"Address: low-level delegate call failed"
);
}
function functionDelegateCall(
address target,
bytes memory data,
string memory errorMessage
) internal returns (bytes memory) {
require(isContract(target), "Address: delegate call to non-contract");
(bool success, bytes memory returndata) = target.delegatecall(data);
return verifyCallResult(success, returndata, errorMessage);
}
function verifyCallResult(
bool success,
bytes memory returndata,
string memory errorMessage
) internal pure returns (bytes memory) {
if (success) {
return returndata;
} else {
if (returndata.length > 0) {
assembly {
let returndata_size := mload(returndata)
revert(add(32, returndata), returndata_size)
}
} else {
revert(errorMessage);
}
}
}
}
library Strings {
bytes16 private constant _HEX_SYMBOLS = "0123456789abcdef";
function toString(uint256 value) internal pure returns (string memory) {
if (value == 0) {
return "0";
}
uint256 temp = value;
uint256 digits;
while (temp != 0) {
digits++;
temp /= 10;
}
bytes memory buffer = new bytes(digits);
while (value != 0) {
digits -= 1;
buffer[digits] = bytes1(uint8(48 + uint256(value % 10)));
value /= 10;
}
return string(buffer);
}
function toHexString(uint256 value) internal pure returns (string memory) {
if (value == 0) {
return "0x00";
}
uint256 temp = value;
uint256 length = 0;
while (temp != 0) {
length++;
temp >>= 8;
}
return toHexString(value, length);
}
function toHexString(uint256 value, uint256 length)
internal
pure
returns (string memory)
{
bytes memory buffer = new bytes(2 * length + 2);
buffer[0] = "0";
buffer[1] = "x";
for (uint256 i = 2 * length + 1; i > 1; --i) {
buffer[i] = _HEX_SYMBOLS[value & 0xf];
value >>= 4;
}
require(value == 0, "Strings: hex length insufficient");
return string(buffer);
}
}
interface IERC721Receiver {
function onERC721Received(
address operator,
address from,
uint256 tokenId,
bytes calldata data
) external returns (bytes4);
}
contract ERC721 is Context, ERC165, IERC721, IERC721Metadata {
using Address for address;
using Strings for uint256;
string private _name;
string private _symbol;
mapping(uint256 => address) private _owners;
mapping(address => uint256) private _balances;
mapping(uint256 => address) private _tokenApprovals;
mapping(address => mapping(address => bool)) private _operatorApprovals;
constructor(string memory name_, string memory symbol_) {
_name = name_;
_symbol = symbol_;
}
function supportsInterface(bytes4 interfaceId)
public
view
virtual
override(ERC165, IERC165)
returns (bool)
{
return
interfaceId == type(IERC721).interfaceId ||
interfaceId == type(IERC721Metadata).interfaceId ||
super.supportsInterface(interfaceId);
}
function balanceOf(address owner)
public
view
virtual
override
returns (uint256)
{
require(
owner != address(0),
"ERC721: balance query for the zero address"
);
return _balances[owner];
}
function ownerOf(uint256 tokenId)
public
view
virtual
override
returns (address)
{
address owner = _owners[tokenId];
require(
owner != address(0),
"ERC721: owner query for nonexistent token"
);
return owner;
}
function name() public view virtual override returns (string memory) {
return _name;
}
function symbol() public view virtual override returns (string memory) {
return _symbol;
}
function tokenURI(uint256 tokenId)
public
view
virtual
override
returns (string memory)
{
require(
_exists(tokenId),
"ERC721Metadata: URI query for nonexistent token"
);
string memory baseURI = _baseURI();
return
bytes(baseURI).length > 0
? string(abi.encodePacked(baseURI, tokenId.toString()))
: "";
}
function _baseURI() internal view virtual returns (string memory) {
return "";
}
function approve(address to, uint256 tokenId) public virtual override {
address owner = ERC721.ownerOf(tokenId);
require(to != owner, "ERC721: approval to current owner");
require(
_msgSender() == owner || isApprovedForAll(owner, _msgSender()),
"ERC721: approve caller is not owner nor approved for all"
);
_approve(to, tokenId);
}
function getApproved(uint256 tokenId)
public
view
virtual
override
returns (address)
{
require(
_exists(tokenId),
"ERC721: approved query for nonexistent token"
);
return _tokenApprovals[tokenId];
}
function setApprovalForAll(address operator, bool approved)
public
virtual
override
{
require(operator != _msgSender(), "ERC721: approve to caller");
_operatorApprovals[_msgSender()][operator] = approved;
emit ApprovalForAll(_msgSender(), operator, approved);
}
function isApprovedForAll(address owner, address operator)
public
view
virtual
override
returns (bool)
{
return _operatorApprovals[owner][operator];
}
function transferFrom(
address from,
address to,
uint256 tokenId
) public virtual override {
//solhint-disable-next-line max-line-length
require(
_isApprovedOrOwner(_msgSender(), tokenId),
"ERC721: transfer caller is not owner nor approved"
);
_transfer(from, to, tokenId);
}
function safeTransferFrom(
address from,
address to,
uint256 tokenId
) public virtual override {
safeTransferFrom(from, to, tokenId, "");
}
function safeTransferFrom(
address from,
address to,
uint256 tokenId,
bytes memory _data
) public virtual override {
require(
_isApprovedOrOwner(_msgSender(), tokenId),
"ERC721: transfer caller is not owner nor approved"
);
_safeTransfer(from, to, tokenId, _data);
}
function _safeTransfer(
address from,
address to,
uint256 tokenId,
bytes memory _data
) internal virtual {
_transfer(from, to, tokenId);
require(
_checkOnERC721Received(from, to, tokenId, _data),
"ERC721: transfer to non ERC721Receiver implementer"
);
}
function _exists(uint256 tokenId) internal view virtual returns (bool) {
return _owners[tokenId] != address(0);
}
function _isApprovedOrOwner(address spender, uint256 tokenId)
internal
view
virtual
returns (bool)
{
require(
_exists(tokenId),
"ERC721: operator query for nonexistent token"
);
address owner = ERC721.ownerOf(tokenId);
return (spender == owner ||
getApproved(tokenId) == spender ||
isApprovedForAll(owner, spender));
}
function _safeMint(address to, uint256 tokenId) internal virtual {
_safeMint(to, tokenId, "");
}
function _safeMint(
address to,
uint256 tokenId,
bytes memory _data
) internal virtual {
_mint(to, tokenId);
require(
_checkOnERC721Received(address(0), to, tokenId, _data),
"ERC721: transfer to non ERC721Receiver implementer"
);
}
function _mint(address to, uint256 tokenId) internal virtual {
require(to != address(0), "ERC721: mint to the zero address");
require(!_exists(tokenId), "ERC721: token already minted");
_beforeTokenTransfer(address(0), to, tokenId);
_balances[to] += 1;
_owners[tokenId] = to;
emit Transfer(address(0), to, tokenId);
}
function _burn(uint256 tokenId) internal virtual {
address owner = ERC721.ownerOf(tokenId);
_beforeTokenTransfer(owner, address(0), tokenId);
// Clear approvals
_approve(address(0), tokenId);
_balances[owner] -= 1;
delete _owners[tokenId];
emit Transfer(owner, address(0), tokenId);
}
function _transfer(
address from,
address to,
uint256 tokenId
) internal virtual {
require(
ERC721.ownerOf(tokenId) == from,
"ERC721: transfer of token that is not own"
);
require(to != address(0), "ERC721: transfer to the zero address");
_beforeTokenTransfer(from, to, tokenId);
_approve(address(0), tokenId);
_balances[from] -= 1;
_balances[to] += 1;
_owners[tokenId] = to;
emit Transfer(from, to, tokenId);
}
function _approve(address to, uint256 tokenId) internal virtual {
_tokenApprovals[tokenId] = to;
emit Approval(ERC721.ownerOf(tokenId), to, tokenId);
}
function _checkOnERC721Received(
address from,
address to,
uint256 tokenId,
bytes memory _data
) private returns (bool) {
if (to.isContract()) {
try
IERC721Receiver(to).onERC721Received(
_msgSender(),
from,
tokenId,
_data
)
returns (bytes4 retval) {
return retval == IERC721Receiver.onERC721Received.selector;
} catch (bytes memory reason) {
if (reason.length == 0) {
revert(
"ERC721: transfer to non ERC721Receiver implementer"
);
} else {
assembly {
revert(add(32, reason), mload(reason))
}
}
}
} else {
return true;
}
}
function _beforeTokenTransfer(
address from,
address to,
uint256 tokenId
) internal virtual {}
}
abstract contract ERC721URIStorage is ERC721 {
using Strings for uint256;
mapping(uint256 => string) private _tokenURIs;
function tokenURI(uint256 tokenId)
public
view
virtual
override
returns (string memory)
{
require(
_exists(tokenId),
"ERC721URIStorage: URI query for nonexistent token"
);
string memory _tokenURI = _tokenURIs[tokenId];
string memory base = _baseURI();
if (bytes(base).length == 0) {
return _tokenURI;
}
if (bytes(_tokenURI).length > 0) {
return string(abi.encodePacked(base, _tokenURI));
}
return super.tokenURI(tokenId);
}
function _setTokenURI(uint256 tokenId, string memory _tokenURI)
internal
virtual
{
require(
_exists(tokenId),
"ERC721URIStorage: URI set of nonexistent token"
);
_tokenURIs[tokenId] = _tokenURI;
}
function _burn(uint256 tokenId) internal virtual override {
super._burn(tokenId);
if (bytes(_tokenURIs[tokenId]).length != 0) {
delete _tokenURIs[tokenId];
}
}
}
interface IAccessControl {
event RoleAdminChanged(
bytes32 indexed role,
bytes32 indexed previousAdminRole,
bytes32 indexed newAdminRole
);
event RoleGranted(
bytes32 indexed role,
address indexed account,
address indexed sender
);
event RoleRevoked(
bytes32 indexed role,
address indexed account,
address indexed sender
);
function hasRole(bytes32 role, address account)
external
view
returns (bool);
function getRoleAdmin(bytes32 role) external view returns (bytes32);
function grantRole(bytes32 role, address account) external;
function revokeRole(bytes32 role, address account) external;
function renounceRole(bytes32 role, address account) external;
}
abstract contract AccessControl is Context, IAccessControl, ERC165 {
struct RoleData {
mapping(address => bool) members;
bytes32 adminRole;
}
mapping(bytes32 => RoleData) private _roles;
bytes32 public constant DEFAULT_ADMIN_ROLE = 0x00;
modifier onlyRole(bytes32 role) {
_checkRole(role, _msgSender());
_;
}
function supportsInterface(bytes4 interfaceId)
public
view
virtual
override
returns (bool)
{
return
interfaceId == type(IAccessControl).interfaceId ||
super.supportsInterface(interfaceId);
}
function hasRole(bytes32 role, address account)
public
view
override
returns (bool)
{
return _roles[role].members[account];
}
function _checkRole(bytes32 role, address account) internal view {
if (!hasRole(role, account)) {
revert(
string(
abi.encodePacked(
"AccessControl: account ",
Strings.toHexString(uint160(account), 20),
" is missing role ",
Strings.toHexString(uint256(role), 32)
)
)
);
}
}
function getRoleAdmin(bytes32 role) public view override returns (bytes32) {
return _roles[role].adminRole;
}
function grantRole(bytes32 role, address account)
public
virtual
override
onlyRole(getRoleAdmin(role))
{
_grantRole(role, account);
}
function revokeRole(bytes32 role, address account)
public
virtual
override
onlyRole(getRoleAdmin(role))
{
_revokeRole(role, account);
}
function renounceRole(bytes32 role, address account)
public
virtual
override
{
require(
account == _msgSender(),
"AccessControl: can only renounce roles for self"
);
_revokeRole(role, account);
}
function _setupRole(bytes32 role, address account) internal virtual {
_grantRole(role, account);
}
function _setRoleAdmin(bytes32 role, bytes32 adminRole) internal virtual {
bytes32 previousAdminRole = getRoleAdmin(role);
_roles[role].adminRole = adminRole;
emit RoleAdminChanged(role, previousAdminRole, adminRole);
}
function _grantRole(bytes32 role, address account) private {
if (!hasRole(role, account)) {
_roles[role].members[account] = true;
emit RoleGranted(role, account, _msgSender());
}
}
function _revokeRole(bytes32 role, address account) private {
if (hasRole(role, account)) {
_roles[role].members[account] = false;
emit RoleRevoked(role, account, _msgSender());
}
}
}
contract OwnableDelegateProxy {}
contract ProxyRegistry {
mapping(address => OwnableDelegateProxy) public proxies;
}
contract BlueWorld is ERC721URIStorage, Ownable, AccessControl {
bytes32 public constant PRE_SALE_ROLE = keccak256("PRE_SALE_ROLE");
string private contractUri;
string private baseUri;
uint8 private platformRoyalty;
address private proxyRegistryAddress;
mapping(uint256 => uint256) tokenSalePrices;
event TokenSold(
uint256 tokenId,
address from,
address to,
uint256 price,
uint256 royaltyPaid
);
function supportsInterface(bytes4 interfaceId)
public
view
virtual
override(ERC721, AccessControl)
returns (bool)
{
return super.supportsInterface(interfaceId);
}
// Rinkeby proxy for OpenSea: 0xf57b2c51ded3a29e6891aba85459d600256cf317
// Mainnet proxy for OpenSea: 0xa5409ec958c83c3f309868babaca7c86dcb077c1
constructor(address _proxyRegistryAddress, address _proxyMinterAddress)
ERC721("BlueWorld", "BWRLD")
{
contractUri = "https://api.blueworld.co/contract";
baseUri = "https://api.blueworld.co/ipfs/";
platformRoyalty = 5;
proxyRegistryAddress = _proxyRegistryAddress;
_setupRole(PRE_SALE_ROLE, _proxyMinterAddress);
_setupRole(DEFAULT_ADMIN_ROLE, msg.sender);
}
function contractURI() public view returns (string memory) {
return contractUri;
}
function setContractUri(string memory newUri) public onlyOwner {
contractUri = newUri;
}
function _baseURI() internal view override returns (string memory) {
return baseUri;
}
function setBaseUri(string memory newUri) public onlyOwner {
baseUri = newUri;
}
function platformFee() public view returns (uint8) {
return platformRoyalty;
}
function setPlatformFee(uint8 newFee) public onlyOwner {
platformRoyalty = newFee;
}
function mintCompany(address to, uint256 tokenId) public {
require(
hasRole(PRE_SALE_ROLE, msg.sender) ||
hasRole(DEFAULT_ADMIN_ROLE, msg.sender),
"Access forbidden"
);
require(!_exists(tokenId), "Company has already been minted");
_mint(to, tokenId);
}
function batchMintCompanies(address owner, uint256[] memory tokenIds)
public
onlyOwner
{
for (uint256 i = 0; i < tokenIds.length; i++) {
require(!_exists(tokenIds[i]), "Company has already been minted");
_mint(owner, tokenIds[i]);
}
}
function mergeTokens(
uint256 token1,
uint256 token2,
uint256 newToken
) public {
require(
_exists(token1) && _exists(token2),
"One of the companies does not exist."
);
require(
ownerOf(token1) == _msgSender() && ownerOf(token2) == _msgSender(),
"You are not owner of one of the companies"
);
require(!_exists(newToken), "Company with new token ID already exists");
_burn(token1);
_burn(token2);
_mint(_msgSender(), newToken);
}
function putTokenOnSale(uint256 tokenId, uint256 value) public {
require(
ownerOf(tokenId) == _msgSender(),
"You are not the owner of this company"
);
tokenSalePrices[tokenId] = value;
}
function getCompanySalePrice(uint256 tokenId)
public
view
returns (uint256)
{
require(_exists(tokenId), "Token does not exist");
require(tokenSalePrices[tokenId] > 0, "Token is not on sale");
return tokenSalePrices[tokenId];
}
function buyTokenFromSale(uint256 tokenId) public payable {
require(_exists(tokenId), "Token does not exist");
require(tokenSalePrices[tokenId] > 0, "Token is not on sale");
require(
msg.value == tokenSalePrices[tokenId],
"Please provide sufficient ETH to purchase this company"
);
uint256 royalty = ((msg.value * platformRoyalty) / 100);
payable(owner()).transfer(royalty);
payable(ownerOf(tokenId)).transfer(msg.value - royalty);
_transfer(ownerOf(tokenId), _msgSender(), tokenId);
emit TokenSold(
tokenId,
ownerOf(tokenId),
_msgSender(),
msg.value,
royalty
);
}
function removeTokenFromSale(uint256 tokenId) public {
require(_exists(tokenId), "Token does not exist");
require(tokenSalePrices[tokenId] > 0, "Token is not on sale");
require(
ownerOf(tokenId) == _msgSender(),
"You are not the owner of this company"
);
tokenSalePrices[tokenId] = 0;
}
function isApprovedForAll(address _owner, address _operator)
public
view
override
returns (bool isOperator)
{
// Whitelist OpenSea proxy contract for easy trading.
ProxyRegistry proxyRegistry = ProxyRegistry(proxyRegistryAddress);
if (address(proxyRegistry.proxies(_owner)) == _operator) {
return true;
}
return isApprovedForAll(_owner, _operator);
}
function _beforeTokenTransfer(
address from,
address to,
uint256 tokenId
) internal override {
super._beforeTokenTransfer(from, to, tokenId);
if (tokenSalePrices[tokenId] > 0) {
tokenSalePrices[tokenId] = 0;
}
}
}
Read Contract
DEFAULT_ADMIN_ROLE 0xa217fddf → bytes32
PRE_SALE_ROLE 0x37754d9a → bytes32
balanceOf 0x70a08231 → uint256
contractURI 0xe8a3d485 → string
getApproved 0x081812fc → address
getCompanySalePrice 0x6ce3f687 → uint256
getRoleAdmin 0x248a9ca3 → bytes32
hasRole 0x91d14854 → bool
isApprovedForAll 0xe985e9c5 → bool
name 0x06fdde03 → string
owner 0x8da5cb5b → address
ownerOf 0x6352211e → address
platformFee 0x26232a2e → uint8
supportsInterface 0x01ffc9a7 → bool
symbol 0x95d89b41 → string
tokenURI 0xc87b56dd → string
Write Contract 19 functions
These functions modify contract state and require a wallet transaction to execute.
approve 0x095ea7b3
address to
uint256 tokenId
batchMintCompanies 0x068da657
address owner
uint256[] tokenIds
buyTokenFromSale 0xe8376eb0
uint256 tokenId
grantRole 0x2f2ff15d
bytes32 role
address account
mergeTokens 0x7836a925
uint256 token1
uint256 token2
uint256 newToken
mintCompany 0x720093e4
address to
uint256 tokenId
putTokenOnSale 0x65af3798
uint256 tokenId
uint256 value
removeTokenFromSale 0xe8cdea11
uint256 tokenId
renounceOwnership 0x715018a6
No parameters
renounceRole 0x36568abe
bytes32 role
address account
revokeRole 0xd547741f
bytes32 role
address account
safeTransferFrom 0x42842e0e
address from
address to
uint256 tokenId
safeTransferFrom 0xb88d4fde
address from
address to
uint256 tokenId
bytes _data
setApprovalForAll 0xa22cb465
address operator
bool approved
setBaseUri 0xa0bcfc7f
string newUri
setContractUri 0xccb4807b
string newUri
setPlatformFee 0x8042853f
uint8 newFee
transferFrom 0x23b872dd
address from
address to
uint256 tokenId
transferOwnership 0xf2fde38b
address newOwner
Recent Transactions
No transactions found for this address