Address Contract Partially Verified
Address
0x617913Dd43dbDf4236B85Ec7BdF9aDFD7E35b340
Balance
0 ETH
Nonce
1
Code Size
15373 bytes
Creator
0xe7aF1137...8f4a at tx 0xbdc55996...777173
Indexed Transactions
0
Contract Bytecode
15373 bytes
0x608060405234801561001057600080fd5b506004361061030e576000357c01000000000000000000000000000000000000000000000000000000009004806370a08231116101ba578063a22cb46511610106578063c0ac9983116100bf578063db2c0b9111610099578063db2c0b91146111bd578063e78482c1146111e3578063e985e9c514611237578063fbba7b62146112b35761030e565b8063c0ac99831461106d578063c87b56dd146110f0578063cb338ea8146111975761030e565b8063a22cb46514610e2a578063a457a62d14610e7a578063aa271e1a14610ec0578063b88d4fde14610f1c578063bd71a52114611021578063bd7c40c7146110475761030e565b80638c75065f11610173578063986502751161014d5780639865027514610d1b5780639989948f14610d2557806399e0dd7c14610d6b5780639cc19bfb14610de45761030e565b80638c75065f14610c3657806395d89b4114610c54578063983b2d5614610cd75761030e565b806370a0823114610abd5780637427306614610b155780637c755b5314610b9c57806382dc1ec414610bc25780638456cb5914610c065780638c2c3e6914610c105761030e565b806340c10f19116102795780634f6ccce711610232578063639d6bc91161020c578063639d6bc9146109c65780636b2ba26914610a0c5780636ef8d66d14610a3a5780636efaed5114610a445761030e565b80634f6ccce7146108f45780635c975abb146109365780636352211e146109585761030e565b806340c10f19146106ea578063410cb3f81461075057806342842e0e1461079a57806346fbf68e1461080857806348758697146108645780634d4f6ea9146108ae5761030e565b80631ee2ec93116102cb5780631ee2ec931461051b5780632239325b1461056457806323b872dd146105bc5780632f745c591461062a578063355692391461068c5780633f4ba83a146106e05761030e565b806301ffc9a71461031357806306fdde0314610378578063081812fc146103fb578063095ea7b3146104695780630b32e757146104b757806318160ddd146104fd575b600080fd5b61035e6004803603602081101561032957600080fd5b8101908080357bffffffffffffffffffffffffffffffffffffffffffffffffffffffff191690602001909291905050506112f9565b604051808215151515815260200191505060405180910390f35b610380611360565b6040518080602001828103825283818151815260200191508051906020019080838360005b838110156103c05780820151818401526020810190506103a5565b50505050905090810190601f1680156103ed5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6104276004803603602081101561041157600080fd5b8101908080359060200190929190505050611402565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b6104b56004803603604081101561047f57600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff16906020019092919080359060200190929190505050611453565b005b6104e7600480360360208110156104cd57600080fd5b81019080803561ffff16906020019092919050505061148d565b6040518082815260200191505060405180910390f35b6105056114b2565b6040518082815260200191505060405180910390f35b6105476004803603602081101561053157600080fd5b81019080803590602001909291905050506114bf565b604051808381526020018281526020019250505060405180910390f35b6105ba6004803603606081101561057a57600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff1690602001909291908035906020019092919080359060200190929190505050611521565b005b610628600480360360608110156105d257600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190803573ffffffffffffffffffffffffffffffffffffffff169060200190929190803590602001909291905050506117b7565b005b6106766004803603604081101561064057600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190803590602001909291905050506117f3565b6040518082815260200191505060405180910390f35b6106ca600480360360408110156106a257600080fd5b81019080803561ffff169060200190929190803561ffff16906020019092919050505061186a565b6040518082815260200191505060405180910390f35b6106e86118a9565b005b6107366004803603604081101561070057600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff16906020019092919080359060200190929190505050611958565b604051808215151515815260200191505060405180910390f35b61077c6004803603602081101561076657600080fd5b8101908080359060200190929190505050611982565b604051808261ffff1661ffff16815260200191505060405180910390f35b610806600480360360608110156107b057600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190803573ffffffffffffffffffffffffffffffffffffffff169060200190929190803590602001909291905050506119b2565b005b61084a6004803603602081101561081e57600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff1690602001909291905050506119d3565b604051808215151515815260200191505060405180910390f35b6108906004803603602081101561087a57600080fd5b81019080803590602001909291905050506119f0565b604051808261ffff1661ffff16815260200191505060405180910390f35b6108da600480360360208110156108c457600080fd5b8101908080359060200190929190505050611a0f565b604051808215151515815260200191505060405180910390f35b6109206004803603602081101561090a57600080fd5b8101908080359060200190929190505050611a39565b6040518082815260200191505060405180910390f35b61093e611a71565b604051808215151515815260200191505060405180910390f35b6109846004803603602081101561096e57600080fd5b8101908080359060200190929190505050611a88565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b6109f6600480360360208110156109dc57600080fd5b81019080803561ffff169060200190929190505050611b06565b6040518082815260200191505060405180910390f35b610a3860048036036020811015610a2257600080fd5b8101908080359060200190929190505050611b2b565b005b610a42611b6e565b005b610abb6004803603610100811015610a5b57600080fd5b81019080803561ffff16906020019092919080359060200190929190803590602001909291908035906020019092919080359060200190929190803590602001909291908035906020019092919080359060200190929190505050611b79565b005b610aff60048036036020811015610ad357600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190505050612001565b6040518082815260200191505060405180910390f35b610b4560048036036020811015610b2b57600080fd5b81019080803561ffff169060200190929190505050612085565b6040518080602001828103825283818151815260200191508051906020019060200280838360005b83811015610b88578082015181840152602081019050610b6d565b505050509050019250505060405180910390f35b610ba46120f8565b604051808261ffff1661ffff16815260200191505060405180910390f35b610c0460048036036020811015610bd857600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff1690602001909291905050506120fd565b005b610c0e61211d565b005b610c186121cd565b604051808261ffff1661ffff16815260200191505060405180910390f35b610c3e6121d2565b6040518082815260200191505060405180910390f35b610c5c6121de565b6040518080602001828103825283818151815260200191508051906020019080838360005b83811015610c9c578082015181840152602081019050610c81565b50505050905090810190601f168015610cc95780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b610d1960048036036020811015610ced57600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190505050612280565b005b610d236122a0565b005b610d5160048036036020811015610d3b57600080fd5b81019080803590602001909291905050506122ab565b604051808215151515815260200191505060405180910390f35b610de260048036036020811015610d8157600080fd5b8101908080359060200190640100000000811115610d9e57600080fd5b820183602082011115610db057600080fd5b80359060200191846001830284011164010000000083111715610dd257600080fd5b90919293919293905050506123a1565b005b610e1060048036036020811015610dfa57600080fd5b81019080803590602001909291905050506123cb565b604051808215151515815260200191505060405180910390f35b610e7860048036036040811015610e4057600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff1690602001909291908035151590602001909291905050506123dd565b005b610eaa60048036036020811015610e9057600080fd5b81019080803561ffff169060200190929190505050612407565b6040518082815260200191505060405180910390f35b610f0260048036036020811015610ed657600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff16906020019092919050505061242c565b604051808215151515815260200191505060405180910390f35b61101f60048036036080811015610f3257600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190803573ffffffffffffffffffffffffffffffffffffffff1690602001909291908035906020019092919080359060200190640100000000811115610f9957600080fd5b820183602082011115610fab57600080fd5b80359060200191846001830284011164010000000083111715610fcd57600080fd5b91908080601f016020809104026020016040519081016040528093929190818152602001838380828437600081840152601f19601f820116905080830192505050505050509192919290505050612449565b005b611029612471565b604051808261ffff1661ffff16815260200191505060405180910390f35b61104f612476565b604051808261ffff1661ffff16815260200191505060405180910390f35b61107561247b565b6040518080602001828103825283818151815260200191508051906020019080838360005b838110156110b557808201518184015260208101905061109a565b50505050905090810190601f1680156110e25780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b61111c6004803603602081101561110657600080fd5b8101908080359060200190929190505050612519565b6040518080602001828103825283818151815260200191508051906020019080838360005b8381101561115c578082015181840152602081019050611141565b50505050905090810190601f1680156111895780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b61119f612815565b604051808261ffff1661ffff16815260200191505060405180910390f35b6111c561281a565b604051808261ffff1661ffff16815260200191505060405180910390f35b611221600480360360408110156111f957600080fd5b81019080803561ffff169060200190929190803561ffff16906020019092919050505061281f565b6040518082815260200191505060405180910390f35b6112996004803603604081101561124d57600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190803573ffffffffffffffffffffffffffffffffffffffff16906020019092919050505061285e565b604051808215151515815260200191505060405180910390f35b6112e3600480360360208110156112c957600080fd5b81019080803561ffff1690602001909291905050506128f2565b6040518082815260200191505060405180910390f35b6000806000837bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19167bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916815260200190815260200160002060009054906101000a900460ff169050919050565b606060098054600181600116156101000203166002900480601f0160208091040260200160405190810160405280929190818152602001828054600181600116156101000203166002900480156113f85780601f106113cd576101008083540402835291602001916113f8565b820191906000526020600020905b8154815290600101906020018083116113db57829003601f168201915b5050505050905090565b600061140d82612917565b151561141857600080fd5b6002600083815260200190815260200160002060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050919050565b6017600082815260200190815260200160002060009054906101000a900460ff16151561147f57600080fd5b6114898282612989565b5050565b6000601660008361ffff1661ffff168152602001908152602001600020549050919050565b6000600780549050905090565b60008061150f6114d66114d185611982565b6128f2565b611501670de0b6b3a76400006114f36114ee886119f0565b61148d565b6129b390919063ffffffff16565b6129f190919063ffffffff16565b670de0b6b3a764000091509150915091565b61152a3361242c565b151561153557600080fd5b61153e826123cb565b15151561154a57600080fd5b611553826122ab565b151561155e57600080fd5b600061156983611982565b9050601160008261ffff1661ffff16815260200190815260200160002054601460008361ffff1661ffff168152602001908152602001600020541015156115af57600080fd5b60006115ba846119f0565b9050601260008361ffff1661ffff16815260200190815260200160002060008261ffff1661ffff16815260200190815260200160002054601560008461ffff1661ffff16815260200190815260200160002060008361ffff1661ffff1681526020019081526020016000205410151561169b576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252600b8152602001807f737570706c79206f76657200000000000000000000000000000000000000000081525060200191505060405180910390fd5b6116a58585612a1b565b601360008361ffff1661ffff168152602001908152602001600020849080600181540180825580915050906001820390600052602060002001600090919290919091505550601460008361ffff1661ffff16815260200190815260200160002060008154809291906001019190505550601560008361ffff1661ffff16815260200190815260200160002060008261ffff1661ffff16815260200190815260200160002060008154809291906001019190505550828573ffffffffffffffffffffffffffffffffffffffff167f4a08db80e18c0be3902463f739cf63fbfef0e82163d3b77a324871c5b20110e18642604051808381526020018281526020019250505060405180910390a35050505050565b6017600082815260200190815260200160002060009054906101000a900460ff1615156117e357600080fd5b6117ee838383612a3c565b505050565b60006117fe83612001565b8210151561180b57600080fd5b600560008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208281548110151561185757fe5b9060005260206000200154905092915050565b6000601260008461ffff1661ffff16815260200190815260200160002060008361ffff1661ffff16815260200190815260200160002054905092915050565b6118b2336119d3565b15156118bd57600080fd5b600e60009054906101000a900460ff1615156118d857600080fd5b6000600e60006101000a81548160ff0219169083151502179055507f5db9ee0a495bf2e6ff9c91a7834c1ba4fdd244a5e8aa4e537bd38aeae4b073aa33604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390a1565b60006119633361242c565b151561196e57600080fd5b6119788383612a1b565b6001905092915050565b6000806103e861199d612710856129f190919063ffffffff16565b8115156119a657fe5b06905080915050919050565b6119ce8383836020604051908101604052806000815250612449565b505050565b60006119e982600d612a6890919063ffffffff16565b9050919050565b6000611a0862989680836129f190919063ffffffff16565b9050919050565b60006017600083815260200190815260200160002060009054906101000a900460ff169050919050565b6000611a436114b2565b82101515611a5057600080fd5b600782815481101515611a5f57fe5b90600052602060002001549050919050565b6000600e60009054906101000a900460ff16905090565b6000806001600084815260200190815260200160002060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1614151515611afd57600080fd5b80915050919050565b6000601460008361ffff1661ffff168152602001908152602001600020549050919050565b611b343361242c565b1515611b3f57600080fd5b60016017600083815260200190815260200160002060006101000a81548160ff02191690831515021790555050565b611b7733612afc565b565b611b823361242c565b1515611b8d57600080fd5b60008861ffff1614151515611c0a576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260148152602001807f6c616e64547970652030206973206e6f6c616e6400000000000000000000000081525060200191505060405180910390fd5b60008714151515611c83576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260198152602001807f746f74616c566f6c756d65206d757374206e6f7420626520300000000000000081525060200191505060405180910390fd5b6000611c8e89611b06565b141515611d03576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252601c8152602001807f54686973204c616e645479706520616c7265616479206578697374730000000081525060200191505060405180910390fd5b86611e33611d3660166000600161ffff1661ffff16815260200190815260200160002054846129b390919063ffffffff16565b611e25611d6860166000600261ffff1661ffff16815260200190815260200160002054876129b390919063ffffffff16565b611e17611d9a60166000600361ffff1661ffff168152602001908152602001600020548a6129b390919063ffffffff16565b611e09611dcc60166000600461ffff1661ffff168152602001908152602001600020548d6129b390919063ffffffff16565b611dfb60166000600561ffff1661ffff168152602001908152602001600020548f6129b390919063ffffffff16565b612b5690919063ffffffff16565b612b5690919063ffffffff16565b612b5690919063ffffffff16565b612b5690919063ffffffff16565b141515611e3f57600080fd5b85611e8982611e7b85611e6d88611e5f8b8d612b5690919063ffffffff16565b612b5690919063ffffffff16565b612b5690919063ffffffff16565b612b5690919063ffffffff16565b141515611e9557600080fd5b86601060008a61ffff1661ffff1681526020019081526020016000208190555085601160008a61ffff1661ffff1681526020019081526020016000208190555084601260008a61ffff1661ffff1681526020019081526020016000206000600561ffff1661ffff1681526020019081526020016000208190555083601260008a61ffff1661ffff1681526020019081526020016000206000600461ffff1661ffff1681526020019081526020016000208190555082601260008a61ffff1661ffff1681526020019081526020016000206000600361ffff1661ffff1681526020019081526020016000208190555081601260008a61ffff1661ffff1681526020019081526020016000206000600261ffff1661ffff1681526020019081526020016000208190555080601260008a61ffff1661ffff1681526020019081526020016000206000600161ffff1661ffff168152602001908152602001600020819055505050505050505050565b60008073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff161415151561203e57600080fd5b600360008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050919050565b6060601360008361ffff1661ffff1681526020019081526020016000208054806020026020016040519081016040528092919081815260200182805480156120ec57602002820191906000526020600020905b8154815260200190600101908083116120d8575b50505050509050919050565b600281565b612106336119d3565b151561211157600080fd5b61211a81612b77565b50565b612126336119d3565b151561213157600080fd5b600e60009054906101000a900460ff1615151561214d57600080fd5b6001600e60006101000a81548160ff0219169083151502179055507f62e78cea01bee320cd4e420270b5ea74000d11b0c9f74754ebdbfc544b05a25833604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390a1565b600081565b670de0b6b3a764000081565b6060600a8054600181600116156101000203166002900480601f0160208091040260200160405190810160405280929190818152602001828054600181600116156101000203166002900480156122765780601f1061224b57610100808354040283529160200191612276565b820191906000526020600020905b81548152906001019060200180831161225957829003601f168201915b5050505050905090565b6122893361242c565b151561229457600080fd5b61229d81612bd1565b50565b6122a933612c2b565b565b6000806122b7836119f0565b90506000601660008361ffff1661ffff168152602001908152602001600020541115156122e857600091505061239c565b60006122f384611982565b90506000601060008361ffff1661ffff168152602001908152602001600020541115156123255760009250505061239c565b60006127108581151561233457fe5b069050600081141561234c576000935050505061239c565b601260008361ffff1661ffff16815260200190815260200160002060008461ffff1661ffff16815260200190815260200160002054811115612394576000935050505061239c565b600193505050505b919050565b6123aa3361242c565b15156123b557600080fd5b8181600f91906123c6929190613b10565b505050565b60006123d682612917565b9050919050565b600e60009054906101000a900460ff161515156123f957600080fd5b6124038282612c85565b5050565b6000601160008361ffff1661ffff168152602001908152602001600020549050919050565b600061244282600c612a6890919063ffffffff16565b9050919050565b6124548484846117b7565b61246084848484612dc1565b151561246b57600080fd5b50505050565b600181565b600581565b600f8054600181600116156101000203166002900480601f0160208091040260200160405190810160405280929190818152602001828054600181600116156101000203166002900480156125115780601f106124e657610100808354040283529160200191612511565b820191906000526020600020905b8154815290600101906020018083116124f457829003601f168201915b505050505081565b606060008083141561254d577f300000000000000000000000000000000000000000000000000000000000000090506125c2565b60008390505b60008111156125c057610100826001900481151561256d57fe5b0460010291507f01000000000000000000000000000000000000000000000000000000000000006030600a838115156125a257fe5b06010260010282179150600a818115156125b857fe5b049050612553565b505b6060600f8054600181600116156101000203166002900480601f01602080910402602001604051908101604052809291908181526020018280546001816001161561010002031660029004801561265a5780601f1061262f5761010080835404028352916020019161265a565b820191906000526020600020905b81548152906001019060200180831161263d57829003601f168201915b505050505090506060602060ff168251016040519080825280601f01601f19166020018201604052801561269d5781602001600182028038833980820191505090505b50905060008060009050600091505b83518260ff16101561276a57838260ff168151811015156126c957fe5b9060200101517f010000000000000000000000000000000000000000000000000000000000000090047f010000000000000000000000000000000000000000000000000000000000000002838260ff1681518110151561272557fe5b9060200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a905350808060010191505081806001019250506126ac565b600091505b602060ff168260ff16101561280857848260ff1660208110151561278f57fe5b1a7f010000000000000000000000000000000000000000000000000000000000000002838260ff168151811015156127c357fe5b9060200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a9053508080600101915050818060010192505061276f565b8295505050505050919050565b600481565b600381565b6000601560008461ffff1661ffff16815260200190815260200160002060008361ffff1661ffff16815260200190815260200160002054905092915050565b6000600460008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16905092915050565b6000601060008361ffff1661ffff168152602001908152602001600020549050919050565b6000806001600084815260200190815260200160002060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff161415915050919050565b600e60009054906101000a900460ff161515156129a557600080fd5b6129af8282612fe4565b5050565b6000808314156129c657600090506129eb565b600082840290508284828115156129d957fe5b041415156129e657600080fd5b809150505b92915050565b60008082111515612a0157600080fd5b60008284811515612a0e57fe5b0490508091505092915050565b612a258282613129565b612a2f82826132c2565b612a3881613389565b5050565b600e60009054906101000a900460ff16151515612a5857600080fd5b612a638383836133d5565b505050565b60008073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1614151515612aa557600080fd5b8260000160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16905092915050565b612b1081600d6133fa90919063ffffffff16565b8073ffffffffffffffffffffffffffffffffffffffff167fcd265ebaf09df2871cc7bd4133404a235ba12eff2041bb89d9c714a2621c7c7e60405160405180910390a250565b6000808284019050838110151515612b6d57600080fd5b8091505092915050565b612b8b81600d6134a990919063ffffffff16565b8073ffffffffffffffffffffffffffffffffffffffff167f6719d08c1888103bea251a4ed56406bd0c3e69723c8a1686e017e7bbe159b6f860405160405180910390a250565b612be581600c6134a990919063ffffffff16565b8073ffffffffffffffffffffffffffffffffffffffff167f6ae172837ea30b801fbfcdd4108aa1d5bf8ff775444fd70256b44e6bf3dfc3f660405160405180910390a250565b612c3f81600c6133fa90919063ffffffff16565b8073ffffffffffffffffffffffffffffffffffffffff167fe94479a9f7e1952cc78f2d6baab678adc1b772d936c6583def489e524cb6669260405160405180910390a250565b3373ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1614151515612cc057600080fd5b80600460003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055508173ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff167f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c3183604051808215151515815260200191505060405180910390a35050565b6000612de28473ffffffffffffffffffffffffffffffffffffffff16613559565b1515612df15760019050612fdc565b60008473ffffffffffffffffffffffffffffffffffffffff1663150b7a02338887876040518563ffffffff167c0100000000000000000000000000000000000000000000000000000000028152600401808573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020018473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200183815260200180602001828103825283818151815260200191508051906020019080838360005b83811015612ee8578082015181840152602081019050612ecd565b50505050905090810190601f168015612f155780820380516001836020036101000a031916815260200191505b5095505050505050602060405180830381600087803b158015612f3757600080fd5b505af1158015612f4b573d6000803e3d6000fd5b505050506040513d6020811015612f6157600080fd5b8101908080519060200190929190505050905063150b7a027c0100000000000000000000000000000000000000000000000000000000027bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916817bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916149150505b949350505050565b6000612fef82611a88565b90508073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff161415151561302c57600080fd5b8073ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff16148061306c575061306b813361285e565b5b151561307757600080fd5b826002600084815260200190815260200160002060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550818373ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92560405160405180910390a4505050565b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff161415151561316557600080fd5b61316e81612917565b15151561317a57600080fd5b816001600083815260200190815260200160002060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555061321f6001600360008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054612b5690919063ffffffff16565b600360008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002081905550808273ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a45050565b600560008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020805490506006600083815260200190815260200160002081905550600560008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208190806001815401808255809150509060018203906000526020600020016000909192909190915055505050565b6007805490506008600083815260200190815260200160002081905550600781908060018154018082558091505090600182039060005260206000200160009091929091909150555050565b6133df338261356c565b15156133ea57600080fd5b6133f5838383613601565b505050565b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff161415151561343657600080fd5b6134408282612a68565b151561344b57600080fd5b60008260000160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055505050565b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff16141515156134e557600080fd5b6134ef8282612a68565b1515156134fb57600080fd5b60018260000160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055505050565b600080823b905060008111915050919050565b60008061357883611a88565b90508073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614806135e757508373ffffffffffffffffffffffffffffffffffffffff166135cf84611402565b73ffffffffffffffffffffffffffffffffffffffff16145b806135f857506135f7818561285e565b5b91505092915050565b61360c838383613625565b613616838261388a565b61362082826132c2565b505050565b8273ffffffffffffffffffffffffffffffffffffffff1661364582611a88565b73ffffffffffffffffffffffffffffffffffffffff1614151561366757600080fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16141515156136a357600080fd5b6136ac81613a2e565b6136ff6001600360008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054613aee90919063ffffffff16565b600360008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055506137956001600360008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054612b5690919063ffffffff16565b600360008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002081905550816001600083815260200190815260200160002060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550808273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a4505050565b60006138e26001600560008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002080549050613aee90919063ffffffff16565b905060006006600084815260200190815260200160002054905081811415156139d5576000600560008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208381548110151561395357fe5b9060005260206000200154905080600560008773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020838154811015156139ad57fe5b9060005260206000200181905550816006600083815260200190815260200160002081905550505b600560008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020805480919060019003613a279190613b90565b5050505050565b600073ffffffffffffffffffffffffffffffffffffffff166002600083815260200190815260200160002060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16141515613aeb5760006002600083815260200190815260200160002060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055505b50565b6000828211151515613aff57600080fd5b600082840390508091505092915050565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f10613b5157803560ff1916838001178555613b7f565b82800160010185558215613b7f579182015b82811115613b7e578235825591602001919060010190613b63565b5b509050613b8c9190613bbc565b5090565b815481835581811115613bb757818360005260206000209182019101613bb69190613bbc565b5b505050565b613bde91905b80821115613bda576000816000905550600101613bc2565b5090565b9056fea165627a7a723058202d55f3f64a7864fddc72ceac42316a206adc1b7d217743a6240457b925e8f6cc0029
Verified Source Code Partial Match
Compiler: v0.5.4+commit.9549d8ff
EVM: byzantium
Optimization: No
LandSectorAsset.sol 1257 lines
pragma solidity ^0.5.0;
// File: contracts/lib/github.com/OpenZeppelin/openzeppelin-solidity-2.1.2/contracts/introspection/IERC165.sol
/**
* @title IERC165
* @dev https://github.com/ethereum/EIPs/blob/master/EIPS/eip-165.md
*/
interface IERC165 {
/**
* @notice Query if a contract implements an interface
* @param interfaceId The interface identifier, as specified in ERC-165
* @dev Interface identification is specified in ERC-165. This function
* uses less than 30,000 gas.
*/
function supportsInterface(bytes4 interfaceId) external view returns (bool);
}
// File: contracts/lib/github.com/OpenZeppelin/openzeppelin-solidity-2.1.2/contracts/token/ERC721/IERC721.sol
/**
* @title ERC721 Non-Fungible Token Standard basic interface
* @dev see https://github.com/ethereum/EIPs/blob/master/EIPS/eip-721.md
*/
contract 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) public view returns (uint256 balance);
function ownerOf(uint256 tokenId) public view returns (address owner);
function approve(address to, uint256 tokenId) public;
function getApproved(uint256 tokenId) public view returns (address operator);
function setApprovalForAll(address operator, bool _approved) public;
function isApprovedForAll(address owner, address operator) public view returns (bool);
function transferFrom(address from, address to, uint256 tokenId) public;
function safeTransferFrom(address from, address to, uint256 tokenId) public;
function safeTransferFrom(address from, address to, uint256 tokenId, bytes memory data) public;
}
// File: contracts/lib/github.com/OpenZeppelin/openzeppelin-solidity-2.1.2/contracts/token/ERC721/IERC721Receiver.sol
/**
* @title ERC721 token receiver interface
* @dev Interface for any contract that wants to support safeTransfers
* from ERC721 asset contracts.
*/
contract IERC721Receiver {
/**
* @notice Handle the receipt of an NFT
* @dev The ERC721 smart contract calls this function on the recipient
* after a `safeTransfer`. This function MUST return the function selector,
* otherwise the caller will revert the transaction. The selector to be
* returned can be obtained as `this.onERC721Received.selector`. This
* function MAY throw to revert and reject the transfer.
* Note: the ERC721 contract address is always the message sender.
* @param operator The address which called `safeTransferFrom` function
* @param from The address which previously owned the token
* @param tokenId The NFT identifier which is being transferred
* @param data Additional data with no specified format
* @return `bytes4(keccak256("onERC721Received(address,address,uint256,bytes)"))`
*/
function onERC721Received(address operator, address from, uint256 tokenId, bytes memory data)
public returns (bytes4);
}
// File: contracts/lib/github.com/OpenZeppelin/openzeppelin-solidity-2.1.2/contracts/math/SafeMath.sol
/**
* @title SafeMath
* @dev Unsigned math operations with safety checks that revert on error
*/
library SafeMath {
/**
* @dev Multiplies two unsigned integers, reverts on overflow.
*/
function mul(uint256 a, uint256 b) internal pure returns (uint256) {
// Gas optimization: this is cheaper than requiring 'a' not being zero, but the
// benefit is lost if 'b' is also tested.
// See: https://github.com/OpenZeppelin/openzeppelin-solidity/pull/522
if (a == 0) {
return 0;
}
uint256 c = a * b;
require(c / a == b);
return c;
}
/**
* @dev Integer division of two unsigned integers truncating the quotient, reverts on division by zero.
*/
function div(uint256 a, uint256 b) internal pure returns (uint256) {
// Solidity only automatically asserts when dividing by 0
require(b > 0);
uint256 c = a / b;
// assert(a == b * c + a % b); // There is no case in which this doesn't hold
return c;
}
/**
* @dev Subtracts two unsigned integers, reverts on overflow (i.e. if subtrahend is greater than minuend).
*/
function sub(uint256 a, uint256 b) internal pure returns (uint256) {
require(b <= a);
uint256 c = a - b;
return c;
}
/**
* @dev Adds two unsigned integers, reverts on overflow.
*/
function add(uint256 a, uint256 b) internal pure returns (uint256) {
uint256 c = a + b;
require(c >= a);
return c;
}
/**
* @dev Divides two unsigned integers and returns the remainder (unsigned integer modulo),
* reverts when dividing by zero.
*/
function mod(uint256 a, uint256 b) internal pure returns (uint256) {
require(b != 0);
return a % b;
}
}
// File: contracts/lib/github.com/OpenZeppelin/openzeppelin-solidity-2.1.2/contracts/utils/Address.sol
/**
* Utility library of inline functions on addresses
*/
library Address {
/**
* Returns whether the target address is a contract
* @dev This function will return false if invoked during the constructor of a contract,
* as the code is not actually created until after the constructor finishes.
* @param account address of the account to check
* @return whether the target address is a contract
*/
function isContract(address account) internal view returns (bool) {
uint256 size;
// XXX Currently there is no better way to check if there is a contract in an address
// than to check the size of the code at that address.
// See https://ethereum.stackexchange.com/a/14016/36603
// for more details about how this works.
// TODO Check this again before the Serenity release, because all addresses will be
// contracts then.
// solhint-disable-next-line no-inline-assembly
assembly { size := extcodesize(account) }
return size > 0;
}
}
// File: contracts/lib/github.com/OpenZeppelin/openzeppelin-solidity-2.1.2/contracts/introspection/ERC165.sol
/**
* @title ERC165
* @author Matt Condon (@shrugs)
* @dev Implements ERC165 using a lookup table.
*/
contract ERC165 is IERC165 {
bytes4 private constant _INTERFACE_ID_ERC165 = 0x01ffc9a7;
/**
* 0x01ffc9a7 ===
* bytes4(keccak256('supportsInterface(bytes4)'))
*/
/**
* @dev a mapping of interface id to whether or not it's supported
*/
mapping(bytes4 => bool) private _supportedInterfaces;
/**
* @dev A contract implementing SupportsInterfaceWithLookup
* implement ERC165 itself
*/
constructor () internal {
_registerInterface(_INTERFACE_ID_ERC165);
}
/**
* @dev implement supportsInterface(bytes4) using a lookup table
*/
function supportsInterface(bytes4 interfaceId) external view returns (bool) {
return _supportedInterfaces[interfaceId];
}
/**
* @dev internal method for registering an interface
*/
function _registerInterface(bytes4 interfaceId) internal {
require(interfaceId != 0xffffffff);
_supportedInterfaces[interfaceId] = true;
}
}
// File: contracts/lib/github.com/OpenZeppelin/openzeppelin-solidity-2.1.2/contracts/token/ERC721/ERC721.sol
/**
* @title ERC721 Non-Fungible Token Standard basic implementation
* @dev see https://github.com/ethereum/EIPs/blob/master/EIPS/eip-721.md
*/
contract ERC721 is ERC165, IERC721 {
using SafeMath for uint256;
using Address for address;
// Equals to `bytes4(keccak256("onERC721Received(address,address,uint256,bytes)"))`
// which can be also obtained as `IERC721Receiver(0).onERC721Received.selector`
bytes4 private constant _ERC721_RECEIVED = 0x150b7a02;
// Mapping from token ID to owner
mapping (uint256 => address) private _tokenOwner;
// Mapping from token ID to approved address
mapping (uint256 => address) private _tokenApprovals;
// Mapping from owner to number of owned token
mapping (address => uint256) private _ownedTokensCount;
// Mapping from owner to operator approvals
mapping (address => mapping (address => bool)) private _operatorApprovals;
bytes4 private constant _INTERFACE_ID_ERC721 = 0x80ac58cd;
/*
* 0x80ac58cd ===
* bytes4(keccak256('balanceOf(address)')) ^
* bytes4(keccak256('ownerOf(uint256)')) ^
* bytes4(keccak256('approve(address,uint256)')) ^
* bytes4(keccak256('getApproved(uint256)')) ^
* bytes4(keccak256('setApprovalForAll(address,bool)')) ^
* bytes4(keccak256('isApprovedForAll(address,address)')) ^
* bytes4(keccak256('transferFrom(address,address,uint256)')) ^
* bytes4(keccak256('safeTransferFrom(address,address,uint256)')) ^
* bytes4(keccak256('safeTransferFrom(address,address,uint256,bytes)'))
*/
constructor () public {
// register the supported interfaces to conform to ERC721 via ERC165
_registerInterface(_INTERFACE_ID_ERC721);
}
/**
* @dev Gets the balance of the specified address
* @param owner address to query the balance of
* @return uint256 representing the amount owned by the passed address
*/
function balanceOf(address owner) public view returns (uint256) {
require(owner != address(0));
return _ownedTokensCount[owner];
}
/**
* @dev Gets the owner of the specified token ID
* @param tokenId uint256 ID of the token to query the owner of
* @return owner address currently marked as the owner of the given token ID
*/
function ownerOf(uint256 tokenId) public view returns (address) {
address owner = _tokenOwner[tokenId];
require(owner != address(0));
return owner;
}
/**
* @dev Approves another address to transfer the given token ID
* The zero address indicates there is no approved address.
* There can only be one approved address per token at a given time.
* Can only be called by the token owner or an approved operator.
* @param to address to be approved for the given token ID
* @param tokenId uint256 ID of the token to be approved
*/
function approve(address to, uint256 tokenId) public {
address owner = ownerOf(tokenId);
require(to != owner);
require(msg.sender == owner || isApprovedForAll(owner, msg.sender));
_tokenApprovals[tokenId] = to;
emit Approval(owner, to, tokenId);
}
/**
* @dev Gets the approved address for a token ID, or zero if no address set
* Reverts if the token ID does not exist.
* @param tokenId uint256 ID of the token to query the approval of
* @return address currently approved for the given token ID
*/
function getApproved(uint256 tokenId) public view returns (address) {
require(_exists(tokenId));
return _tokenApprovals[tokenId];
}
/**
* @dev Sets or unsets the approval of a given operator
* An operator is allowed to transfer all tokens of the sender on their behalf
* @param to operator address to set the approval
* @param approved representing the status of the approval to be set
*/
function setApprovalForAll(address to, bool approved) public {
require(to != msg.sender);
_operatorApprovals[msg.sender][to] = approved;
emit ApprovalForAll(msg.sender, to, approved);
}
/**
* @dev Tells whether an operator is approved by a given owner
* @param owner owner address which you want to query the approval of
* @param operator operator address which you want to query the approval of
* @return bool whether the given operator is approved by the given owner
*/
function isApprovedForAll(address owner, address operator) public view returns (bool) {
return _operatorApprovals[owner][operator];
}
/**
* @dev Transfers the ownership of a given token ID to another address
* Usage of this method is discouraged, use `safeTransferFrom` whenever possible
* Requires the msg sender to be the owner, approved, or operator
* @param from current owner of the token
* @param to address to receive the ownership of the given token ID
* @param tokenId uint256 ID of the token to be transferred
*/
function transferFrom(address from, address to, uint256 tokenId) public {
require(_isApprovedOrOwner(msg.sender, tokenId));
_transferFrom(from, to, tokenId);
}
/**
* @dev Safely transfers the ownership of a given token ID to another address
* If the target address is a contract, it must implement `onERC721Received`,
* which is called upon a safe transfer, and return the magic value
* `bytes4(keccak256("onERC721Received(address,address,uint256,bytes)"))`; otherwise,
* the transfer is reverted.
*
* Requires the msg sender to be the owner, approved, or operator
* @param from current owner of the token
* @param to address to receive the ownership of the given token ID
* @param tokenId uint256 ID of the token to be transferred
*/
function safeTransferFrom(address from, address to, uint256 tokenId) public {
safeTransferFrom(from, to, tokenId, "");
}
/**
* @dev Safely transfers the ownership of a given token ID to another address
* If the target address is a contract, it must implement `onERC721Received`,
* which is called upon a safe transfer, and return the magic value
* `bytes4(keccak256("onERC721Received(address,address,uint256,bytes)"))`; otherwise,
* the transfer is reverted.
* Requires the msg sender to be the owner, approved, or operator
* @param from current owner of the token
* @param to address to receive the ownership of the given token ID
* @param tokenId uint256 ID of the token to be transferred
* @param _data bytes data to send along with a safe transfer check
*/
function safeTransferFrom(address from, address to, uint256 tokenId, bytes memory _data) public {
transferFrom(from, to, tokenId);
require(_checkOnERC721Received(from, to, tokenId, _data));
}
/**
* @dev Returns whether the specified token exists
* @param tokenId uint256 ID of the token to query the existence of
* @return whether the token exists
*/
function _exists(uint256 tokenId) internal view returns (bool) {
address owner = _tokenOwner[tokenId];
return owner != address(0);
}
/**
* @dev Returns whether the given spender can transfer a given token ID
* @param spender address of the spender to query
* @param tokenId uint256 ID of the token to be transferred
* @return bool whether the msg.sender is approved for the given token ID,
* is an operator of the owner, or is the owner of the token
*/
function _isApprovedOrOwner(address spender, uint256 tokenId) internal view returns (bool) {
address owner = ownerOf(tokenId);
return (spender == owner || getApproved(tokenId) == spender || isApprovedForAll(owner, spender));
}
/**
* @dev Internal function to mint a new token
* Reverts if the given token ID already exists
* @param to The address that will own the minted token
* @param tokenId uint256 ID of the token to be minted
*/
function _mint(address to, uint256 tokenId) internal {
require(to != address(0));
require(!_exists(tokenId));
_tokenOwner[tokenId] = to;
_ownedTokensCount[to] = _ownedTokensCount[to].add(1);
emit Transfer(address(0), to, tokenId);
}
/**
* @dev Internal function to burn a specific token
* Reverts if the token does not exist
* Deprecated, use _burn(uint256) instead.
* @param owner owner of the token to burn
* @param tokenId uint256 ID of the token being burned
*/
function _burn(address owner, uint256 tokenId) internal {
require(ownerOf(tokenId) == owner);
_clearApproval(tokenId);
_ownedTokensCount[owner] = _ownedTokensCount[owner].sub(1);
_tokenOwner[tokenId] = address(0);
emit Transfer(owner, address(0), tokenId);
}
/**
* @dev Internal function to burn a specific token
* Reverts if the token does not exist
* @param tokenId uint256 ID of the token being burned
*/
function _burn(uint256 tokenId) internal {
_burn(ownerOf(tokenId), tokenId);
}
/**
* @dev Internal function to transfer ownership of a given token ID to another address.
* As opposed to transferFrom, this imposes no restrictions on msg.sender.
* @param from current owner of the token
* @param to address to receive the ownership of the given token ID
* @param tokenId uint256 ID of the token to be transferred
*/
function _transferFrom(address from, address to, uint256 tokenId) internal {
require(ownerOf(tokenId) == from);
require(to != address(0));
_clearApproval(tokenId);
_ownedTokensCount[from] = _ownedTokensCount[from].sub(1);
_ownedTokensCount[to] = _ownedTokensCount[to].add(1);
_tokenOwner[tokenId] = to;
emit Transfer(from, to, tokenId);
}
/**
* @dev Internal function to invoke `onERC721Received` on a target address
* The call is not executed if the target address is not a contract
* @param from address representing the previous owner of the given token ID
* @param to target address that will receive the tokens
* @param tokenId uint256 ID of the token to be transferred
* @param _data bytes optional data to send along with the call
* @return whether the call correctly returned the expected magic value
*/
function _checkOnERC721Received(address from, address to, uint256 tokenId, bytes memory _data)
internal returns (bool)
{
if (!to.isContract()) {
return true;
}
bytes4 retval = IERC721Receiver(to).onERC721Received(msg.sender, from, tokenId, _data);
return (retval == _ERC721_RECEIVED);
}
/**
* @dev Private function to clear current approval of a given token ID
* @param tokenId uint256 ID of the token to be transferred
*/
function _clearApproval(uint256 tokenId) private {
if (_tokenApprovals[tokenId] != address(0)) {
_tokenApprovals[tokenId] = address(0);
}
}
}
// File: contracts/lib/github.com/OpenZeppelin/openzeppelin-solidity-2.1.2/contracts/access/Roles.sol
/**
* @title Roles
* @dev Library for managing addresses assigned to a Role.
*/
library Roles {
struct Role {
mapping (address => bool) bearer;
}
/**
* @dev give an account access to this role
*/
function add(Role storage role, address account) internal {
require(account != address(0));
require(!has(role, account));
role.bearer[account] = true;
}
/**
* @dev remove an account's access to this role
*/
function remove(Role storage role, address account) internal {
require(account != address(0));
require(has(role, account));
role.bearer[account] = false;
}
/**
* @dev check if an account has this role
* @return bool
*/
function has(Role storage role, address account) internal view returns (bool) {
require(account != address(0));
return role.bearer[account];
}
}
// File: contracts/lib/github.com/OpenZeppelin/openzeppelin-solidity-2.1.2/contracts/access/roles/MinterRole.sol
contract MinterRole {
using Roles for Roles.Role;
event MinterAdded(address indexed account);
event MinterRemoved(address indexed account);
Roles.Role private _minters;
constructor () internal {
_addMinter(msg.sender);
}
modifier onlyMinter() {
require(isMinter(msg.sender));
_;
}
function isMinter(address account) public view returns (bool) {
return _minters.has(account);
}
function addMinter(address account) public onlyMinter {
_addMinter(account);
}
function renounceMinter() public {
_removeMinter(msg.sender);
}
function _addMinter(address account) internal {
_minters.add(account);
emit MinterAdded(account);
}
function _removeMinter(address account) internal {
_minters.remove(account);
emit MinterRemoved(account);
}
}
// File: contracts/lib/github.com/OpenZeppelin/openzeppelin-solidity-2.1.2/contracts/token/ERC721/ERC721Mintable.sol
/**
* @title ERC721Mintable
* @dev ERC721 minting logic
*/
contract ERC721Mintable is ERC721, MinterRole {
/**
* @dev Function to mint tokens
* @param to The address that will receive the minted tokens.
* @param tokenId The token id to mint.
* @return A boolean that indicates if the operation was successful.
*/
function mint(address to, uint256 tokenId) public onlyMinter returns (bool) {
_mint(to, tokenId);
return true;
}
}
// File: contracts/lib/github.com/OpenZeppelin/openzeppelin-solidity-2.1.2/contracts/access/roles/PauserRole.sol
contract PauserRole {
using Roles for Roles.Role;
event PauserAdded(address indexed account);
event PauserRemoved(address indexed account);
Roles.Role private _pausers;
constructor () internal {
_addPauser(msg.sender);
}
modifier onlyPauser() {
require(isPauser(msg.sender));
_;
}
function isPauser(address account) public view returns (bool) {
return _pausers.has(account);
}
function addPauser(address account) public onlyPauser {
_addPauser(account);
}
function renouncePauser() public {
_removePauser(msg.sender);
}
function _addPauser(address account) internal {
_pausers.add(account);
emit PauserAdded(account);
}
function _removePauser(address account) internal {
_pausers.remove(account);
emit PauserRemoved(account);
}
}
// File: contracts/lib/github.com/OpenZeppelin/openzeppelin-solidity-2.1.2/contracts/lifecycle/Pausable.sol
/**
* @title Pausable
* @dev Base contract which allows children to implement an emergency stop mechanism.
*/
contract Pausable is PauserRole {
event Paused(address account);
event Unpaused(address account);
bool private _paused;
constructor () internal {
_paused = false;
}
/**
* @return true if the contract is paused, false otherwise.
*/
function paused() public view returns (bool) {
return _paused;
}
/**
* @dev Modifier to make a function callable only when the contract is not paused.
*/
modifier whenNotPaused() {
require(!_paused);
_;
}
/**
* @dev Modifier to make a function callable only when the contract is paused.
*/
modifier whenPaused() {
require(_paused);
_;
}
/**
* @dev called by the owner to pause, triggers stopped state
*/
function pause() public onlyPauser whenNotPaused {
_paused = true;
emit Paused(msg.sender);
}
/**
* @dev called by the owner to unpause, returns to normal state
*/
function unpause() public onlyPauser whenPaused {
_paused = false;
emit Unpaused(msg.sender);
}
}
// File: contracts/lib/github.com/OpenZeppelin/openzeppelin-solidity-2.1.2/contracts/token/ERC721/ERC721Pausable.sol
/**
* @title ERC721 Non-Fungible Pausable token
* @dev ERC721 modified with pausable transfers.
**/
contract ERC721Pausable is ERC721, Pausable {
function approve(address to, uint256 tokenId) public whenNotPaused {
super.approve(to, tokenId);
}
function setApprovalForAll(address to, bool approved) public whenNotPaused {
super.setApprovalForAll(to, approved);
}
function transferFrom(address from, address to, uint256 tokenId) public whenNotPaused {
super.transferFrom(from, to, tokenId);
}
}
// File: contracts/lib/github.com/OpenZeppelin/openzeppelin-solidity-2.1.2/contracts/token/ERC721/IERC721Enumerable.sol
/**
* @title ERC-721 Non-Fungible Token Standard, optional enumeration extension
* @dev See https://github.com/ethereum/EIPs/blob/master/EIPS/eip-721.md
*/
contract IERC721Enumerable is IERC721 {
function totalSupply() public view returns (uint256);
function tokenOfOwnerByIndex(address owner, uint256 index) public view returns (uint256 tokenId);
function tokenByIndex(uint256 index) public view returns (uint256);
}
// File: contracts/lib/github.com/OpenZeppelin/openzeppelin-solidity-2.1.2/contracts/token/ERC721/ERC721Enumerable.sol
/**
* @title ERC-721 Non-Fungible Token with optional enumeration extension logic
* @dev See https://github.com/ethereum/EIPs/blob/master/EIPS/eip-721.md
*/
contract ERC721Enumerable is ERC165, ERC721, IERC721Enumerable {
// Mapping from owner to list of owned token IDs
mapping(address => uint256[]) private _ownedTokens;
// Mapping from token ID to index of the owner tokens list
mapping(uint256 => uint256) private _ownedTokensIndex;
// Array with all token ids, used for enumeration
uint256[] private _allTokens;
// Mapping from token id to position in the allTokens array
mapping(uint256 => uint256) private _allTokensIndex;
bytes4 private constant _INTERFACE_ID_ERC721_ENUMERABLE = 0x780e9d63;
/**
* 0x780e9d63 ===
* bytes4(keccak256('totalSupply()')) ^
* bytes4(keccak256('tokenOfOwnerByIndex(address,uint256)')) ^
* bytes4(keccak256('tokenByIndex(uint256)'))
*/
/**
* @dev Constructor function
*/
constructor () public {
// register the supported interface to conform to ERC721 via ERC165
_registerInterface(_INTERFACE_ID_ERC721_ENUMERABLE);
}
/**
* @dev Gets the token ID at a given index of the tokens list of the requested owner
* @param owner address owning the tokens list to be accessed
* @param index uint256 representing the index to be accessed of the requested tokens list
* @return uint256 token ID at the given index of the tokens list owned by the requested address
*/
function tokenOfOwnerByIndex(address owner, uint256 index) public view returns (uint256) {
require(index < balanceOf(owner));
return _ownedTokens[owner][index];
}
/**
* @dev Gets the total amount of tokens stored by the contract
* @return uint256 representing the total amount of tokens
*/
function totalSupply() public view returns (uint256) {
return _allTokens.length;
}
/**
* @dev Gets the token ID at a given index of all the tokens in this contract
* Reverts if the index is greater or equal to the total number of tokens
* @param index uint256 representing the index to be accessed of the tokens list
* @return uint256 token ID at the given index of the tokens list
*/
function tokenByIndex(uint256 index) public view returns (uint256) {
require(index < totalSupply());
return _allTokens[index];
}
/**
* @dev Internal function to transfer ownership of a given token ID to another address.
* As opposed to transferFrom, this imposes no restrictions on msg.sender.
* @param from current owner of the token
* @param to address to receive the ownership of the given token ID
* @param tokenId uint256 ID of the token to be transferred
*/
function _transferFrom(address from, address to, uint256 tokenId) internal {
super._transferFrom(from, to, tokenId);
_removeTokenFromOwnerEnumeration(from, tokenId);
_addTokenToOwnerEnumeration(to, tokenId);
}
/**
* @dev Internal function to mint a new token
* Reverts if the given token ID already exists
* @param to address the beneficiary that will own the minted token
* @param tokenId uint256 ID of the token to be minted
*/
function _mint(address to, uint256 tokenId) internal {
super._mint(to, tokenId);
_addTokenToOwnerEnumeration(to, tokenId);
_addTokenToAllTokensEnumeration(tokenId);
}
/**
* @dev Internal function to burn a specific token
* Reverts if the token does not exist
* Deprecated, use _burn(uint256) instead
* @param owner owner of the token to burn
* @param tokenId uint256 ID of the token being burned
*/
function _burn(address owner, uint256 tokenId) internal {
super._burn(owner, tokenId);
_removeTokenFromOwnerEnumeration(owner, tokenId);
// Since tokenId will be deleted, we can clear its slot in _ownedTokensIndex to trigger a gas refund
_ownedTokensIndex[tokenId] = 0;
_removeTokenFromAllTokensEnumeration(tokenId);
}
/**
* @dev Gets the list of token IDs of the requested owner
* @param owner address owning the tokens
* @return uint256[] List of token IDs owned by the requested address
*/
function _tokensOfOwner(address owner) internal view returns (uint256[] storage) {
return _ownedTokens[owner];
}
/**
* @dev Private function to add a token to this extension's ownership-tracking data structures.
* @param to address representing the new owner of the given token ID
* @param tokenId uint256 ID of the token to be added to the tokens list of the given address
*/
function _addTokenToOwnerEnumeration(address to, uint256 tokenId) private {
_ownedTokensIndex[tokenId] = _ownedTokens[to].length;
_ownedTokens[to].push(tokenId);
}
/**
* @dev Private function to add a token to this extension's token tracking data structures.
* @param tokenId uint256 ID of the token to be added to the tokens list
*/
function _addTokenToAllTokensEnumeration(uint256 tokenId) private {
_allTokensIndex[tokenId] = _allTokens.length;
_allTokens.push(tokenId);
}
/**
* @dev Private function to remove a token from this extension's ownership-tracking data structures. Note that
* while the token is not assigned a new owner, the _ownedTokensIndex mapping is _not_ updated: this allows for
* gas optimizations e.g. when performing a transfer operation (avoiding double writes).
* This has O(1) time complexity, but alters the order of the _ownedTokens array.
* @param from address representing the previous owner of the given token ID
* @param tokenId uint256 ID of the token to be removed from the tokens list of the given address
*/
function _removeTokenFromOwnerEnumeration(address from, uint256 tokenId) private {
// To prevent a gap in from's tokens array, we store the last token in the index of the token to delete, and
// then delete the last slot (swap and pop).
uint256 lastTokenIndex = _ownedTokens[from].length.sub(1);
uint256 tokenIndex = _ownedTokensIndex[tokenId];
// When the token to delete is the last token, the swap operation is unnecessary
if (tokenIndex != lastTokenIndex) {
uint256 lastTokenId = _ownedTokens[from][lastTokenIndex];
_ownedTokens[from][tokenIndex] = lastTokenId; // Move the last token to the slot of the to-delete token
_ownedTokensIndex[lastTokenId] = tokenIndex; // Update the moved token's index
}
// This also deletes the contents at the last position of the array
_ownedTokens[from].length--;
// Note that _ownedTokensIndex[tokenId] hasn't been cleared: it still points to the old slot (now occcupied by
// lasTokenId, or just over the end of the array if the token was the last one).
}
/**
* @dev Private function to remove a token from this extension's token tracking data structures.
* This has O(1) time complexity, but alters the order of the _allTokens array.
* @param tokenId uint256 ID of the token to be removed from the tokens list
*/
function _removeTokenFromAllTokensEnumeration(uint256 tokenId) private {
// To prevent a gap in the tokens array, we store the last token in the index of the token to delete, and
// then delete the last slot (swap and pop).
uint256 lastTokenIndex = _allTokens.length.sub(1);
uint256 tokenIndex = _allTokensIndex[tokenId];
// When the token to delete is the last token, the swap operation is unnecessary. However, since this occurs so
// rarely (when the last minted token is burnt) that we still do the swap here to avoid the gas cost of adding
// an 'if' statement (like in _removeTokenFromOwnerEnumeration)
uint256 lastTokenId = _allTokens[lastTokenIndex];
_allTokens[tokenIndex] = lastTokenId; // Move the last token to the slot of the to-delete token
_allTokensIndex[lastTokenId] = tokenIndex; // Update the moved token's index
// This also deletes the contents at the last position of the array
_allTokens.length--;
_allTokensIndex[tokenId] = 0;
}
}
// File: contracts/lib/github.com/OpenZeppelin/openzeppelin-solidity-2.1.2/contracts/token/ERC721/IERC721Metadata.sol
/**
* @title ERC-721 Non-Fungible Token Standard, optional metadata extension
* @dev See https://github.com/ethereum/EIPs/blob/master/EIPS/eip-721.md
*/
contract 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);
}
// File: contracts/lib/github.com/OpenZeppelin/openzeppelin-solidity-2.1.2/contracts/token/ERC721/ERC721Metadata.sol
contract ERC721Metadata is ERC165, ERC721, IERC721Metadata {
// Token name
string private _name;
// Token symbol
string private _symbol;
// Optional mapping for token URIs
mapping(uint256 => string) private _tokenURIs;
bytes4 private constant _INTERFACE_ID_ERC721_METADATA = 0x5b5e139f;
/**
* 0x5b5e139f ===
* bytes4(keccak256('name()')) ^
* bytes4(keccak256('symbol()')) ^
* bytes4(keccak256('tokenURI(uint256)'))
*/
/**
* @dev Constructor function
*/
constructor (string memory name, string memory symbol) public {
_name = name;
_symbol = symbol;
// register the supported interfaces to conform to ERC721 via ERC165
_registerInterface(_INTERFACE_ID_ERC721_METADATA);
}
/**
* @dev Gets the token name
* @return string representing the token name
*/
function name() external view returns (string memory) {
return _name;
}
/**
* @dev Gets the token symbol
* @return string representing the token symbol
*/
function symbol() external view returns (string memory) {
return _symbol;
}
/**
* @dev Returns an URI for a given token ID
* Throws if the token ID does not exist. May return an empty string.
* @param tokenId uint256 ID of the token to query
*/
function tokenURI(uint256 tokenId) external view returns (string memory) {
require(_exists(tokenId));
return _tokenURIs[tokenId];
}
/**
* @dev Internal function to set the token URI for a given token
* Reverts if the token ID does not exist
* @param tokenId uint256 ID of the token to set its URI
* @param uri string URI to assign
*/
function _setTokenURI(uint256 tokenId, string memory uri) internal {
require(_exists(tokenId));
_tokenURIs[tokenId] = uri;
}
/**
* @dev Internal function to burn a specific token
* Reverts if the token does not exist
* Deprecated, use _burn(uint256) instead
* @param owner owner of the token to burn
* @param tokenId uint256 ID of the token being burned by the msg.sender
*/
function _burn(address owner, uint256 tokenId) internal {
super._burn(owner, tokenId);
// Clear metadata (if any)
if (bytes(_tokenURIs[tokenId]).length != 0) {
delete _tokenURIs[tokenId];
}
}
}
// File: contracts/lib/github.com/OpenZeppelin/openzeppelin-solidity-2.1.2/contracts/token/ERC721/ERC721FUll.sol
/**
* @title Full ERC721 Token
* This implementation includes all the required and some optional functionality of the ERC721 standard
* Moreover, it includes approve all functionality using operator terminology
* @dev see https://github.com/ethereum/EIPs/blob/master/EIPS/eip-721.md
*/
contract ERC721Full is ERC721, ERC721Enumerable, ERC721Metadata {
constructor (string memory name, string memory symbol) public ERC721Metadata(name, symbol) {
// solhint-disable-previous-line no-empty-blocks
}
}
// File: contracts/LandSectorAsset.sol
/* solhint-disable indent*/
pragma solidity 0.5.4;
contract LandSectorAsset is ERC721Full, ERC721Mintable, ERC721Pausable {
uint256 public constant SHARE_RATE_DECIMAL = 10**18;
uint16 public constant LEGENDARY_RARITY = 5;
uint16 public constant EPIC_RARITY = 4;
uint16 public constant RARE_RARITY = 3;
uint16 public constant UNCOMMON_RARITY = 2;
uint16 public constant COMMON_RARITY = 1;
uint16 public constant NO_LAND = 0;
string public tokenURIPrefix = "https://www.mycryptoheroes.net/metadata/land/";
mapping(uint16 => uint256) private landTypeToTotalVolume;
mapping(uint16 => uint256) private landTypeToSectorSupplyLimit;
mapping(uint16 => mapping(uint16 => uint256)) private landTypeAndRarityToSectorSupply;
mapping(uint16 => uint256[]) private landTypeToLandSectorList;
mapping(uint16 => uint256) private landTypeToLandSectorIndex;
mapping(uint16 => mapping(uint16 => uint256)) private landTypeAndRarityToLandSectorCount;
mapping(uint16 => uint256) private rarityToSectorVolume;
mapping(uint256 => bool) private allowed;
event MintEvent(
address indexed assetOwner,
uint256 tokenId,
uint256 at,
bytes32 indexed eventHash
);
constructor() public ERC721Full("MyCryptoHeroes:Land", "MCHL") {
rarityToSectorVolume[5] = 100;
rarityToSectorVolume[4] = 20;
rarityToSectorVolume[3] = 5;
rarityToSectorVolume[2] = 2;
rarityToSectorVolume[1] = 1;
landTypeToTotalVolume[NO_LAND] = 0;
}
function setSupplyAndSector(
uint16 _landType,
uint256 _totalVolume,
uint256 _sectorSupplyLimit,
uint256 legendarySupply,
uint256 epicSupply,
uint256 rareSupply,
uint256 uncommonSupply,
uint256 commonSupply
) external onlyMinter {
require(_landType != 0, "landType 0 is noland");
require(_totalVolume != 0, "totalVolume must not be 0");
require(getMintedSectorCount(_landType) == 0, "This LandType already exists");
require(
legendarySupply.mul(rarityToSectorVolume[LEGENDARY_RARITY])
.add(epicSupply.mul(rarityToSectorVolume[EPIC_RARITY]))
.add(rareSupply.mul(rarityToSectorVolume[RARE_RARITY]))
.add(uncommonSupply.mul(rarityToSectorVolume[UNCOMMON_RARITY]))
.add(commonSupply.mul(rarityToSectorVolume[COMMON_RARITY]))
== _totalVolume
);
require(
legendarySupply
.add(epicSupply)
.add(rareSupply)
.add(uncommonSupply)
.add(commonSupply)
== _sectorSupplyLimit
);
landTypeToTotalVolume[_landType] = _totalVolume;
landTypeToSectorSupplyLimit[_landType] = _sectorSupplyLimit;
landTypeAndRarityToSectorSupply[_landType][LEGENDARY_RARITY] = legendarySupply;
landTypeAndRarityToSectorSupply[_landType][EPIC_RARITY] = epicSupply;
landTypeAndRarityToSectorSupply[_landType][RARE_RARITY] = rareSupply;
landTypeAndRarityToSectorSupply[_landType][UNCOMMON_RARITY] = uncommonSupply;
landTypeAndRarityToSectorSupply[_landType][COMMON_RARITY] = commonSupply;
}
function approve(address _to, uint256 _tokenId) public {
require(allowed[_tokenId]);
super.approve(_to, _tokenId);
}
function transferFrom(address _from, address _to, uint256 _tokenId) public {
require(allowed[_tokenId]);
super.transferFrom(_from, _to, _tokenId);
}
function unLockToken(uint256 _tokenId) public onlyMinter {
allowed[_tokenId] = true;
}
function setTokenURIPrefix(string calldata _tokenURIPrefix) external onlyMinter {
tokenURIPrefix = _tokenURIPrefix;
}
function isAlreadyMinted(uint256 _tokenId) public view returns (bool) {
return _exists(_tokenId);
}
function isValidLandSector(uint256 _tokenId) public view returns (bool) {
uint16 rarity = getRarity(_tokenId);
if (!(rarityToSectorVolume[rarity] > 0)) {
return false;
}
uint16 landType = getLandType(_tokenId);
if (!(landTypeToTotalVolume[landType] > 0)) {
return false;
}
uint256 serial = _tokenId % 10000;
if (serial == 0) {
return false;
}
if (serial > landTypeAndRarityToSectorSupply[landType][rarity]) {
return false;
}
return true;
}
function canTransfer(uint256 _tokenId) public view returns (bool) {
return allowed[_tokenId];
}
function getTotalVolume(uint16 _landType) public view returns (uint256) {
return landTypeToTotalVolume[_landType];
}
function getSectorSupplyLimit(uint16 _landType) public view returns (uint256) {
return landTypeToSectorSupplyLimit[_landType];
}
function getLandType(uint256 _landSector) public view returns (uint16) {
uint16 _landType = uint16((_landSector.div(10000)) % 1000);
return _landType;
}
function getRarity(uint256 _landSector) public view returns (uint16) {
return uint16(_landSector.div(10**7));
}
function getMintedSectorCount(uint16 _landType) public view returns (uint256) {
return landTypeToLandSectorIndex[_landType];
}
function getMintedSectorCountByRarity(uint16 _landType, uint16 _rarity) public view returns (uint256) {
return landTypeAndRarityToLandSectorCount[_landType][_rarity];
}
function getSectorSupplyByRarity(uint16 _landType, uint16 _rarity) public view returns (uint256) {
return landTypeAndRarityToSectorSupply[_landType][_rarity];
}
function getMintedSectorList(uint16 _landType) public view returns (uint256[] memory) {
return landTypeToLandSectorList[_landType];
}
function getSectorVolumeByRarity(uint16 _rarity) public view returns (uint256) {
return rarityToSectorVolume[_rarity];
}
function getShareRateWithDecimal(uint256 _landSector) public view returns (uint256, uint256) {
return (
getSectorVolumeByRarity(getRarity(_landSector))
.mul(SHARE_RATE_DECIMAL)
.div(getTotalVolume(getLandType(_landSector))),
SHARE_RATE_DECIMAL
);
}
function mintLandSector(address _owner, uint256 _landSector, bytes32 _eventHash) public onlyMinter {
require(!isAlreadyMinted(_landSector));
require(isValidLandSector(_landSector));
uint16 _landType = getLandType(_landSector);
require(landTypeToLandSectorIndex[_landType] < landTypeToSectorSupplyLimit[_landType]);
uint16 rarity = getRarity(_landSector);
require(landTypeAndRarityToLandSectorCount[_landType][rarity] < landTypeAndRarityToSectorSupply[_landType][rarity], "supply over");
_mint(_owner, _landSector);
landTypeToLandSectorList[_landType].push(_landSector);
landTypeToLandSectorIndex[_landType]++;
landTypeAndRarityToLandSectorCount[_landType][rarity]++;
emit MintEvent(
_owner,
_landSector,
block.timestamp,
_eventHash
);
}
function tokenURI(uint256 _tokenId) public view returns (string memory) {
bytes32 tokenIdBytes;
if (_tokenId == 0) {
tokenIdBytes = "0";
} else {
uint256 value = _tokenId;
while (value > 0) {
tokenIdBytes = bytes32(uint256(tokenIdBytes) / (2 ** 8));
tokenIdBytes |= bytes32(((value % 10) + 48) * 2 ** (8 * 31));
value /= 10;
}
}
bytes memory prefixBytes = bytes(tokenURIPrefix);
bytes memory tokenURIBytes = new bytes(prefixBytes.length + tokenIdBytes.length);
uint8 i;
uint8 index = 0;
for (i = 0; i < prefixBytes.length; i++) {
tokenURIBytes[index] = prefixBytes[i];
index++;
}
for (i = 0; i < tokenIdBytes.length; i++) {
tokenURIBytes[index] = tokenIdBytes[i];
index++;
}
return string(tokenURIBytes);
}
}
/* solhint-enable indent*/
Read Contract
COMMON_RARITY 0xbd71a521 → uint16
EPIC_RARITY 0xcb338ea8 → uint16
LEGENDARY_RARITY 0xbd7c40c7 → uint16
NO_LAND 0x8c2c3e69 → uint16
RARE_RARITY 0xdb2c0b91 → uint16
SHARE_RATE_DECIMAL 0x8c75065f → uint256
UNCOMMON_RARITY 0x7c755b53 → uint16
balanceOf 0x70a08231 → uint256
canTransfer 0x4d4f6ea9 → bool
getApproved 0x081812fc → address
getLandType 0x410cb3f8 → uint16
getMintedSectorCount 0x639d6bc9 → uint256
getMintedSectorCountByRarity 0xe78482c1 → uint256
getMintedSectorList 0x74273066 → uint256[]
getRarity 0x48758697 → uint16
getSectorSupplyByRarity 0x35569239 → uint256
getSectorSupplyLimit 0xa457a62d → uint256
getSectorVolumeByRarity 0x0b32e757 → uint256
getShareRateWithDecimal 0x1ee2ec93 → uint256, uint256
getTotalVolume 0xfbba7b62 → uint256
isAlreadyMinted 0x9cc19bfb → bool
isApprovedForAll 0xe985e9c5 → bool
isMinter 0xaa271e1a → bool
isPauser 0x46fbf68e → bool
isValidLandSector 0x9989948f → bool
name 0x06fdde03 → string
ownerOf 0x6352211e → address
paused 0x5c975abb → bool
supportsInterface 0x01ffc9a7 → bool
symbol 0x95d89b41 → string
tokenByIndex 0x4f6ccce7 → uint256
tokenOfOwnerByIndex 0x2f745c59 → uint256
tokenURI 0xc87b56dd → string
tokenURIPrefix 0xc0ac9983 → string
totalSupply 0x18160ddd → uint256
Write Contract 16 functions
These functions modify contract state and require a wallet transaction to execute.
addMinter 0x983b2d56
address account
addPauser 0x82dc1ec4
address account
approve 0x095ea7b3
address _to
uint256 _tokenId
mint 0x40c10f19
address to
uint256 tokenId
returns: bool
mintLandSector 0x2239325b
address _owner
uint256 _landSector
bytes32 _eventHash
pause 0x8456cb59
No parameters
renounceMinter 0x98650275
No parameters
renouncePauser 0x6ef8d66d
No parameters
safeTransferFrom 0x42842e0e
address from
address to
uint256 tokenId
safeTransferFrom 0xb88d4fde
address from
address to
uint256 tokenId
bytes _data
setApprovalForAll 0xa22cb465
address to
bool approved
setSupplyAndSector 0x6efaed51
uint16 _landType
uint256 _totalVolume
uint256 _sectorSupplyLimit
uint256 legendarySupply
uint256 epicSupply
uint256 rareSupply
uint256 uncommonSupply
uint256 commonSupply
setTokenURIPrefix 0x99e0dd7c
string _tokenURIPrefix
transferFrom 0x23b872dd
address _from
address _to
uint256 _tokenId
unLockToken 0x6b2ba269
uint256 _tokenId
unpause 0x3f4ba83a
No parameters
Recent Transactions
No transactions found for this address