@etherisc/gif-next 0.0.2-719a8f1-103 → 0.0.2-71b939f-497

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (773) hide show
  1. package/README.md +252 -21
  2. package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +4 -0
  3. package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +1293 -0
  4. package/artifacts/contracts/authorization/AccessAdmin.sol/IAccessManagedChecker.dbg.json +4 -0
  5. package/artifacts/contracts/{shared/IOwnable.sol/IOwnable.json → authorization/AccessAdmin.sol/IAccessManagedChecker.json} +4 -4
  6. package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.dbg.json +4 -0
  7. package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.json +1206 -0
  8. package/artifacts/contracts/authorization/Authorization.sol/Authorization.dbg.json +4 -0
  9. package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +414 -0
  10. package/artifacts/contracts/authorization/IAccess.sol/IAccess.dbg.json +4 -0
  11. package/artifacts/contracts/{instance/module/access → authorization}/IAccess.sol/IAccess.json +1 -1
  12. package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.dbg.json +4 -0
  13. package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.json +1060 -0
  14. package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +4 -0
  15. package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +295 -0
  16. package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +4 -0
  17. package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.json +167 -0
  18. package/artifacts/contracts/authorization/ReleaseAccessManager.sol/ReleaseAccessManager.dbg.json +4 -0
  19. package/artifacts/contracts/authorization/ReleaseAccessManager.sol/ReleaseAccessManager.json +1196 -0
  20. package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +4 -0
  21. package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +253 -0
  22. package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +4 -0
  23. package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +1324 -0
  24. package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +4 -0
  25. package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +470 -0
  26. package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +4 -0
  27. package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +1018 -0
  28. package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +4 -0
  29. package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +1494 -0
  30. package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
  31. package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +862 -0
  32. package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +4 -0
  33. package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +917 -0
  34. package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +4 -0
  35. package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +984 -0
  36. package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.dbg.json +4 -0
  37. package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.json +22 -0
  38. package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.dbg.json +4 -0
  39. package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.json +1429 -0
  40. package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +4 -0
  41. package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +502 -0
  42. package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +4 -0
  43. package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +1979 -0
  44. package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +4 -0
  45. package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +470 -0
  46. package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.dbg.json +4 -0
  47. package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.json +376 -0
  48. package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.dbg.json +4 -0
  49. package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.json +1430 -0
  50. package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +4 -0
  51. package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +1177 -0
  52. package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +4 -0
  53. package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +1606 -0
  54. package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +4 -0
  55. package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +2281 -0
  56. package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +4 -0
  57. package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +808 -0
  58. package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
  59. package/artifacts/contracts/instance/IInstance.sol/IInstance.json +384 -1836
  60. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +4 -0
  61. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +722 -0
  62. package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
  63. package/artifacts/contracts/instance/Instance.sol/Instance.json +401 -2076
  64. package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +4 -0
  65. package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +1666 -0
  66. package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +4 -0
  67. package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +574 -0
  68. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +4 -0
  69. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +2286 -0
  70. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +4 -0
  71. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +1031 -0
  72. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +4 -0
  73. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +746 -0
  74. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +4 -0
  75. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +3668 -0
  76. package/artifacts/contracts/instance/RiskSet.sol/RiskSet.dbg.json +4 -0
  77. package/artifacts/contracts/instance/RiskSet.sol/RiskSet.json +810 -0
  78. package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +4 -0
  79. package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +318 -0
  80. package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +4 -0
  81. package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.json +137 -0
  82. package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +4 -0
  83. package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +10 -0
  84. package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.dbg.json +4 -0
  85. package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.json +223 -0
  86. package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.dbg.json +4 -0
  87. package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.json +181 -0
  88. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +4 -0
  89. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +129 -0
  90. package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +4 -0
  91. package/artifacts/contracts/instance/module/{bundle/IBundle.sol → IBundle.sol}/IBundle.json +1 -1
  92. package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +4 -0
  93. package/artifacts/contracts/instance/{base/ModuleBase.sol/ModuleBase.json → module/IComponents.sol/IComponents.json} +2 -2
  94. package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +4 -0
  95. package/artifacts/contracts/instance/module/{distribution/IDistribution.sol → IDistribution.sol}/IDistribution.json +1 -1
  96. package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +4 -0
  97. package/artifacts/contracts/instance/module/{policy/IPolicy.sol → IPolicy.sol}/IPolicy.json +1 -1
  98. package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +4 -0
  99. package/artifacts/contracts/instance/module/{risk/IRisk.sol → IRisk.sol}/IRisk.json +1 -1
  100. package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +4 -0
  101. package/artifacts/contracts/mock/Dip.sol/Dip.json +376 -0
  102. package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.dbg.json +4 -0
  103. package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.json +961 -0
  104. package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +4 -0
  105. package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +478 -0
  106. package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +4 -0
  107. package/artifacts/contracts/oracle/IOracle.sol/IOracle.json +52 -0
  108. package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +4 -0
  109. package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +776 -0
  110. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +4 -0
  111. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +709 -0
  112. package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +4 -0
  113. package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +877 -0
  114. package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +4 -0
  115. package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +990 -0
  116. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +4 -0
  117. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +766 -0
  118. package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +4 -0
  119. package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +1254 -0
  120. package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +4 -0
  121. package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +502 -0
  122. package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +4 -0
  123. package/artifacts/contracts/pool/BundleService.sol/BundleService.json +1360 -0
  124. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
  125. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +822 -0
  126. package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +4 -0
  127. package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +922 -0
  128. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
  129. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +909 -0
  130. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +4 -0
  131. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +1285 -0
  132. package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +4 -0
  133. package/artifacts/contracts/pool/Pool.sol/Pool.json +1029 -0
  134. package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +4 -0
  135. package/artifacts/contracts/pool/PoolService.sol/PoolService.json +1619 -0
  136. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
  137. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +794 -0
  138. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +4 -0
  139. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +806 -0
  140. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
  141. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +730 -0
  142. package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +4 -0
  143. package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +1148 -0
  144. package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +4 -0
  145. package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +470 -0
  146. package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +4 -0
  147. package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +1439 -0
  148. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
  149. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +858 -0
  150. package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +4 -0
  151. package/artifacts/contracts/{instance/service/IProductService.sol/IProductService.json → product/IApplicationService.sol/IApplicationService.json} +244 -345
  152. package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +4 -0
  153. package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +942 -0
  154. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +4 -0
  155. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +944 -0
  156. package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +4 -0
  157. package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +578 -0
  158. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +4 -0
  159. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +1005 -0
  160. package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +4 -0
  161. package/artifacts/contracts/{instance/base/ServiceBase.sol/ServiceBase.json → product/IRiskService.sol/IRiskService.json} +202 -153
  162. package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +4 -0
  163. package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +1313 -0
  164. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
  165. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +810 -0
  166. package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +4 -0
  167. package/artifacts/contracts/product/PricingService.sol/PricingService.json +923 -0
  168. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +4 -0
  169. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +786 -0
  170. package/artifacts/contracts/product/Product.sol/Product.dbg.json +4 -0
  171. package/artifacts/contracts/product/Product.sol/Product.json +1106 -0
  172. package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +4 -0
  173. package/artifacts/contracts/product/RiskService.sol/RiskService.json +638 -0
  174. package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +4 -0
  175. package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +718 -0
  176. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
  177. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +103 -2
  178. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
  179. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +791 -163
  180. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
  181. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +539 -188
  182. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
  183. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +5 -0
  184. package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
  185. package/artifacts/contracts/registry/Registry.sol/Registry.json +991 -147
  186. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +4 -0
  187. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +1899 -0
  188. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
  189. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +592 -215
  190. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
  191. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +379 -102
  192. package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +4 -0
  193. package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +205 -0
  194. package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +4 -0
  195. package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +1067 -0
  196. package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +4 -0
  197. package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +272 -0
  198. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +4 -0
  199. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +661 -0
  200. package/artifacts/contracts/shared/Component.sol/Component.dbg.json +4 -0
  201. package/artifacts/contracts/shared/Component.sol/Component.json +695 -0
  202. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +4 -0
  203. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +1835 -0
  204. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +4 -0
  205. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +846 -0
  206. package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +4 -0
  207. package/artifacts/contracts/{instance/base/InstanceBase.sol/InstanceBase.json → shared/ComponentVerifyingService.sol/ComponentVerifyingService.json} +223 -205
  208. package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +4 -0
  209. package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +488 -0
  210. package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.dbg.json +4 -0
  211. package/artifacts/contracts/{instance/IInstanceLinked.sol/IInstanceLinked.json → shared/ContractLib.sol/IInstanceAdminHelper.json} +5 -5
  212. package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.dbg.json +4 -0
  213. package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.json +30 -0
  214. package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +4 -0
  215. package/artifacts/contracts/shared/IComponent.sol/IComponent.json +620 -0
  216. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +4 -0
  217. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +1402 -0
  218. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +4 -0
  219. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +711 -0
  220. package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
  221. package/artifacts/contracts/{instance/base → shared}/IKeyValueStore.sol/IKeyValueStore.json +122 -172
  222. package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +4 -0
  223. package/artifacts/contracts/{instance/base → shared}/ILifecycle.sol/ILifecycle.json +35 -4
  224. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +4 -0
  225. package/artifacts/contracts/{instance/module/component/ComponentModule.sol/ComponentModule.json → shared/INftOwnable.sol/INftOwnable.json} +82 -52
  226. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +4 -0
  227. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +175 -0
  228. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
  229. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +94 -8
  230. package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +4 -0
  231. package/artifacts/contracts/{experiment/inheritance/IA.sol/ISharedA.json → shared/IRegistryLinked.sol/IRegistryLinked.json} +15 -17
  232. package/artifacts/contracts/shared/IService.sol/IService.dbg.json +4 -0
  233. package/artifacts/contracts/{instance/service/IComponentOwnerService.sol/IComponentOwnerService.json → shared/IService.sol/IService.json} +168 -182
  234. package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.dbg.json +4 -0
  235. package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.json +53 -0
  236. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +4 -0
  237. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +799 -0
  238. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +4 -0
  239. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +538 -0
  240. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +4 -0
  241. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +174 -0
  242. package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.dbg.json +4 -0
  243. package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.json +306 -0
  244. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
  245. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +101 -24
  246. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +4 -0
  247. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +198 -0
  248. package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
  249. package/artifacts/contracts/shared/Registerable.sol/Registerable.json +174 -12
  250. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +4 -0
  251. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +58 -0
  252. package/artifacts/contracts/shared/Service.sol/Service.dbg.json +4 -0
  253. package/artifacts/contracts/{instance/base/ComponentServiceBase.sol/ComponentServiceBase.json → shared/Service.sol/Service.json} +215 -166
  254. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +4 -0
  255. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +822 -0
  256. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.dbg.json +4 -0
  257. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.json +395 -0
  258. package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +4 -0
  259. package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +172 -0
  260. package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +4 -0
  261. package/artifacts/contracts/staking/IStaking.sol/IStaking.json +1435 -0
  262. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +4 -0
  263. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +1043 -0
  264. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +4 -0
  265. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +440 -0
  266. package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +4 -0
  267. package/artifacts/contracts/staking/Staking.sol/Staking.json +1816 -0
  268. package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.dbg.json +4 -0
  269. package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.json +205 -0
  270. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +4 -0
  271. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +780 -0
  272. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +4 -0
  273. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +587 -0
  274. package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +4 -0
  275. package/artifacts/contracts/staking/StakingService.sol/StakingService.json +1265 -0
  276. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +4 -0
  277. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +734 -0
  278. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +4 -0
  279. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +2283 -0
  280. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +4 -0
  281. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +607 -0
  282. package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +4 -0
  283. package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.json +10 -0
  284. package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +4 -0
  285. package/artifacts/contracts/type/Amount.sol/AmountLib.json +398 -0
  286. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +4 -0
  287. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +225 -0
  288. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
  289. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +203 -0
  290. package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +4 -0
  291. package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +104 -0
  292. package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +4 -0
  293. package/artifacts/contracts/type/Fee.sol/FeeLib.json +317 -0
  294. package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +4 -0
  295. package/artifacts/contracts/type/Key32.sol/Key32Lib.json +125 -0
  296. package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.dbg.json +4 -0
  297. package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.json +33 -0
  298. package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +4 -0
  299. package/artifacts/contracts/type/NftId.sol/NftIdLib.json +228 -0
  300. package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +4 -0
  301. package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +33 -0
  302. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +4 -0
  303. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +239 -0
  304. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
  305. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +209 -0
  306. package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +4 -0
  307. package/artifacts/contracts/type/Referral.sol/ReferralLib.json +142 -0
  308. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +4 -0
  309. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +204 -0
  310. package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +4 -0
  311. package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +180 -0
  312. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +4 -0
  313. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +369 -0
  314. package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +4 -0
  315. package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +246 -0
  316. package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +4 -0
  317. package/artifacts/contracts/type/Selector.sol/SelectorLib.json +129 -0
  318. package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +4 -0
  319. package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +10 -0
  320. package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +4 -0
  321. package/artifacts/contracts/type/StateId.sol/StateIdLib.json +105 -0
  322. package/artifacts/contracts/type/String.sol/StrLib.dbg.json +4 -0
  323. package/artifacts/contracts/type/String.sol/StrLib.json +132 -0
  324. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +4 -0
  325. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +312 -0
  326. package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +4 -0
  327. package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +548 -0
  328. package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +4 -0
  329. package/artifacts/contracts/type/Version.sol/VersionLib.json +177 -0
  330. package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +4 -0
  331. package/artifacts/contracts/type/Version.sol/VersionPartLib.json +68 -0
  332. package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.dbg.json +4 -0
  333. package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.json +55 -0
  334. package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.dbg.json +4 -0
  335. package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +618 -0
  336. package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +4 -0
  337. package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +129 -0
  338. package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +4 -0
  339. package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.json +78 -0
  340. package/contracts/authorization/AccessAdmin.sol +615 -0
  341. package/contracts/authorization/AccessManagerCloneable.sol +16 -0
  342. package/contracts/authorization/Authorization.sol +289 -0
  343. package/contracts/authorization/IAccess.sol +49 -0
  344. package/contracts/authorization/IAccessAdmin.sol +137 -0
  345. package/contracts/authorization/IAuthorization.sol +60 -0
  346. package/contracts/authorization/IServiceAuthorization.sol +40 -0
  347. package/contracts/authorization/ReleaseAccessManager.sol +38 -0
  348. package/contracts/authorization/ServiceAuthorization.sol +106 -0
  349. package/contracts/distribution/BasicDistribution.sol +139 -0
  350. package/contracts/distribution/BasicDistributionAuthorization.sol +47 -0
  351. package/contracts/distribution/Distribution.sol +284 -0
  352. package/contracts/distribution/DistributionService.sol +354 -0
  353. package/contracts/distribution/DistributionServiceManager.sol +39 -0
  354. package/contracts/distribution/IDistributionComponent.sol +52 -0
  355. package/contracts/distribution/IDistributionService.sol +100 -0
  356. package/contracts/examples/fire/DamageLevel.sol +59 -0
  357. package/contracts/examples/fire/FirePool.sol +86 -0
  358. package/contracts/examples/fire/FirePoolAuthorization.sol +34 -0
  359. package/contracts/examples/fire/FireProduct.sol +431 -0
  360. package/contracts/examples/fire/FireProductAuthorization.sol +44 -0
  361. package/contracts/examples/fire/FireUSD.sol +26 -0
  362. package/contracts/examples/unpermissioned/SimpleDistribution.sol +58 -0
  363. package/contracts/examples/unpermissioned/SimpleOracle.sol +137 -0
  364. package/contracts/examples/unpermissioned/SimplePool.sol +108 -0
  365. package/contracts/examples/unpermissioned/SimpleProduct.sol +345 -0
  366. package/contracts/instance/BundleSet.sol +130 -0
  367. package/contracts/instance/IInstance.sol +64 -46
  368. package/contracts/instance/IInstanceService.sol +74 -0
  369. package/contracts/instance/Instance.sol +226 -70
  370. package/contracts/instance/InstanceAdmin.sol +281 -0
  371. package/contracts/instance/InstanceAuthorizationV3.sol +217 -0
  372. package/contracts/instance/InstanceReader.sol +581 -0
  373. package/contracts/instance/InstanceService.sol +425 -0
  374. package/contracts/instance/InstanceServiceManager.sol +39 -0
  375. package/contracts/instance/InstanceStore.sol +287 -0
  376. package/contracts/instance/RiskSet.sol +119 -0
  377. package/contracts/instance/base/BalanceStore.sol +123 -0
  378. package/contracts/instance/base/Cloneable.sol +28 -0
  379. package/contracts/instance/base/ObjectCounter.sol +20 -0
  380. package/contracts/instance/base/ObjectLifecycle.sol +111 -0
  381. package/contracts/instance/base/ObjectSet.sol +78 -0
  382. package/contracts/instance/module/IAccess.sol +46 -0
  383. package/contracts/instance/module/IBundle.sol +20 -0
  384. package/contracts/instance/module/IComponents.sol +50 -0
  385. package/contracts/instance/module/IDistribution.sol +41 -0
  386. package/contracts/instance/module/IPolicy.sol +85 -0
  387. package/contracts/instance/module/IRisk.sol +12 -0
  388. package/contracts/{test/TestToken.sol → mock/Dip.sol} +6 -6
  389. package/contracts/oracle/BasicOracle.sol +47 -0
  390. package/contracts/oracle/BasicOracleAuthorization.sol +46 -0
  391. package/contracts/oracle/IOracle.sol +36 -0
  392. package/contracts/oracle/IOracleComponent.sol +33 -0
  393. package/contracts/oracle/IOracleService.sol +66 -0
  394. package/contracts/oracle/Oracle.sol +156 -0
  395. package/contracts/oracle/OracleService.sol +309 -0
  396. package/contracts/oracle/OracleServiceManager.sol +39 -0
  397. package/contracts/pool/BasicPool.sol +175 -0
  398. package/contracts/pool/BasicPoolAuthorization.sol +68 -0
  399. package/contracts/pool/BundleService.sol +423 -0
  400. package/contracts/pool/BundleServiceManager.sol +39 -0
  401. package/contracts/pool/IBundleService.sol +122 -0
  402. package/contracts/pool/IPoolComponent.sol +62 -0
  403. package/contracts/pool/IPoolService.sol +153 -0
  404. package/contracts/pool/Pool.sol +345 -0
  405. package/contracts/pool/PoolService.sol +612 -0
  406. package/contracts/pool/PoolServiceManager.sol +39 -0
  407. package/contracts/product/ApplicationService.sol +259 -0
  408. package/contracts/product/ApplicationServiceManager.sol +38 -0
  409. package/contracts/product/BasicProduct.sol +49 -0
  410. package/contracts/product/BasicProductAuthorization.sol +42 -0
  411. package/contracts/product/ClaimService.sol +614 -0
  412. package/contracts/product/ClaimServiceManager.sol +38 -0
  413. package/contracts/product/IApplicationService.sol +66 -0
  414. package/contracts/product/IClaimService.sol +123 -0
  415. package/contracts/product/IPolicyService.sol +90 -0
  416. package/contracts/product/IPricingService.sol +39 -0
  417. package/contracts/product/IProductComponent.sol +59 -0
  418. package/contracts/product/IRiskService.sol +33 -0
  419. package/contracts/product/PolicyService.sol +733 -0
  420. package/contracts/product/PolicyServiceManager.sol +39 -0
  421. package/contracts/product/PricingService.sol +300 -0
  422. package/contracts/product/PricingServiceManager.sol +39 -0
  423. package/contracts/product/Product.sol +427 -0
  424. package/contracts/product/RiskService.sol +107 -0
  425. package/contracts/product/RiskServiceManager.sol +39 -0
  426. package/contracts/registry/ChainNft.sol +99 -37
  427. package/contracts/registry/IRegistry.sol +139 -39
  428. package/contracts/registry/IRegistryService.sol +49 -16
  429. package/contracts/registry/ITransferInterceptor.sol +1 -1
  430. package/contracts/registry/Registry.sol +568 -333
  431. package/contracts/registry/RegistryAdmin.sol +451 -0
  432. package/contracts/registry/RegistryService.sol +144 -278
  433. package/contracts/registry/RegistryServiceManager.sol +28 -27
  434. package/contracts/registry/ReleaseLifecycle.sol +30 -0
  435. package/contracts/registry/ReleaseRegistry.sol +486 -0
  436. package/contracts/registry/ServiceAuthorizationV3.sol +175 -0
  437. package/contracts/registry/TokenRegistry.sol +315 -0
  438. package/contracts/shared/Component.sol +217 -0
  439. package/contracts/shared/ComponentService.sol +809 -0
  440. package/contracts/shared/ComponentServiceManager.sol +38 -0
  441. package/contracts/shared/ComponentVerifyingService.sol +128 -0
  442. package/contracts/shared/ContractLib.sol +224 -0
  443. package/contracts/shared/IComponent.sol +67 -0
  444. package/contracts/shared/IComponentService.sol +130 -0
  445. package/contracts/shared/IInstanceLinkedComponent.sol +41 -0
  446. package/contracts/shared/IKeyValueStore.sol +54 -0
  447. package/contracts/{instance/base → shared}/ILifecycle.sol +6 -5
  448. package/contracts/shared/INftOwnable.sol +25 -0
  449. package/contracts/shared/IPolicyHolder.sol +35 -0
  450. package/contracts/shared/IRegisterable.sol +16 -12
  451. package/contracts/shared/IRegistryLinked.sol +11 -0
  452. package/contracts/shared/IService.sol +25 -0
  453. package/contracts/shared/InitializableERC165.sol +27 -0
  454. package/contracts/shared/InstanceLinkedComponent.sol +205 -0
  455. package/contracts/shared/KeyValueStore.sol +131 -0
  456. package/contracts/shared/Lifecycle.sol +88 -0
  457. package/contracts/shared/NftIdSet.sol +65 -0
  458. package/contracts/shared/NftOwnable.sol +90 -50
  459. package/contracts/shared/PolicyHolder.sol +62 -0
  460. package/contracts/shared/Registerable.sol +37 -71
  461. package/contracts/shared/RegistryLinked.sol +38 -0
  462. package/contracts/shared/Service.sol +84 -0
  463. package/contracts/shared/TokenHandler.sol +389 -0
  464. package/contracts/shared/TokenHandlerDeployerLib.sol +20 -0
  465. package/contracts/staking/IStaking.sol +173 -0
  466. package/contracts/staking/IStakingService.sol +157 -0
  467. package/contracts/staking/StakeManagerLib.sol +224 -0
  468. package/contracts/staking/Staking.sol +505 -0
  469. package/contracts/staking/StakingLifecycle.sol +23 -0
  470. package/contracts/staking/StakingManager.sol +52 -0
  471. package/contracts/staking/StakingReader.sol +190 -0
  472. package/contracts/staking/StakingService.sol +440 -0
  473. package/contracts/staking/StakingServiceManager.sol +44 -0
  474. package/contracts/staking/StakingStore.sol +605 -0
  475. package/contracts/staking/TargetManagerLib.sol +211 -0
  476. package/contracts/{types → type}/AddressSet.sol +1 -1
  477. package/contracts/type/Amount.sol +150 -0
  478. package/contracts/{types → type}/Blocknumber.sol +27 -3
  479. package/contracts/type/ClaimId.sol +80 -0
  480. package/contracts/type/DistributorType.sol +55 -0
  481. package/contracts/type/Fee.sol +66 -0
  482. package/contracts/{types → type}/Key32.sol +10 -5
  483. package/contracts/type/Key32Set.sol +62 -0
  484. package/contracts/{types → type}/NftId.sol +28 -15
  485. package/contracts/type/NftIdSet.sol +62 -0
  486. package/contracts/type/ObjectType.sol +278 -0
  487. package/contracts/type/PayoutId.sol +82 -0
  488. package/contracts/type/Referral.sol +90 -0
  489. package/contracts/type/RequestId.sol +75 -0
  490. package/contracts/{types → type}/RiskId.sol +31 -5
  491. package/contracts/type/RoleId.sol +162 -0
  492. package/contracts/type/Seconds.sol +101 -0
  493. package/contracts/type/Selector.sol +102 -0
  494. package/contracts/{types → type}/StateId.sol +53 -5
  495. package/contracts/type/String.sol +53 -0
  496. package/contracts/{types → type}/Timestamp.sol +38 -15
  497. package/contracts/{types → type}/UFixed.sol +48 -12
  498. package/contracts/{types → type}/Version.sol +8 -2
  499. package/contracts/{shared → upgradeability}/IVersionable.sol +5 -48
  500. package/contracts/upgradeability/ProxyManager.sol +232 -0
  501. package/contracts/{shared → upgradeability}/UpgradableProxyWithAdmin.sol +2 -4
  502. package/contracts/upgradeability/Versionable.sol +59 -0
  503. package/package.json +12 -7
  504. package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +0 -4
  505. package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.json +0 -213
  506. package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +0 -4
  507. package/artifacts/contracts/components/Distribution.sol/Distribution.json +0 -445
  508. package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +0 -4
  509. package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.json +0 -177
  510. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +0 -4
  511. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +0 -177
  512. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +0 -4
  513. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +0 -308
  514. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +0 -4
  515. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +0 -207
  516. package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +0 -4
  517. package/artifacts/contracts/components/Pool.sol/Pool.json +0 -602
  518. package/artifacts/contracts/components/Product.sol/Product.dbg.json +0 -4
  519. package/artifacts/contracts/components/Product.sol/Product.json +0 -502
  520. package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +0 -4
  521. package/artifacts/contracts/experiment/errors/Require.sol/Require.json +0 -105
  522. package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +0 -4
  523. package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +0 -105
  524. package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +0 -4
  525. package/artifacts/contracts/experiment/inheritance/A.sol/A.json +0 -128
  526. package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +0 -4
  527. package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +0 -42
  528. package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +0 -4
  529. package/artifacts/contracts/experiment/inheritance/B.sol/B.json +0 -76
  530. package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +0 -4
  531. package/artifacts/contracts/experiment/inheritance/C.sol/C.json +0 -89
  532. package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +0 -4
  533. package/artifacts/contracts/experiment/inheritance/IA.sol/IA.json +0 -128
  534. package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +0 -4
  535. package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +0 -4
  536. package/artifacts/contracts/experiment/inheritance/IB.sol/IB.json +0 -50
  537. package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +0 -4
  538. package/artifacts/contracts/experiment/inheritance/IC.sol/IC.json +0 -63
  539. package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.dbg.json +0 -4
  540. package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +0 -59
  541. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +0 -4
  542. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.json +0 -124
  543. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +0 -4
  544. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.json +0 -74
  545. package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +0 -4
  546. package/artifacts/contracts/experiment/statemachine/SM.sol/SM.json +0 -124
  547. package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +0 -4
  548. package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.json +0 -207
  549. package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +0 -4
  550. package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.json +0 -10
  551. package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +0 -4
  552. package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.json +0 -10
  553. package/artifacts/contracts/instance/IInstanceLinked.sol/IInstanceLinked.dbg.json +0 -4
  554. package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +0 -4
  555. package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +0 -4
  556. package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.json +0 -113
  557. package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +0 -4
  558. package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +0 -4
  559. package/artifacts/contracts/instance/base/IService.sol/IService.dbg.json +0 -4
  560. package/artifacts/contracts/instance/base/IService.sol/IService.json +0 -344
  561. package/artifacts/contracts/instance/base/InstanceBase.sol/InstanceBase.dbg.json +0 -4
  562. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +0 -4
  563. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +0 -710
  564. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +0 -4
  565. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +0 -169
  566. package/artifacts/contracts/instance/base/ModuleBase.sol/ModuleBase.dbg.json +0 -4
  567. package/artifacts/contracts/instance/base/ServiceBase.sol/ServiceBase.dbg.json +0 -4
  568. package/artifacts/contracts/instance/module/access/Access.sol/AccessModule.dbg.json +0 -4
  569. package/artifacts/contracts/instance/module/access/Access.sol/AccessModule.json +0 -333
  570. package/artifacts/contracts/instance/module/access/IAccess.sol/IAccess.dbg.json +0 -4
  571. package/artifacts/contracts/instance/module/access/IAccess.sol/IAccessModule.dbg.json +0 -4
  572. package/artifacts/contracts/instance/module/access/IAccess.sol/IAccessModule.json +0 -333
  573. package/artifacts/contracts/instance/module/bundle/BundleModule.sol/BundleModule.dbg.json +0 -4
  574. package/artifacts/contracts/instance/module/bundle/BundleModule.sol/BundleModule.json +0 -297
  575. package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundle.dbg.json +0 -4
  576. package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundleModule.dbg.json +0 -4
  577. package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundleModule.json +0 -297
  578. package/artifacts/contracts/instance/module/component/ComponentModule.sol/ComponentModule.dbg.json +0 -4
  579. package/artifacts/contracts/instance/module/component/IComponent.sol/IComponent.dbg.json +0 -4
  580. package/artifacts/contracts/instance/module/component/IComponent.sol/IComponent.json +0 -10
  581. package/artifacts/contracts/instance/module/component/IComponent.sol/IComponentModule.dbg.json +0 -4
  582. package/artifacts/contracts/instance/module/component/IComponent.sol/IComponentModule.json +0 -117
  583. package/artifacts/contracts/instance/module/distribution/DistributionModule.sol/DistributionModule.dbg.json +0 -4
  584. package/artifacts/contracts/instance/module/distribution/DistributionModule.sol/DistributionModule.json +0 -10
  585. package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistribution.dbg.json +0 -4
  586. package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistributionModule.dbg.json +0 -4
  587. package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistributionModule.json +0 -10
  588. package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicy.dbg.json +0 -4
  589. package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicyModule.dbg.json +0 -4
  590. package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicyModule.json +0 -284
  591. package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.dbg.json +0 -4
  592. package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.json +0 -284
  593. package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPool.dbg.json +0 -4
  594. package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPool.json +0 -10
  595. package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPoolModule.dbg.json +0 -4
  596. package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPoolModule.json +0 -164
  597. package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.dbg.json +0 -4
  598. package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.json +0 -164
  599. package/artifacts/contracts/instance/module/risk/IRisk.sol/IRisk.dbg.json +0 -4
  600. package/artifacts/contracts/instance/module/risk/IRisk.sol/IRiskModule.dbg.json +0 -4
  601. package/artifacts/contracts/instance/module/risk/IRisk.sol/IRiskModule.json +0 -113
  602. package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.dbg.json +0 -4
  603. package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.json +0 -131
  604. package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasury.dbg.json +0 -4
  605. package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasury.json +0 -10
  606. package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasuryModule.dbg.json +0 -4
  607. package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasuryModule.json +0 -638
  608. package/artifacts/contracts/instance/module/treasury/TokenHandler.sol/TokenHandler.dbg.json +0 -4
  609. package/artifacts/contracts/instance/module/treasury/TokenHandler.sol/TokenHandler.json +0 -76
  610. package/artifacts/contracts/instance/module/treasury/TreasuryModule.sol/TreasuryModule.dbg.json +0 -4
  611. package/artifacts/contracts/instance/module/treasury/TreasuryModule.sol/TreasuryModule.json +0 -638
  612. package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +0 -4
  613. package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +0 -690
  614. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +0 -4
  615. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +0 -526
  616. package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +0 -4
  617. package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +0 -4
  618. package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.json +0 -369
  619. package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +0 -4
  620. package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +0 -484
  621. package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +0 -4
  622. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +0 -4
  623. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +0 -649
  624. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +0 -4
  625. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +0 -964
  626. package/artifacts/contracts/registry/IChainNft.sol/IChainNft.dbg.json +0 -4
  627. package/artifacts/contracts/registry/IChainNft.sol/IChainNft.json +0 -457
  628. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +0 -4
  629. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +0 -107
  630. package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +0 -4
  631. package/artifacts/contracts/shared/ERC165.sol/ERC165.json +0 -35
  632. package/artifacts/contracts/shared/IOwnable.sol/IOwnable.dbg.json +0 -4
  633. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +0 -4
  634. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +0 -205
  635. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +0 -4
  636. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +0 -344
  637. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +0 -4
  638. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +0 -129
  639. package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +0 -4
  640. package/artifacts/contracts/shared/Versionable.sol/Versionable.json +0 -228
  641. package/artifacts/contracts/test/TestDistribution.sol/TestDistribution.dbg.json +0 -4
  642. package/artifacts/contracts/test/TestDistribution.sol/TestDistribution.json +0 -445
  643. package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +0 -4
  644. package/artifacts/contracts/test/TestFee.sol/TestFee.json +0 -119
  645. package/artifacts/contracts/test/TestPool.sol/TestPool.dbg.json +0 -4
  646. package/artifacts/contracts/test/TestPool.sol/TestPool.json +0 -602
  647. package/artifacts/contracts/test/TestProduct.sol/TestProduct.dbg.json +0 -4
  648. package/artifacts/contracts/test/TestProduct.sol/TestProduct.json +0 -632
  649. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +0 -4
  650. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +0 -191
  651. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +0 -4
  652. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +0 -116
  653. package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +0 -4
  654. package/artifacts/contracts/test/TestService.sol/TestService.json +0 -472
  655. package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +0 -4
  656. package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +0 -338
  657. package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +0 -4
  658. package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +0 -218
  659. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +0 -4
  660. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +0 -270
  661. package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +0 -4
  662. package/artifacts/contracts/test/Usdc.sol/USDC.json +0 -338
  663. package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +0 -4
  664. package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.json +0 -10
  665. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +0 -4
  666. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +0 -174
  667. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +0 -4
  668. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +0 -10
  669. package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +0 -4
  670. package/artifacts/contracts/types/Fee.sol/FeeLib.json +0 -257
  671. package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +0 -4
  672. package/artifacts/contracts/types/Key32.sol/Key32Lib.json +0 -111
  673. package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +0 -4
  674. package/artifacts/contracts/types/NftId.sol/NftIdLib.json +0 -153
  675. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +0 -4
  676. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.json +0 -10
  677. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +0 -4
  678. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +0 -92
  679. package/artifacts/contracts/types/ReferralId.sol/ReferralIdLib.dbg.json +0 -4
  680. package/artifacts/contracts/types/ReferralId.sol/ReferralIdLib.json +0 -99
  681. package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +0 -4
  682. package/artifacts/contracts/types/RiskId.sol/RiskIdLib.json +0 -86
  683. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +0 -4
  684. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +0 -30
  685. package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +0 -4
  686. package/artifacts/contracts/types/StateId.sol/StateIdLib.json +0 -92
  687. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +0 -4
  688. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +0 -236
  689. package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.dbg.json +0 -4
  690. package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.json +0 -479
  691. package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +0 -4
  692. package/artifacts/contracts/types/Version.sol/VersionLib.json +0 -177
  693. package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +0 -4
  694. package/artifacts/contracts/types/Version.sol/VersionPartLib.json +0 -30
  695. package/contracts/components/BaseComponent.sol +0 -79
  696. package/contracts/components/Distribution.sol +0 -155
  697. package/contracts/components/IBaseComponent.sol +0 -19
  698. package/contracts/components/IDistributionComponent.sol +0 -46
  699. package/contracts/components/IPoolComponent.sol +0 -64
  700. package/contracts/components/IProductComponent.sol +0 -37
  701. package/contracts/components/Pool.sol +0 -246
  702. package/contracts/components/Product.sol +0 -299
  703. package/contracts/experiment/errors/Require.sol +0 -38
  704. package/contracts/experiment/errors/Revert.sol +0 -44
  705. package/contracts/experiment/inheritance/A.sol +0 -53
  706. package/contracts/experiment/inheritance/B.sol +0 -28
  707. package/contracts/experiment/inheritance/C.sol +0 -34
  708. package/contracts/experiment/inheritance/IA.sol +0 -13
  709. package/contracts/experiment/inheritance/IB.sol +0 -10
  710. package/contracts/experiment/inheritance/IC.sol +0 -12
  711. package/contracts/experiment/statemachine/Dummy.sol +0 -27
  712. package/contracts/experiment/statemachine/ISM.sol +0 -25
  713. package/contracts/experiment/statemachine/SM.sol +0 -57
  714. package/contracts/experiment/statemachine/SimpleStateMachine.sol +0 -31
  715. package/contracts/experiment/types/TypeA.sol +0 -47
  716. package/contracts/experiment/types/TypeB.sol +0 -29
  717. package/contracts/instance/IInstanceLinked.sol +0 -8
  718. package/contracts/instance/base/ComponentServiceBase.sol +0 -49
  719. package/contracts/instance/base/IInstanceBase.sol +0 -23
  720. package/contracts/instance/base/IKeyValueStore.sol +0 -50
  721. package/contracts/instance/base/IService.sol +0 -15
  722. package/contracts/instance/base/InstanceBase.sol +0 -89
  723. package/contracts/instance/base/KeyValueStore.sol +0 -161
  724. package/contracts/instance/base/Lifecycle.sol +0 -100
  725. package/contracts/instance/base/ModuleBase.sol +0 -57
  726. package/contracts/instance/base/ServiceBase.sol +0 -43
  727. package/contracts/instance/module/access/Access.sol +0 -149
  728. package/contracts/instance/module/access/IAccess.sol +0 -53
  729. package/contracts/instance/module/bundle/BundleModule.sol +0 -134
  730. package/contracts/instance/module/bundle/IBundle.sol +0 -53
  731. package/contracts/instance/module/component/ComponentModule.sol +0 -71
  732. package/contracts/instance/module/component/IComponent.sol +0 -28
  733. package/contracts/instance/module/distribution/DistributionModule.sol +0 -17
  734. package/contracts/instance/module/distribution/IDistribution.sol +0 -10
  735. package/contracts/instance/module/policy/IPolicy.sol +0 -63
  736. package/contracts/instance/module/policy/PolicyModule.sol +0 -91
  737. package/contracts/instance/module/pool/IPoolModule.sol +0 -41
  738. package/contracts/instance/module/pool/PoolModule.sol +0 -95
  739. package/contracts/instance/module/risk/IRisk.sol +0 -26
  740. package/contracts/instance/module/risk/RiskModule.sol +0 -62
  741. package/contracts/instance/module/treasury/ITreasury.sol +0 -84
  742. package/contracts/instance/module/treasury/TokenHandler.sol +0 -48
  743. package/contracts/instance/module/treasury/TreasuryModule.sol +0 -131
  744. package/contracts/instance/service/ComponentOwnerService.sol +0 -272
  745. package/contracts/instance/service/DistributionService.sol +0 -54
  746. package/contracts/instance/service/IComponentOwnerService.sol +0 -20
  747. package/contracts/instance/service/IDistributionService.sol +0 -12
  748. package/contracts/instance/service/IPoolService.sol +0 -37
  749. package/contracts/instance/service/IProductService.sol +0 -107
  750. package/contracts/instance/service/PoolService.sol +0 -149
  751. package/contracts/instance/service/ProductService.sol +0 -510
  752. package/contracts/registry/IChainNft.sol +0 -22
  753. package/contracts/shared/ContractDeployerLib.sol +0 -72
  754. package/contracts/shared/ERC165.sol +0 -21
  755. package/contracts/shared/IOwnable.sol +0 -6
  756. package/contracts/shared/ProxyManager.sol +0 -103
  757. package/contracts/shared/Versionable.sol +0 -147
  758. package/contracts/test/TestDistribution.sol +0 -22
  759. package/contracts/test/TestFee.sol +0 -25
  760. package/contracts/test/TestPool.sol +0 -27
  761. package/contracts/test/TestProduct.sol +0 -74
  762. package/contracts/test/TestRegisterable.sol +0 -18
  763. package/contracts/test/TestRoleId.sol +0 -14
  764. package/contracts/test/TestService.sol +0 -26
  765. package/contracts/test/TestVersion.sol +0 -44
  766. package/contracts/test/TestVersionable.sol +0 -17
  767. package/contracts/test/Usdc.sol +0 -26
  768. package/contracts/types/ChainId.sol +0 -38
  769. package/contracts/types/Fee.sol +0 -56
  770. package/contracts/types/NftIdSet.sol +0 -60
  771. package/contracts/types/ObjectType.sol +0 -131
  772. package/contracts/types/ReferralId.sol +0 -48
  773. package/contracts/types/RoleId.sol +0 -38
@@ -1,448 +1,525 @@
1
1
  // SPDX-License-Identifier: Apache-2.0
2
2
  pragma solidity ^0.8.20;
3
3
 
4
- import {IRegisterable} from "../shared/IRegisterable.sol";
5
- import {IService} from "../instance/base/IService.sol";
4
+ import {IERC165} from "@openzeppelin/contracts/utils/introspection/IERC165.sol";
5
+ import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
6
+ import {AccessManaged} from "@openzeppelin/contracts/access/manager/AccessManaged.sol";
7
+ import {Initializable} from "@openzeppelin/contracts/proxy/utils/Initializable.sol";
8
+
9
+ import {NftId, NftIdLib} from "../type/NftId.sol";
10
+ import {VersionPart, VersionPartLib} from "../type/Version.sol";
11
+ import {ObjectType, ObjectTypeLib, PROTOCOL, REGISTRY, SERVICE, INSTANCE, STAKE, STAKING, PRODUCT, DISTRIBUTION, DISTRIBUTOR, ORACLE, POOL, POLICY, BUNDLE} from "../type/ObjectType.sol";
6
12
 
7
- import {IChainNft} from "./IChainNft.sol";
8
13
  import {ChainNft} from "./ChainNft.sol";
9
14
  import {IRegistry} from "./IRegistry.sol";
10
- import {NftId, toNftId, zeroNftId, NftIdLib} from "../types/NftId.sol";
11
- import {Version, VersionPart, VersionLib} from "../types/Version.sol";
12
- import {ObjectType, PROTOCOL, REGISTRY, TOKEN, SERVICE, INSTANCE, STAKE, PRODUCT, DISTRIBUTION, ORACLE, POOL, POLICY, BUNDLE} from "../types/ObjectType.sol";
13
- import {ITransferInterceptor} from "./ITransferInterceptor.sol";
14
-
15
- import {IOwnable} from "../shared/IOwnable.sol";
16
- import {ERC165} from "../shared/ERC165.sol";
17
-
15
+ import {IRegisterable} from "../shared/IRegisterable.sol";
16
+ import {IStaking} from "../staking/IStaking.sol";
17
+ import {ReleaseRegistry} from "./ReleaseRegistry.sol";
18
+ import {TokenRegistry} from "./TokenRegistry.sol";
19
+ import {RegistryAdmin} from "./RegistryAdmin.sol";
18
20
 
19
- // IMPORTANT
21
+ /// @dev IMPORTANT
20
22
  // Each NFT minted by registry is accosiated with:
21
23
  // 1) NFT owner
22
24
  // 2) registred contract OR object stored in registered (parent) contract
23
- // Four registration flows:
24
- // 1) non IRegisterable address by registryOwner (TOKEN)
25
- // 2) IRegisterable address by registryOwner (SERVICE)
26
- // 3) IRegisterable address by approved service (INSTANCE, COMPONENT)
27
- // 4) state object by approved service (POLICY, BUNDLE, STAKE)
28
-
25
+ // Five registration flows:
26
+ // 1) registerService() -> registers IService address by ReleaseRegistry (ReleaseRegistry is set at deployment time)
27
+ // 2) register() -> registers IRegisterable address by IService (INSTANCE, PRODUCT, POOL, DISTRIBUTION, ORACLE)
28
+ // 3) -> registers object by IService (POLICY, BUNDLE, STAKE)
29
+ // 4) registerWithCustomType() -> registers IRegisterable address with custom type by IService
30
+ // 5) registerRegistry() -> registers IRegistry address (from different chain) by GifAdmin. Works ONLY on mainnet.
31
+ // Note: getters by address MUST not be used with this address (will return 0 or data related to different object or even revert)
32
+
33
+ /// @dev Chain Registry contract implementing IRegistry.
34
+ /// IRegistry for method details.
29
35
  contract Registry is
30
- ERC165,
36
+ Initializable,
37
+ AccessManaged,
31
38
  IRegistry
32
39
  {
33
- // register
34
- error NotRegistryService();
35
- error ZeroParentAddress();
36
- error ContractAlreadyRegistered(address objectAddress);
37
- error InvalidServiceVersion(VersionPart majorVersion);
38
- error ServiceNameAlreadyRegistered(string name, VersionPart majorVersion);
39
-
40
- // approve
41
- error NotOwner();
42
- error NotRegisteredContract(NftId registrarNftId);
43
- error NotService(NftId registrarNftId);
44
- error InvalidTypesCombination(ObjectType objectType, ObjectType parentType);
45
-
46
- uint256 public constant MAJOR_VERSION_MIN = 3;
40
+ /// @dev Protocol NFT ID
41
+ NftId public immutable PROTOCOL_NFT_ID;
42
+
43
+ /// @dev Gobal registry NFT ID
44
+ NftId public immutable GLOBAL_REGISTRY_NFT_ID;
45
+
46
+ /// @dev Gobal registry address on mainnet.
47
+ address public immutable GLOBAL_REGISTRY_ADDRESS;
48
+
49
+ /// @dev Registry NFT ID
50
+ NftId public immutable REGISTRY_NFT_ID;
51
+
52
+ /// @dev Deployer address that authorizes the initializer of this contract.
53
+ address public immutable DEPLOYER;
54
+
55
+ /// @dev Registry admin contract for this registry.
56
+ RegistryAdmin public immutable ADMIN;
57
+
58
+ /// @dev Chain NFT contract that keeps track of the ownership of all registered objects.
59
+ ChainNft public immutable CHAIN_NFT;
60
+
47
61
  address public constant NFT_LOCK_ADDRESS = address(0x1);
48
- uint256 public constant REGISTRY_SERVICE_TOKEN_SEQUENCE_ID = 3;
62
+ uint256 public constant REGISTRY_TOKEN_SEQUENCE_ID = 2;
63
+ uint256 public constant STAKING_TOKEN_SEQUENCE_ID = 3;
49
64
  string public constant EMPTY_URI = "";
50
65
 
51
- mapping(NftId nftId => ObjectInfo info) _info;
52
- mapping(address object => NftId nftId) _nftIdByAddress;
66
+ /// @dev keep track of different registries on different chains
67
+ mapping(uint256 chainId => NftId registryNftId) private _registryNftIdByChainId;
68
+ uint256[] private _chainId;
53
69
 
54
- mapping(NftId registrator => mapping(
55
- ObjectType objectType => bool)) _isApproved;
70
+ /// @dev keep track of object info and address reverse lookup
71
+ mapping(NftId nftId => ObjectInfo info) private _info;
72
+ mapping(address object => NftId nftId) private _nftIdByAddress;
56
73
 
57
- mapping(ObjectType objectType => mapping(
58
- ObjectType parentType => bool)) _isValidContractCombination;
74
+ /// @dev keep track of service addresses by version and domain
75
+ mapping(VersionPart version => mapping(ObjectType serviceDomain => address)) private _service;
76
+
77
+ mapping(ObjectType objectType => bool) private _coreTypes;
59
78
 
60
79
  mapping(ObjectType objectType => mapping(
61
- ObjectType parentType => bool)) _isValidObjectCombination;
80
+ ObjectType parentType => bool)) private _coreContractCombinations;
62
81
 
63
- mapping(NftId nftId => string name) _string;
64
- mapping(bytes32 serviceNameHash => mapping(
65
- VersionPart majorVersion => address service)) _service;
82
+ mapping(ObjectType objectType => mapping(
83
+ ObjectType parentType => bool)) private _coreObjectCombinations;
66
84
 
67
- NftId _registryNftId;
68
- NftId _serviceNftId; // set in stone upon registry creation
69
- IChainNft _chainNft;
70
- ChainNft _chainNftInternal;
85
+ NftId private _stakingNftId;
71
86
 
72
- /*
73
- modifier onlyInitialOwner() {
74
- if(
75
- msg.sender != getOwner() ||
76
- msg.sender != _info[_registryNftId].initialOwner) {
77
- revert NotInitialOwner();
78
- }
79
- }*/
80
-
81
- modifier onlyOwner() {
82
- if(msg.sender != getOwner()) {
83
- revert NotOwner();
84
- }
85
- _;
86
- }
87
+ ReleaseRegistry private _releaseRegistry;
88
+ address private _tokenRegistryAddress;
89
+ address private _stakingAddress;
87
90
 
88
- modifier onlyRegistryService() {
89
-
90
- if(msg.sender != _info[_serviceNftId].objectAddress) {
91
- revert NotRegistryService();
91
+ modifier onlyDeployer() {
92
+ if (msg.sender != DEPLOYER) {
93
+ revert ErrorRegistryCallerNotDeployer();
92
94
  }
93
95
  _;
94
96
  }
95
97
 
96
- constructor(address registryOwner, VersionPart majorVersion)
98
+ // TODO when create2 strategy is added to ignition:
99
+ // 1. move globalRegistry arg out from constructor into initialize()
100
+ // 2. add testRegistry_deployChainRegistryAtGlobalRegistryAddress
101
+ /// @dev Creates the registry contract and populates it with the protocol and registry objects.
102
+ /// Internally deploys the ChainNft contract.
103
+ constructor(RegistryAdmin admin, address globalRegistry)
104
+ AccessManaged(admin.authority())
97
105
  {
98
- require(registryOwner > address(0), "Registry: protocol owner is 0");
99
- require(majorVersion.toInt() == MAJOR_VERSION_MIN, "Registry: initial major version of registry service is not MAJOR_VERSION_MIN");
106
+ DEPLOYER = msg.sender;
107
+ ADMIN = admin;
108
+ GLOBAL_REGISTRY_ADDRESS = _getGlobalRegistryAddress(globalRegistry);
100
109
 
101
110
  // deploy NFT
102
- _chainNftInternal = new ChainNft(address(this));// adds 10kb to deployment size
103
- _chainNft = IChainNft(_chainNftInternal);
111
+ CHAIN_NFT = new ChainNft(address(this));
112
+ GLOBAL_REGISTRY_NFT_ID = NftIdLib.toNftId(
113
+ CHAIN_NFT.GLOBAL_REGISTRY_ID());
104
114
 
105
115
  // initial registry setup
106
- _registerProtocol();
107
- _registerRegistry(registryOwner);
108
- _registerRegistryService(registryOwner);
116
+ PROTOCOL_NFT_ID = _registerProtocol();
117
+ REGISTRY_NFT_ID = _registerRegistry();
109
118
 
110
- // set object parent relations
111
- _setupValidObjectParentCombinations();
119
+ // set object types and object parent relations
120
+ _setupValidCoreTypesAndCombinations();
121
+ }
122
+
123
+
124
+ /// @dev Wires release registry, token registry and staking contract to this registry.
125
+ /// MUST be called by release registry.
126
+ function initialize(
127
+ address releaseRegistry,
128
+ address tokenRegistry,
129
+ address staking
130
+ )
131
+ external
132
+ initializer()
133
+ onlyDeployer()
134
+ {
135
+ // store links to supporting contracts
136
+ _releaseRegistry = ReleaseRegistry(releaseRegistry);
137
+ _tokenRegistryAddress = tokenRegistry;
138
+ _stakingAddress = staking;
112
139
 
113
- _registerInterface(type(IRegistry).interfaceId);
114
- _registerInterface(type(IOwnable).interfaceId);
140
+ // register staking contract
141
+ _stakingNftId = _registerStaking();
115
142
  }
116
143
 
117
- /// @dev registry protects only from tampering existing records and invalid types pairs
118
- // IMPORTANT: rare case when parentNftId is not registered and == next nftId -> technincally this is ZeroParentAddress error
119
- // to catch this check parent address before minting !!!!
120
- // TODO service registration means its approval for some type?
121
- function register(ObjectInfo memory info)
144
+ /// @inheritdoc IRegistry
145
+ function registerRegistry(
146
+ NftId nftId,
147
+ uint256 chainId,
148
+ address registryAddress
149
+ )
150
+ external
151
+ restricted()
152
+ {
153
+ // registration of chain registries only allowed on mainnet
154
+ if (block.chainid != 1) {
155
+ revert ErrorRegistryNotOnMainnet(block.chainid);
156
+ }
157
+
158
+ // registry chain id is not zero
159
+ if(chainId == 0) {
160
+ revert ErrorRegistryChainRegistryChainIdZero(nftId);
161
+ }
162
+
163
+ // registry address is not zero
164
+ if (registryAddress == address(0)) {
165
+ revert ErrorRegistryChainRegistryAddressZero(nftId, chainId);
166
+ }
167
+
168
+ // registry nft id matches registry chain id
169
+ uint256 expectedRegistryId = CHAIN_NFT.calculateTokenId(REGISTRY_TOKEN_SEQUENCE_ID, chainId);
170
+ if (nftId != NftIdLib.toNftId(expectedRegistryId)) {
171
+ revert ErrorRegistryChainRegistryNftIdInvalid(nftId, chainId);
172
+ }
173
+
174
+ emit LogChainRegistryRegistration(nftId, chainId, registryAddress);
175
+
176
+ _registerRegistryForNft(
177
+ chainId,
178
+ ObjectInfo({
179
+ nftId: nftId,
180
+ parentNftId: REGISTRY_NFT_ID,
181
+ objectType: REGISTRY(),
182
+ isInterceptor: false,
183
+ objectAddress: registryAddress,
184
+ initialOwner: NFT_LOCK_ADDRESS,
185
+ data: ""
186
+ }),
187
+ false); // do not update address lookup for objects on a different chain
188
+ }
189
+
190
+ // TODO limit service owner to registry admin?
191
+ /// @inheritdoc IRegistry
192
+ function registerService(
193
+ ObjectInfo memory info,
194
+ VersionPart version,
195
+ ObjectType domain
196
+ )
122
197
  external
123
- onlyRegistryService
198
+ restricted()
124
199
  returns(NftId nftId)
125
200
  {
126
- ObjectType objectType = info.objectType;
127
- NftId parentNftId = info.parentNftId;
128
- ObjectInfo memory parentInfo = _info[parentNftId];
129
- ObjectType parentType = parentInfo.objectType; // see function header
130
- address parentAddress = parentInfo.objectAddress;
201
+ // service address is defined
202
+ address service = info.objectAddress;
203
+ if(service == address(0)) {
204
+ revert ErrorRegistryServiceAddressZero();
205
+ }
131
206
 
132
- // parent is contract -> need to check? -> check before minting
133
- // special case: global registry nft as parent when not on mainnet -> global registry address is 0
134
- // special case: when parentNftId == _chainNft.mint(), check for zero parent address before mint
135
- // special case: when parentNftId == _chainNft.mint() && objectAddress == initialOwner
136
- if(parentAddress == address(0)) {
137
- revert ZeroParentAddress();
207
+ // version is defined
208
+ if(version.eqz()) {
209
+ revert ErrorRegistryServiceVersionZero(service);
210
+ }
211
+ // service domain is defined
212
+ if(domain.eqz()) {
213
+ revert ErrorRegistryServiceDomainZero(service, version);
138
214
  }
139
215
 
140
- address interceptor = _getInterceptor(info.isInterceptor, info.objectAddress, parentInfo.isInterceptor, parentAddress);
216
+ // service has proper type
217
+ if(info.objectType != SERVICE()) {
218
+ revert ErrorRegistryNotService(service, info.objectType);
219
+ }
141
220
 
142
- uint256 mintedTokenId = _chainNft.mint(
143
- info.initialOwner,
144
- interceptor,
145
- EMPTY_URI);
146
- nftId = toNftId(mintedTokenId);
221
+ // service parent has registry type
222
+ if(info.parentNftId != REGISTRY_NFT_ID) {
223
+ revert ErrorRegistryServiceParentNotRegistry(service, version, info.parentNftId);
224
+ }
147
225
 
148
- // TODO move nftId out of info struct
149
- // getters by nftId -> return struct without nftId
150
- // getters by address -> return nftId AND struct
151
- info.nftId = nftId;
152
- _info[nftId] = info;
226
+ // service has not already been registered
227
+ if(_service[version][domain] != address(0)) {
228
+ revert ErrorRegistryServiceDomainAlreadyRegistered(service, version, domain);
229
+ }
153
230
 
154
- if(info.objectAddress > address(0))
155
- {
156
- // TODO if need to add types latter -> at least call this check from registry service
157
- // parent is registered + object-parent types are valid
158
- if(_isValidContractCombination[objectType][parentType] == false) {
159
- revert InvalidTypesCombination(objectType, parentType);
160
- }
231
+ _service[version][domain] = service;
161
232
 
162
- address contractAddress = info.objectAddress;
233
+ emit LogServiceRegistration(version, domain);
163
234
 
164
- if(_nftIdByAddress[contractAddress].gtz()) {
165
- revert ContractAlreadyRegistered(contractAddress);
166
- }
235
+ nftId = _register(info);
236
+ }
237
+
238
+
239
+ /// @inheritdoc IRegistry
240
+ function register(ObjectInfo memory info)
241
+ external
242
+ restricted()
243
+ returns(NftId nftId)
244
+ {
245
+ address objectAddress = info.objectAddress;
246
+ ObjectType objectType = info.objectType;
247
+
248
+ // this indidirectly enforces that the parent is registered
249
+ // parentType would be zero for a non-registered parent which is never a valid type combination
250
+ ObjectType parentType = _info[info.parentNftId].objectType;
167
251
 
168
- _nftIdByAddress[contractAddress] = nftId;
169
-
170
- // special case
171
- if(objectType == SERVICE())
172
- {
173
- (
174
- string memory serviceName,
175
- VersionPart majorVersion
176
- ) = abi.decode(info.data, (string, VersionPart));
177
- bytes32 serviceNameHash = keccak256(abi.encode(serviceName));
178
-
179
- // TODO MUST guarantee consistency of registerable.getVersion() and majorVersion here
180
- // TODO update _serviceNftId when registryService with new major version is registered? -> it is fixed in current setup
181
- // TODO do not use names -> each object type is registered by corresponding service -> conflicting with approve()
182
- if(
183
- majorVersion.toInt() < MAJOR_VERSION_MIN ||
184
- (majorVersion.toInt() > MAJOR_VERSION_MIN &&
185
- _service[serviceNameHash][VersionLib.toVersionPart(majorVersion.toInt() - 1)] == address(0) )
186
- ) {
187
- revert InvalidServiceVersion(majorVersion);
188
- }
189
-
190
- if(_service[serviceNameHash][majorVersion] != address(0)) {
191
- revert ServiceNameAlreadyRegistered(serviceName, majorVersion);
192
- }
193
-
194
- _string[nftId] = serviceName;
195
- _service[serviceNameHash][majorVersion] = contractAddress;
196
-
197
- emit LogServiceNameRegistration(serviceName, majorVersion);
252
+ // check type combinations for core objects
253
+ if(objectAddress == address(0)) {
254
+ if(_coreObjectCombinations[objectType][parentType] == false) {
255
+ revert ErrorRegistryTypesCombinationInvalid(objectAddress, objectType, parentType);
198
256
  }
199
257
  }
200
- else
201
- {
202
- if(_isValidObjectCombination[objectType][parentType] == false) {
203
- revert InvalidTypesCombination(objectType, parentType);
258
+ // check type combinations for contract objects
259
+ else {
260
+ if(_coreContractCombinations[objectType][parentType] == false) {
261
+ revert ErrorRegistryTypesCombinationInvalid(objectAddress, objectType, parentType);
204
262
  }
205
263
  }
206
264
 
207
- emit LogRegistration(nftId, info.parentNftId, info.objectType, info.objectAddress, info.initialOwner);
265
+ nftId = _register(info);
208
266
  }
209
267
 
210
- function registerFrom(
211
- address from,
212
- ObjectInfo memory info
213
- ) external returns (NftId nftId)
214
- {
215
- revert();
216
- }
217
-
218
268
 
219
- /// @dev
220
- // msg.sender - registry owner
221
- // CAN approve only registered service contract
222
- // CAN approve any combination specified in _isValidCombination
223
- // CAN NOT approve itself
224
- // TODO in case where exists exactly one registered service per objectType (and major version):
225
- // - registration and approve is a single operation, no need for separate approve() function
226
- // - then approve can be used to adding new valid object-parent combinations???
227
- function approve(
228
- NftId serviceNftId,
229
- ObjectType objectType,
230
- ObjectType parentType
231
- )
232
- public
233
- onlyOwner()
269
+ /// @inheritdoc IRegistry
270
+ function registerWithCustomType(ObjectInfo memory info)
271
+ external
272
+ restricted()
273
+ returns(NftId nftId)
234
274
  {
235
- address serviceAddress = _info[serviceNftId].objectAddress;
236
-
237
- if(_nftIdByAddress[serviceAddress].eqz()) {
238
- revert NotRegisteredContract(serviceNftId);
239
- }
275
+ ObjectType objectType = info.objectType;
276
+ ObjectType parentType = _info[info.parentNftId].objectType;
240
277
 
241
- if(_info[serviceNftId].objectType != SERVICE()) {
242
- revert NotService(serviceNftId);
278
+ if(_coreTypes[objectType]) {
279
+ revert ErrorRegistryCoreTypeRegistration();
243
280
  }
244
281
 
245
282
  if(
246
- _isValidContractCombination[objectType][parentType] == false &&
247
- _isValidObjectCombination[objectType][parentType] == false) {
248
- revert InvalidTypesCombination(objectType, parentType);
283
+ objectType == ObjectTypeLib.zero() ||
284
+ parentType == ObjectTypeLib.zero() ||
285
+ parentType == PROTOCOL() ||
286
+ parentType == SERVICE()
287
+ ) {
288
+ revert ErrorRegistryTypesCombinationInvalid(info.objectAddress, objectType, parentType);
249
289
  }
250
290
 
251
- _isApproved[serviceNftId][objectType] = true;
291
+ nftId = _register(info);
292
+ }
252
293
 
253
- emit LogApproval(serviceNftId, objectType);
294
+
295
+ /// @dev earliest GIF major version
296
+ function getInitialVersion() external view returns (VersionPart) {
297
+ return VersionPartLib.toVersionPart(_releaseRegistry.INITIAL_GIF_VERSION());
254
298
  }
255
299
 
256
- /// @dev returns false for registry owner nft
257
- // TODO allowance by address?
258
- // TODO checked by registry service -> but registry owner can upgrade registry service not to check allowance....
259
- function allowance(
260
- NftId nftId,
261
- ObjectType object
262
- )
263
- public
264
- view
265
- returns (bool)
266
- {
267
- return _isApproved[nftId][object];
300
+ /// @dev next GIF release version to be released
301
+ function getNextVersion() external view returns (VersionPart) {
302
+ return _releaseRegistry.getNextVersion();
303
+ }
304
+
305
+ /// @dev latest active GIF release version
306
+ function getLatestVersion() external view returns (VersionPart) {
307
+ return _releaseRegistry.getLatestVersion();
308
+ }
309
+
310
+ function getReleaseInfo(VersionPart version) external view returns (ReleaseInfo memory) {
311
+ return _releaseRegistry.getReleaseInfo(version);
312
+ }
313
+
314
+ function chainIds() public view returns (uint256) {
315
+ return _chainId.length;
316
+ }
317
+
318
+ function getChainId(uint256 idx) public view returns (uint256) {
319
+ return _chainId[idx];
320
+ }
321
+
322
+ function getRegistryNftId(uint256 chainId) public view returns (NftId nftId) {
323
+ return _registryNftIdByChainId[chainId];
268
324
  }
269
325
 
270
- // from IRegistry
271
- function getObjectCount() external view override returns (uint256) {
272
-
273
- return _chainNft.totalSupply();
326
+ function getObjectCount() external view returns (uint256) {
327
+ return CHAIN_NFT.totalSupply();
274
328
  }
275
329
 
276
- function getNftId(address object) external view override returns (NftId id) {
330
+ function getNftId() external view returns (NftId nftId) {
331
+ return REGISTRY_NFT_ID;
332
+ }
333
+
334
+ function getProtocolNftId() external view returns (NftId nftId) {
335
+ return PROTOCOL_NFT_ID;
336
+ }
337
+
338
+ function getNftIdForAddress(address object) external view returns (NftId id) {
277
339
  return _nftIdByAddress[object];
278
340
  }
279
341
 
280
- function ownerOf(NftId nftId) public view override returns (address) {
281
- return _chainNft.ownerOf(nftId.toInt());
342
+ function ownerOf(NftId nftId) public view returns (address) {
343
+ return CHAIN_NFT.ownerOf(nftId.toInt());
344
+ }
345
+
346
+ function isOwnerOf(NftId nftId, address expectedOwner) public view returns (bool) {
347
+ return CHAIN_NFT.ownerOf(nftId.toInt()) == expectedOwner;
282
348
  }
283
349
 
284
350
  function ownerOf(address contractAddress) public view returns (address) {
285
-
286
- return _chainNft.ownerOf(_nftIdByAddress[contractAddress].toInt());
351
+ return CHAIN_NFT.ownerOf(_nftIdByAddress[contractAddress].toInt());
287
352
  }
288
353
 
289
- function getObjectInfo(NftId nftId) external view override returns (ObjectInfo memory) {
354
+ function getObjectInfo(NftId nftId) external view returns (ObjectInfo memory) {
290
355
  return _info[nftId];
291
356
  }
292
357
 
293
- function getObjectInfo(address object) external view override returns (ObjectInfo memory) {
294
-
358
+ function isObjectType(address contractAddress, ObjectType expectedObjectType) external view returns (bool) {
359
+ NftId nftId = _nftIdByAddress[contractAddress];
360
+ return isObjectType(nftId, expectedObjectType);
361
+ }
362
+
363
+ function isObjectType(NftId nftId, ObjectType expectedObjectType) public view returns (bool) {
364
+ return _info[nftId].objectType == expectedObjectType;
365
+ }
366
+
367
+ function getObjectAddress(NftId nftId) external view returns (address) {
368
+ return _info[nftId].objectAddress;
369
+ }
370
+
371
+ function getObjectInfo(address object) external view returns (ObjectInfo memory) {
295
372
  return _info[_nftIdByAddress[object]];
296
373
  }
297
374
 
298
- function isRegistered(NftId nftId) public view override returns (bool) {
375
+ function isRegistered(NftId nftId) public view returns (bool) {
299
376
  return _info[nftId].objectType.gtz();
300
377
  }
301
378
 
302
- function isRegistered(address object) external view override returns (bool) {
379
+ function isRegistered(address object) external view returns (bool) {
303
380
  return _nftIdByAddress[object].gtz();
304
381
  }
305
382
 
306
- function getServiceName(NftId nftId) external view returns (string memory) {
307
- return _string[nftId];
383
+ function isRegisteredService(address object) external view returns (bool) {
384
+ return _info[_nftIdByAddress[object]].objectType == SERVICE();
308
385
  }
309
386
 
310
- // special case to retrive a gif service
311
- function getServiceAddress(
312
- string memory serviceName,
313
- VersionPart majorVersion
314
- ) external view returns (address)
315
- {
316
- bytes32 serviceNameHash = keccak256(abi.encode(serviceName));
317
- return _service[serviceNameHash][majorVersion];
387
+ function isRegisteredComponent(address object) external view returns (bool) {
388
+ NftId objectParentNftId = _info[_nftIdByAddress[object]].parentNftId;
389
+ return _info[objectParentNftId].objectType == INSTANCE();
318
390
  }
319
391
 
320
- function getChainNft() external view override returns (IChainNft) {
321
- return _chainNft;
392
+ function isActiveRelease(VersionPart version) external view returns (bool)
393
+ {
394
+ return _releaseRegistry.isActiveRelease(version);
322
395
  }
323
396
 
324
- // from IOwnable
325
- function getOwner() public view returns (address owner) {
326
- return ownerOf(address(this));
397
+ function getStakingAddress() external view returns (address staking) {
398
+ return _stakingAddress;
327
399
  }
328
400
 
329
- // Internals, called only in constructor
401
+ function getTokenRegistryAddress() external view returns (address tokenRegistry) {
402
+ return _tokenRegistryAddress;
403
+ }
330
404
 
331
- /// @dev protocol registration used to anchor the dip ecosystem relations
332
- function _registerProtocol()
333
- internal
405
+ function getServiceAddress(
406
+ ObjectType serviceDomain,
407
+ VersionPart releaseVersion
408
+ ) external view returns (address service)
334
409
  {
335
- uint256 protocolId = _chainNftInternal.PROTOCOL_NFT_ID();
336
- NftId protocolNftId = toNftId(protocolId);
410
+ service = _service[releaseVersion][serviceDomain];
411
+ }
337
412
 
338
- _chainNftInternal.mint(NFT_LOCK_ADDRESS, protocolId);
413
+ function getReleaseRegistryAddress() external view returns (address) {
414
+ return address(_releaseRegistry);
415
+ }
339
416
 
340
- _info[protocolNftId] = ObjectInfo(
341
- protocolNftId,
342
- zeroNftId(), // parent
343
- PROTOCOL(),
344
- false, // isInterceptor
345
- address(0), // objectAddress
346
- NFT_LOCK_ADDRESS,// initialOwner
347
- ""
348
- );
417
+ function getChainNftAddress() external view override returns (address) {
418
+ return address(CHAIN_NFT);
349
419
  }
350
420
 
351
- /// @dev registry registration
352
- /// might also register the global registry when not on mainnet
353
- function _registerRegistry(address registryOwner)
354
- internal
355
- {
356
- uint256 registryId = _chainNftInternal.calculateTokenId(2);
357
- NftId registryNftId = toNftId(registryId);
421
+ function getRegistryAdminAddress() external view returns (address) {
422
+ return address(ADMIN);
423
+ }
358
424
 
359
- NftId parentNftId;
425
+ function getAuthority() external view returns (address) {
426
+ return ADMIN.authority();
427
+ }
360
428
 
361
- if(registryId != _chainNftInternal.GLOBAL_REGISTRY_ID())
362
- {// we're not the global registry
363
- _registerGlobalRegistry();
364
- parentNftId = toNftId(_chainNftInternal.GLOBAL_REGISTRY_ID());
365
- }
366
- else
367
- {// we are global registry
368
- parentNftId = toNftId(_chainNftInternal.PROTOCOL_NFT_ID());
369
- }
429
+ function getOwner() public view returns (address owner) {
430
+ return ownerOf(address(this));
431
+ }
370
432
 
371
- _chainNftInternal.mint(registryOwner, registryId);
433
+ // IERC165
372
434
 
373
- _info[registryNftId] = ObjectInfo(
374
- registryNftId,
375
- parentNftId,
376
- REGISTRY(),
377
- false, // isInterceptor
378
- address(this),
379
- registryOwner,
380
- ""
381
- );
382
- _nftIdByAddress[address(this)] = registryNftId;
383
- _registryNftId = registryNftId;
435
+ function supportsInterface(bytes4 interfaceId) external pure returns (bool) {
436
+ if(interfaceId == type(IERC165).interfaceId || interfaceId == type(IRegistry).interfaceId) {
437
+ return true;
438
+ }
439
+
440
+ return false;
384
441
  }
385
442
 
443
+ // Internals
386
444
 
387
- /// @dev global registry registration for non mainnet registries
388
- function _registerGlobalRegistry()
445
+ /// @dev registry protects only against tampering existing records, registering with invalid types pairs and 0 parent address
446
+ function _register(ObjectInfo memory info)
389
447
  internal
448
+ returns(NftId nftId)
390
449
  {
391
- uint256 globalRegistryId = _chainNftInternal.GLOBAL_REGISTRY_ID();
450
+ ObjectType objectType = info.objectType; // do not care here, never PROTOCOL(), REGISTRY()
451
+ bool isInterceptor = info.isInterceptor;
452
+ address objectAddress = info.objectAddress; // do not care here, can be 0
453
+ address owner = info.initialOwner; // do not care here, can be 0, can be equal info.objectAddress
392
454
 
393
- _chainNftInternal.mint(NFT_LOCK_ADDRESS, globalRegistryId);
455
+ NftId parentNftId = info.parentNftId; // do not care here, can not be 0
456
+ ObjectInfo memory parentInfo = _info[parentNftId];
457
+ address parentAddress = parentInfo.objectAddress; // can be 0
394
458
 
395
- NftId globalRegistryNftId = toNftId(globalRegistryId);
459
+ // parent is contract -> need to check? -> check before minting
460
+ // special case: staking: to protocol possible as well
461
+ // NO LONGER TRUE: special case: global registry nft as parent when not on mainnet -> global registry address is 0
462
+ // special case: when parentNftId == CHAIN_NFT.mint(), check for zero parent address before mint
463
+ // special case: when parentNftId == CHAIN_NFT.mint() && objectAddress == initialOwner
464
+ // Parent can have 0 address in case of STAKE for PROTOCOL / CUSTOM_TYPE for POLICY
465
+ // But it MUST be registered -> parentType != 0 && parentNftId != 0
466
+ /*if(objectType != STAKE()) {
467
+ if(parentAddress == address(0)) {
468
+ revert ErrorRegistryParentAddressZero();
469
+ }
470
+ }*/
471
+
472
+ // global registry is never parent when not on mainnet
473
+ if(block.chainid != 1) {
474
+ if(parentNftId == GLOBAL_REGISTRY_NFT_ID) {
475
+ revert ErrorRegistryGlobalRegistryAsParent(objectAddress, objectType);
476
+ }
477
+ }
396
478
 
397
- _info[globalRegistryNftId] = ObjectInfo(
398
- globalRegistryNftId,
399
- toNftId(_chainNftInternal.PROTOCOL_NFT_ID()), // parent
400
- REGISTRY(),
401
- false, // isInterceptor
402
- address(0), // objectAddress
403
- NFT_LOCK_ADDRESS, // initialOwner
404
- "" // data
405
- );
406
- }
479
+ address interceptorAddress = _getInterceptor(
480
+ isInterceptor,
481
+ objectType,
482
+ objectAddress,
483
+ parentInfo.isInterceptor,
484
+ parentAddress);
407
485
 
408
- function _registerRegistryService(address registryOwner)
409
- internal
410
- {
411
- uint256 serviceId = _chainNftInternal.calculateTokenId(REGISTRY_SERVICE_TOKEN_SEQUENCE_ID);
412
- NftId serviceNftId = toNftId(serviceId);
486
+ uint256 tokenId = CHAIN_NFT.getNextTokenId();
487
+ nftId = NftIdLib.toNftId(tokenId);
488
+ info.nftId = nftId;
413
489
 
414
- _chainNftInternal.mint(registryOwner, serviceId);
490
+ _info[nftId] = info;
491
+ _setAddressForNftId(nftId, objectAddress);
415
492
 
416
- _info[serviceNftId] = ObjectInfo(
417
- serviceNftId,
418
- _registryNftId,
419
- SERVICE(),
420
- false, // isInterceptor
421
- msg.sender, // service deploys registry
422
- registryOwner, // initialOwner,
423
- ""
424
- );
493
+ emit LogRegistration(nftId, parentNftId, objectType, isInterceptor, objectAddress, owner);
425
494
 
426
- _nftIdByAddress[msg.sender] = serviceNftId;
495
+ // calls nft receiver(1) and interceptor(2)
496
+ uint256 mintedTokenId = CHAIN_NFT.mint(
497
+ owner,
498
+ interceptorAddress,
499
+ EMPTY_URI);
427
500
 
428
- string memory serviceName = "RegistryService";
429
- bytes32 serviceNameHash = keccak256(abi.encode(serviceName));
430
- _service[serviceNameHash][VersionLib.toVersionPart(MAJOR_VERSION_MIN)] = msg.sender;
431
- _string[serviceNftId] = serviceName;
432
- _serviceNftId = serviceNftId;
501
+ assert(mintedTokenId == tokenId);
433
502
  }
434
503
 
435
504
  /// @dev obtain interceptor address for this nft if applicable, address(0) otherwise
505
+ /// special case: STAKES (parent may be any type) -> no intercept call
506
+ /// default case:
436
507
  function _getInterceptor(
437
508
  bool isInterceptor,
509
+ ObjectType objectType,
438
510
  address objectAddress,
439
511
  bool parentIsInterceptor,
440
512
  address parentObjectAddress
441
513
  )
442
514
  internal
443
- view
515
+ pure
444
516
  returns (address interceptor)
445
517
  {
518
+ // no intercepting calls for stakes
519
+ if (objectType == STAKE()) {
520
+ return address(0);
521
+ }
522
+
446
523
  if (objectAddress == address(0)) {
447
524
  if (parentIsInterceptor) {
448
525
  return parentObjectAddress;
@@ -458,33 +535,191 @@ contract Registry is
458
535
  return address(0);
459
536
  }
460
537
 
461
- /// @dev defines which object - parent types relations are allowed to register
462
- // IMPORTANT:
463
- // 1) EACH object type MUST have only one parent type across ALL mappings
464
- // 2) DO NOT use object type (e.g. POLCY, BUNDLE, STAKE) as parent type
465
- // 3) DO NOT use REGISTRY as object type
466
- // 2) DO NOT use PROTOCOL and "zeroObjectType"
467
- function _setupValidObjectParentCombinations()
538
+ // Internals called only in constructor
539
+
540
+ /// @dev protocol registration used to anchor the dip ecosystem relations
541
+ function _registerProtocol()
542
+ private
543
+ returns (NftId protocolNftId)
544
+ {
545
+ uint256 protocolId = CHAIN_NFT.PROTOCOL_NFT_ID();
546
+ protocolNftId = NftIdLib.toNftId(protocolId);
547
+
548
+ _registerForNft(
549
+ ObjectInfo({
550
+ nftId: protocolNftId,
551
+ parentNftId: NftIdLib.zero(),
552
+ objectType: PROTOCOL(),
553
+ isInterceptor: false,
554
+ objectAddress: address(0),
555
+ initialOwner: NFT_LOCK_ADDRESS,
556
+ data: ""}),
557
+ true);
558
+ }
559
+
560
+ /// @dev register this registry
561
+ function _registerRegistry()
468
562
  internal
563
+ virtual
564
+ returns (NftId registryNftId)
469
565
  {
470
- // registry as parent, ONLY registry owner
471
- _isValidContractCombination[TOKEN()][REGISTRY()] = true;
472
- _isValidContractCombination[SERVICE()][REGISTRY()] = true;
566
+ // initial assignment
567
+ registryNftId = GLOBAL_REGISTRY_NFT_ID;
568
+
569
+ // register global registry
570
+ _registerRegistryForNft(
571
+ 1, // mainnet chain id
572
+ ObjectInfo({
573
+ nftId: GLOBAL_REGISTRY_NFT_ID,
574
+ parentNftId: PROTOCOL_NFT_ID,
575
+ objectType: REGISTRY(),
576
+ isInterceptor: false,
577
+ objectAddress: GLOBAL_REGISTRY_ADDRESS,
578
+ initialOwner: NFT_LOCK_ADDRESS,
579
+ data: ""}),
580
+ block.chainid == 1);// update address lookup for global registry only on mainnet
581
+
582
+ // if not on mainnet: register this registry with global registry as parent
583
+ if (block.chainid != 1) {
584
+
585
+ // modify registry nft id to local registry when not on mainnet
586
+ registryNftId = NftIdLib.toNftId(
587
+ CHAIN_NFT.calculateTokenId(REGISTRY_TOKEN_SEQUENCE_ID));
588
+
589
+ _registerRegistryForNft(
590
+ block.chainid,
591
+ ObjectInfo({
592
+ nftId: registryNftId,
593
+ parentNftId: GLOBAL_REGISTRY_NFT_ID,
594
+ objectType: REGISTRY(),
595
+ isInterceptor: false,
596
+ objectAddress: address(this),
597
+ initialOwner: NFT_LOCK_ADDRESS,
598
+ data: ""}),
599
+ true);
600
+ }
601
+ }
473
602
 
474
- // registry as parent, ONLY approved
475
- _isValidContractCombination[INSTANCE()][REGISTRY()] = true;
603
+ /// @dev staking registration
604
+ function _registerRegistryForNft(
605
+ uint256 chainId,
606
+ ObjectInfo memory info,
607
+ bool updateAddressLookup
608
+ )
609
+ private
610
+ {
611
+ if (!_registryNftIdByChainId[chainId].eqz()) {
612
+ revert ErrorRegistryChainRegistryAlreadyRegistered(info.nftId, chainId);
613
+ }
476
614
 
477
- // instance as parent, ONLY approved
478
- _isValidContractCombination[PRODUCT()][INSTANCE()] = true;
479
- _isValidContractCombination[DISTRIBUTION()][INSTANCE()] = true;
480
- _isValidContractCombination[ORACLE()][INSTANCE()] = true;
481
- _isValidContractCombination[POOL()][INSTANCE()] = true;
615
+ // update registry lookup variables
616
+ _registryNftIdByChainId[chainId] = info.nftId;
617
+ _chainId.push(chainId);
482
618
 
483
- // product as parent, ONLY approved
484
- _isValidObjectCombination[POLICY()][PRODUCT()] = true;
619
+ // register the registry info
620
+ _registerForNft(
621
+ info,
622
+ updateAddressLookup);
623
+ }
485
624
 
486
- // pool as parent, ONLY approved
487
- _isValidObjectCombination[BUNDLE()][POOL()] = true;
488
- _isValidObjectCombination[STAKE()][POOL()] = true;
625
+ /// @dev staking registration
626
+ function _registerStaking()
627
+ private
628
+ returns (NftId stakingNftId)
629
+ {
630
+ address stakingOwner = IRegisterable(_stakingAddress).getOwner();
631
+ uint256 stakingId = CHAIN_NFT.calculateTokenId(STAKING_TOKEN_SEQUENCE_ID);
632
+ stakingNftId = NftIdLib.toNftId(stakingId);
633
+
634
+ _registerForNft(
635
+ ObjectInfo({
636
+ nftId: stakingNftId,
637
+ parentNftId: REGISTRY_NFT_ID,
638
+ objectType: STAKING(),
639
+ isInterceptor: false,
640
+ objectAddress: _stakingAddress,
641
+ initialOwner: stakingOwner,
642
+ data: ""}),
643
+ true);
644
+
645
+ IStaking(_stakingAddress).initializeTokenHandler();
646
+ }
647
+
648
+ /// @dev Register the provided object info for the specified NFT ID.
649
+ function _registerForNft(
650
+ ObjectInfo memory info,
651
+ bool updateAddressLookup
652
+ )
653
+ internal
654
+ {
655
+ _info[info.nftId] = info;
656
+
657
+ if (updateAddressLookup) {
658
+ _setAddressForNftId(info.nftId, info.objectAddress);
659
+ }
660
+
661
+ // calls nft receiver
662
+ CHAIN_NFT.mint(info.initialOwner, info.nftId.toInt());
663
+ }
664
+
665
+ function _setAddressForNftId(NftId nftId, address objectAddress)
666
+ internal
667
+ {
668
+ if (objectAddress != address(0)) {
669
+ if (_nftIdByAddress[objectAddress].gtz()) {
670
+ revert ErrorRegistryContractAlreadyRegistered(objectAddress);
671
+ }
672
+
673
+ _nftIdByAddress[objectAddress] = nftId;
674
+ }
675
+ }
676
+
677
+ function _getGlobalRegistryAddress(address globalRegistry) internal view returns (address) {
678
+ if (block.chainid == 1) {
679
+ return address(this);
680
+ } else {
681
+ return globalRegistry;
682
+ }
683
+ }
684
+
685
+ /// @dev defines which object - parent types relations are allowed to register
686
+ /// EACH object type MUST have only one parent type across ALL mappings
687
+ // the only EXCEPTION is STAKE, can have any number of parent types
688
+ function _setupValidCoreTypesAndCombinations()
689
+ private
690
+ {
691
+ _coreTypes[PROTOCOL()] = true;
692
+ _coreTypes[REGISTRY()] = true;
693
+ _coreTypes[SERVICE()] = true;
694
+ _coreTypes[INSTANCE()] = true;
695
+ _coreTypes[PRODUCT()] = true;
696
+ _coreTypes[POOL()] = true;
697
+ _coreTypes[DISTRIBUTION()] = true;
698
+ _coreTypes[DISTRIBUTOR()] = true;
699
+ _coreTypes[ORACLE()] = true;
700
+ _coreTypes[POLICY()] = true;
701
+ _coreTypes[BUNDLE()] = true;
702
+ _coreTypes[STAKING()] = true;
703
+ _coreTypes[STAKE()] = true;
704
+
705
+ // types combinations allowed to use with register() function ONLY
706
+ _coreContractCombinations[INSTANCE()][REGISTRY()] = true;
707
+
708
+ // components with instance parent
709
+ _coreContractCombinations[PRODUCT()][INSTANCE()] = true;
710
+
711
+ // components with product parent
712
+ _coreContractCombinations[DISTRIBUTION()][PRODUCT()] = true;
713
+ _coreContractCombinations[ORACLE()][PRODUCT()] = true;
714
+ _coreContractCombinations[POOL()][PRODUCT()] = true;
715
+
716
+ // objects with component parents
717
+ _coreObjectCombinations[POLICY()][PRODUCT()] = true;
718
+ _coreObjectCombinations[DISTRIBUTOR()][DISTRIBUTION()] = true;
719
+ _coreObjectCombinations[BUNDLE()][POOL()] = true;
720
+
721
+ // staking
722
+ _coreObjectCombinations[STAKE()][PROTOCOL()] = true;
723
+ _coreObjectCombinations[STAKE()][INSTANCE()] = true;
489
724
  }
490
725
  }