@etherisc/gif-next 0.0.2-f626d92-602 → 0.0.2-f634e5c-828

Sign up to get free protection for your applications and to get access to all the features.
Files changed (687) hide show
  1. package/README.md +77 -10
  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/authorization/AccessAdmin.sol/IAccessManagedChecker.json +24 -0
  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/ISetup.sol/ISetup.json → authorization/IAccess.sol/IAccess.json} +2 -2
  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 +1310 -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/{components/IDistributionComponent.sol/IDistributionComponent.json → distribution/Distribution.sol/Distribution.json} +348 -313
  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 +903 -0
  34. package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +4 -0
  35. package/artifacts/contracts/{instance/service → distribution}/IDistributionService.sol/IDistributionService.json +221 -327
  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 +1415 -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 +1965 -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 +1429 -0
  50. package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +4 -0
  51. package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +1163 -0
  52. package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +4 -0
  53. package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +1592 -0
  54. package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +4 -0
  55. package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +2267 -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 +350 -1997
  60. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
  61. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +189 -113
  62. package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
  63. package/artifacts/contracts/instance/Instance.sol/Instance.json +406 -2791
  64. package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +4 -0
  65. package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +1684 -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 +1 -1
  69. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +1328 -331
  70. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
  71. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +264 -425
  72. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
  73. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +156 -151
  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/{Cloneable.sol → base/Cloneable.sol}/Cloneable.json +1 -54
  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 +1 -1
  89. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +8 -116
  90. package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
  91. package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +1 -1
  92. package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
  93. package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
  94. package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
  95. package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +4 -0
  96. package/artifacts/contracts/mock/Dip.sol/Dip.json +376 -0
  97. package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.dbg.json +4 -0
  98. package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.json +947 -0
  99. package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +4 -0
  100. package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +478 -0
  101. package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +4 -0
  102. package/artifacts/contracts/oracle/IOracle.sol/IOracle.json +52 -0
  103. package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +4 -0
  104. package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +762 -0
  105. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +4 -0
  106. package/artifacts/contracts/{instance/service/IPolicyService.sol/IPolicyService.json → oracle/IOracleService.sol/IOracleService.json} +282 -179
  107. package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +4 -0
  108. package/artifacts/contracts/{components/Component.sol/Component.json → oracle/Oracle.sol/Oracle.json} +274 -253
  109. package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +4 -0
  110. package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +990 -0
  111. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +4 -0
  112. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +766 -0
  113. package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +4 -0
  114. package/artifacts/contracts/{components/Pool.sol/Pool.json → pool/BasicPool.sol/BasicPool.json} +321 -457
  115. package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +4 -0
  116. package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +502 -0
  117. package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +4 -0
  118. package/artifacts/contracts/pool/BundleService.sol/BundleService.json +1360 -0
  119. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
  120. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +822 -0
  121. package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +4 -0
  122. package/artifacts/contracts/{instance/service → pool}/IBundleService.sol/IBundleService.json +323 -60
  123. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
  124. package/artifacts/contracts/{components/IProductComponent.sol/IProductComponent.json → pool/IPoolComponent.sol/IPoolComponent.json} +346 -281
  125. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +4 -0
  126. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +1285 -0
  127. package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +4 -0
  128. package/artifacts/contracts/{components/IPoolComponent.sol/IPoolComponent.json → pool/Pool.sol/Pool.json} +387 -436
  129. package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +4 -0
  130. package/artifacts/contracts/pool/PoolService.sol/PoolService.json +1619 -0
  131. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
  132. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +794 -0
  133. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +4 -0
  134. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +806 -0
  135. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
  136. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +730 -0
  137. package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +4 -0
  138. package/artifacts/contracts/{components/Product.sol/Product.json → product/BasicProduct.sol/BasicProduct.json} +409 -442
  139. package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +4 -0
  140. package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +470 -0
  141. package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +4 -0
  142. package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +1439 -0
  143. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
  144. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +858 -0
  145. package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +4 -0
  146. package/artifacts/contracts/{instance/service → product}/IApplicationService.sol/IApplicationService.json +117 -166
  147. package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +4 -0
  148. package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +942 -0
  149. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +4 -0
  150. package/artifacts/contracts/{instance/service/IPoolService.sol/IPoolService.json → product/IPolicyService.sol/IPolicyService.json} +485 -385
  151. package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +4 -0
  152. package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +578 -0
  153. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +4 -0
  154. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +991 -0
  155. package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +4 -0
  156. package/artifacts/contracts/{instance/service/IProductService.sol/IProductService.json → product/IRiskService.sol/IRiskService.json} +41 -62
  157. package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +4 -0
  158. package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +1313 -0
  159. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
  160. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +810 -0
  161. package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +4 -0
  162. package/artifacts/contracts/product/PricingService.sol/PricingService.json +923 -0
  163. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +4 -0
  164. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +786 -0
  165. package/artifacts/contracts/product/Product.sol/Product.dbg.json +4 -0
  166. package/artifacts/contracts/product/Product.sol/Product.json +1092 -0
  167. package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +4 -0
  168. package/artifacts/contracts/product/RiskService.sol/RiskService.json +638 -0
  169. package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +4 -0
  170. package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +718 -0
  171. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
  172. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +59 -16
  173. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
  174. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +457 -27
  175. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
  176. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +263 -110
  177. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
  178. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +5 -18
  179. package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
  180. package/artifacts/contracts/registry/Registry.sol/Registry.json +949 -128
  181. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +4 -0
  182. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +1899 -0
  183. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
  184. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +349 -245
  185. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
  186. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +161 -94
  187. package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +4 -0
  188. package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +205 -0
  189. package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +4 -0
  190. package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +1067 -0
  191. package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +4 -0
  192. package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +272 -0
  193. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
  194. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +316 -153
  195. package/artifacts/contracts/shared/Component.sol/Component.dbg.json +4 -0
  196. package/artifacts/contracts/{instance/base/ComponentService.sol/ComponentService.json → shared/Component.sol/Component.json} +292 -204
  197. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +4 -0
  198. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +1908 -0
  199. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +4 -0
  200. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +850 -0
  201. package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +4 -0
  202. package/artifacts/contracts/{instance/service/IClaimService.sol/IClaimService.json → shared/ComponentVerifyingService.sol/ComponentVerifyingService.json} +124 -125
  203. package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +4 -0
  204. package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +488 -0
  205. package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.dbg.json +4 -0
  206. package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.json +24 -0
  207. package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.dbg.json +4 -0
  208. package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.json +30 -0
  209. package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +4 -0
  210. package/artifacts/contracts/{components → shared}/IComponent.sol/IComponent.json +146 -131
  211. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +4 -0
  212. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +1467 -0
  213. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +4 -0
  214. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +697 -0
  215. package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
  216. package/artifacts/contracts/{instance/base → shared}/IKeyValueStore.sol/IKeyValueStore.json +95 -14
  217. package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +4 -0
  218. package/artifacts/contracts/{instance/base → shared}/ILifecycle.sol/ILifecycle.json +35 -4
  219. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
  220. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +19 -10
  221. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
  222. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +59 -13
  223. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
  224. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +28 -6
  225. package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
  226. package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.json +0 -13
  227. package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
  228. package/artifacts/contracts/shared/IService.sol/IService.json +46 -6
  229. package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.dbg.json +4 -0
  230. package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.json +53 -0
  231. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +4 -0
  232. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +785 -0
  233. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +4 -0
  234. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +538 -0
  235. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +4 -0
  236. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +174 -0
  237. package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.dbg.json +4 -0
  238. package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.json +306 -0
  239. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
  240. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +28 -70
  241. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
  242. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +35 -85
  243. package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
  244. package/artifacts/contracts/shared/Registerable.sol/Registerable.json +69 -99
  245. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
  246. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -28
  247. package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
  248. package/artifacts/contracts/shared/Service.sol/Service.json +58 -112
  249. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
  250. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +734 -8
  251. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.dbg.json +4 -0
  252. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.json +395 -0
  253. package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +4 -0
  254. package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +172 -0
  255. package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +4 -0
  256. package/artifacts/contracts/{components/Distribution.sol/Distribution.json → staking/IStaking.sol/IStaking.json} +708 -602
  257. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +4 -0
  258. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +1043 -0
  259. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +4 -0
  260. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +440 -0
  261. package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +4 -0
  262. package/artifacts/contracts/staking/Staking.sol/Staking.json +1816 -0
  263. package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.dbg.json +4 -0
  264. package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.json +205 -0
  265. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +4 -0
  266. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +780 -0
  267. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +4 -0
  268. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +587 -0
  269. package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +4 -0
  270. package/artifacts/contracts/staking/StakingService.sol/StakingService.json +1265 -0
  271. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +4 -0
  272. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +734 -0
  273. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +4 -0
  274. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +2283 -0
  275. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +4 -0
  276. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +607 -0
  277. package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +4 -0
  278. package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.json +10 -0
  279. package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +4 -0
  280. package/artifacts/contracts/type/Amount.sol/AmountLib.json +398 -0
  281. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +4 -0
  282. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +225 -0
  283. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
  284. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +203 -0
  285. package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +4 -0
  286. package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +104 -0
  287. package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +4 -0
  288. package/artifacts/contracts/type/Fee.sol/FeeLib.json +317 -0
  289. package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +4 -0
  290. package/artifacts/contracts/type/Key32.sol/Key32Lib.json +125 -0
  291. package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.dbg.json +4 -0
  292. package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.json +33 -0
  293. package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +4 -0
  294. package/artifacts/contracts/type/NftId.sol/NftIdLib.json +228 -0
  295. package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +4 -0
  296. package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +33 -0
  297. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +4 -0
  298. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +239 -0
  299. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
  300. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +209 -0
  301. package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +4 -0
  302. package/artifacts/contracts/type/Referral.sol/ReferralLib.json +142 -0
  303. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +4 -0
  304. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +204 -0
  305. package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +4 -0
  306. package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +180 -0
  307. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +4 -0
  308. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +369 -0
  309. package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +4 -0
  310. package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +246 -0
  311. package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +4 -0
  312. package/artifacts/contracts/type/Selector.sol/SelectorLib.json +129 -0
  313. package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +4 -0
  314. package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +10 -0
  315. package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +4 -0
  316. package/artifacts/contracts/type/StateId.sol/StateIdLib.json +105 -0
  317. package/artifacts/contracts/type/String.sol/StrLib.dbg.json +4 -0
  318. package/artifacts/contracts/type/String.sol/StrLib.json +132 -0
  319. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +4 -0
  320. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +312 -0
  321. package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +4 -0
  322. package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +548 -0
  323. package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +4 -0
  324. package/artifacts/contracts/type/Version.sol/VersionLib.json +177 -0
  325. package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +4 -0
  326. package/artifacts/contracts/type/Version.sol/VersionPartLib.json +68 -0
  327. package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.dbg.json +4 -0
  328. package/artifacts/contracts/{shared → upgradeability}/IVersionable.sol/IVersionable.json +1 -1
  329. package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.dbg.json +4 -0
  330. package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +618 -0
  331. package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +4 -0
  332. package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +129 -0
  333. package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +4 -0
  334. package/artifacts/contracts/{shared → upgradeability}/Versionable.sol/Versionable.json +1 -1
  335. package/contracts/authorization/AccessAdmin.sol +615 -0
  336. package/contracts/authorization/AccessManagerCloneable.sol +16 -0
  337. package/contracts/authorization/Authorization.sol +289 -0
  338. package/contracts/authorization/IAccess.sol +49 -0
  339. package/contracts/authorization/IAccessAdmin.sol +137 -0
  340. package/contracts/authorization/IAuthorization.sol +60 -0
  341. package/contracts/authorization/IServiceAuthorization.sol +40 -0
  342. package/contracts/authorization/ReleaseAccessManager.sol +38 -0
  343. package/contracts/authorization/ServiceAuthorization.sol +106 -0
  344. package/contracts/distribution/BasicDistribution.sol +139 -0
  345. package/contracts/distribution/BasicDistributionAuthorization.sol +47 -0
  346. package/contracts/{components → distribution}/Distribution.sol +166 -162
  347. package/contracts/distribution/DistributionService.sol +354 -0
  348. package/contracts/distribution/DistributionServiceManager.sol +39 -0
  349. package/contracts/distribution/IDistributionComponent.sol +52 -0
  350. package/contracts/{instance/service → distribution}/IDistributionService.sol +35 -34
  351. package/contracts/examples/fire/DamageLevel.sol +59 -0
  352. package/contracts/examples/fire/FirePool.sol +86 -0
  353. package/contracts/examples/fire/FirePoolAuthorization.sol +34 -0
  354. package/contracts/examples/fire/FireProduct.sol +431 -0
  355. package/contracts/examples/fire/FireProductAuthorization.sol +44 -0
  356. package/contracts/examples/fire/FireUSD.sol +26 -0
  357. package/contracts/examples/unpermissioned/SimpleDistribution.sol +65 -0
  358. package/contracts/examples/unpermissioned/SimpleOracle.sol +137 -0
  359. package/contracts/examples/unpermissioned/SimplePool.sol +108 -0
  360. package/contracts/examples/unpermissioned/SimpleProduct.sol +345 -0
  361. package/contracts/instance/BundleSet.sol +130 -0
  362. package/contracts/instance/IInstance.sol +45 -72
  363. package/contracts/instance/IInstanceService.sol +37 -39
  364. package/contracts/instance/Instance.sol +162 -250
  365. package/contracts/instance/InstanceAdmin.sol +288 -0
  366. package/contracts/instance/InstanceAuthorizationV3.sol +218 -0
  367. package/contracts/instance/InstanceReader.sol +351 -61
  368. package/contracts/instance/InstanceService.sol +250 -353
  369. package/contracts/instance/InstanceServiceManager.sol +14 -29
  370. package/contracts/instance/InstanceStore.sol +287 -0
  371. package/contracts/instance/RiskSet.sol +119 -0
  372. package/contracts/instance/base/BalanceStore.sol +123 -0
  373. package/contracts/instance/base/Cloneable.sol +28 -0
  374. package/contracts/instance/base/ObjectCounter.sol +20 -0
  375. package/contracts/instance/base/ObjectLifecycle.sol +111 -0
  376. package/contracts/instance/base/ObjectSet.sol +78 -0
  377. package/contracts/instance/module/IAccess.sol +4 -12
  378. package/contracts/instance/module/IBundle.sol +6 -9
  379. package/contracts/instance/module/IComponents.sol +27 -18
  380. package/contracts/instance/module/IDistribution.sol +6 -6
  381. package/contracts/instance/module/IPolicy.sol +48 -35
  382. package/contracts/instance/module/IRisk.sol +2 -1
  383. package/contracts/{test/Usdc.sol → mock/Dip.sol} +6 -6
  384. package/contracts/oracle/BasicOracle.sol +47 -0
  385. package/contracts/oracle/BasicOracleAuthorization.sol +46 -0
  386. package/contracts/oracle/IOracle.sol +36 -0
  387. package/contracts/oracle/IOracleComponent.sol +33 -0
  388. package/contracts/oracle/IOracleService.sol +66 -0
  389. package/contracts/oracle/Oracle.sol +156 -0
  390. package/contracts/oracle/OracleService.sol +309 -0
  391. package/contracts/oracle/OracleServiceManager.sol +39 -0
  392. package/contracts/pool/BasicPool.sol +175 -0
  393. package/contracts/pool/BasicPoolAuthorization.sol +68 -0
  394. package/contracts/pool/BundleService.sol +423 -0
  395. package/contracts/pool/BundleServiceManager.sol +39 -0
  396. package/contracts/pool/IBundleService.sol +122 -0
  397. package/contracts/pool/IPoolComponent.sol +62 -0
  398. package/contracts/pool/IPoolService.sol +153 -0
  399. package/contracts/pool/Pool.sol +345 -0
  400. package/contracts/pool/PoolService.sol +612 -0
  401. package/contracts/pool/PoolServiceManager.sol +39 -0
  402. package/contracts/product/ApplicationService.sol +259 -0
  403. package/contracts/{instance/service → product}/ApplicationServiceManager.sol +12 -9
  404. package/contracts/product/BasicProduct.sol +49 -0
  405. package/contracts/product/BasicProductAuthorization.sol +42 -0
  406. package/contracts/product/ClaimService.sol +614 -0
  407. package/contracts/{instance/service → product}/ClaimServiceManager.sol +12 -9
  408. package/contracts/{instance/service → product}/IApplicationService.sol +19 -35
  409. package/contracts/product/IClaimService.sol +123 -0
  410. package/contracts/product/IPolicyService.sol +90 -0
  411. package/contracts/product/IPricingService.sol +39 -0
  412. package/contracts/product/IProductComponent.sol +59 -0
  413. package/contracts/product/IRiskService.sol +33 -0
  414. package/contracts/product/PolicyService.sol +733 -0
  415. package/contracts/product/PolicyServiceManager.sol +39 -0
  416. package/contracts/product/PricingService.sol +300 -0
  417. package/contracts/product/PricingServiceManager.sol +39 -0
  418. package/contracts/product/Product.sol +427 -0
  419. package/contracts/product/RiskService.sol +107 -0
  420. package/contracts/product/RiskServiceManager.sol +39 -0
  421. package/contracts/registry/ChainNft.sol +79 -40
  422. package/contracts/registry/IRegistry.sol +98 -26
  423. package/contracts/registry/IRegistryService.sol +34 -40
  424. package/contracts/registry/ITransferInterceptor.sol +1 -2
  425. package/contracts/registry/Registry.sol +453 -195
  426. package/contracts/registry/RegistryAdmin.sol +451 -0
  427. package/contracts/registry/RegistryService.sol +87 -128
  428. package/contracts/registry/RegistryServiceManager.sol +23 -32
  429. package/contracts/registry/ReleaseLifecycle.sol +30 -0
  430. package/contracts/registry/ReleaseRegistry.sol +486 -0
  431. package/contracts/registry/ServiceAuthorizationV3.sol +176 -0
  432. package/contracts/registry/TokenRegistry.sol +261 -62
  433. package/contracts/shared/Component.sol +222 -0
  434. package/contracts/shared/ComponentService.sol +869 -0
  435. package/contracts/shared/ComponentServiceManager.sol +38 -0
  436. package/contracts/shared/ComponentVerifyingService.sol +128 -0
  437. package/contracts/shared/ContractLib.sol +224 -0
  438. package/contracts/shared/IComponent.sol +67 -0
  439. package/contracts/shared/IComponentService.sol +134 -0
  440. package/contracts/shared/IInstanceLinkedComponent.sol +30 -0
  441. package/contracts/{instance/base → shared}/IKeyValueStore.sol +16 -11
  442. package/contracts/{instance/base → shared}/ILifecycle.sol +5 -4
  443. package/contracts/shared/INftOwnable.sol +4 -2
  444. package/contracts/shared/IPolicyHolder.sol +23 -14
  445. package/contracts/shared/IRegisterable.sol +11 -0
  446. package/contracts/shared/IRegistryLinked.sol +0 -1
  447. package/contracts/shared/IService.sol +12 -3
  448. package/contracts/shared/{ERC165.sol → InitializableERC165.sol} +4 -4
  449. package/contracts/shared/InstanceLinkedComponent.sol +197 -0
  450. package/contracts/shared/KeyValueStore.sol +131 -0
  451. package/contracts/shared/Lifecycle.sol +88 -0
  452. package/contracts/shared/NftIdSet.sol +65 -0
  453. package/contracts/shared/NftOwnable.sol +32 -25
  454. package/contracts/shared/PolicyHolder.sol +22 -41
  455. package/contracts/shared/Registerable.sol +32 -23
  456. package/contracts/shared/RegistryLinked.sol +9 -19
  457. package/contracts/shared/Service.sol +48 -36
  458. package/contracts/shared/TokenHandler.sol +368 -12
  459. package/contracts/shared/TokenHandlerDeployerLib.sol +20 -0
  460. package/contracts/staking/IStaking.sol +173 -0
  461. package/contracts/staking/IStakingService.sol +157 -0
  462. package/contracts/staking/StakeManagerLib.sol +224 -0
  463. package/contracts/staking/Staking.sol +505 -0
  464. package/contracts/staking/StakingLifecycle.sol +23 -0
  465. package/contracts/staking/StakingManager.sol +52 -0
  466. package/contracts/staking/StakingReader.sol +190 -0
  467. package/contracts/staking/StakingService.sol +440 -0
  468. package/contracts/staking/StakingServiceManager.sol +44 -0
  469. package/contracts/staking/StakingStore.sol +605 -0
  470. package/contracts/staking/TargetManagerLib.sol +211 -0
  471. package/contracts/{types → type}/AddressSet.sol +1 -1
  472. package/contracts/type/Amount.sol +150 -0
  473. package/contracts/{types → type}/Blocknumber.sol +26 -3
  474. package/contracts/{types → type}/ClaimId.sol +31 -3
  475. package/contracts/{types → type}/Fee.sol +24 -22
  476. package/contracts/{types → type}/Key32.sol +2 -2
  477. package/contracts/type/Key32Set.sol +62 -0
  478. package/contracts/{types → type}/NftId.sol +21 -16
  479. package/contracts/{types → type}/NftIdSet.sol +2 -2
  480. package/contracts/type/ObjectType.sol +278 -0
  481. package/contracts/type/PayoutId.sol +82 -0
  482. package/contracts/{types → type}/Referral.sol +2 -1
  483. package/contracts/type/RequestId.sol +75 -0
  484. package/contracts/{types → type}/RiskId.sol +31 -5
  485. package/contracts/type/RoleId.sol +162 -0
  486. package/contracts/type/Seconds.sol +101 -0
  487. package/contracts/type/Selector.sol +102 -0
  488. package/contracts/{types → type}/StateId.sol +47 -4
  489. package/contracts/type/String.sol +53 -0
  490. package/contracts/{types → type}/Timestamp.sol +21 -2
  491. package/contracts/{types → type}/UFixed.sol +40 -121
  492. package/contracts/{types → type}/Version.sol +4 -2
  493. package/contracts/{shared → upgradeability}/IVersionable.sol +1 -1
  494. package/contracts/{shared → upgradeability}/ProxyManager.sol +93 -30
  495. package/contracts/{shared → upgradeability}/UpgradableProxyWithAdmin.sol +1 -3
  496. package/contracts/{shared → upgradeability}/Versionable.sol +3 -3
  497. package/package.json +11 -7
  498. package/artifacts/contracts/components/Component.sol/Component.dbg.json +0 -4
  499. package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +0 -4
  500. package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +0 -4
  501. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +0 -4
  502. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +0 -4
  503. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +0 -4
  504. package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +0 -4
  505. package/artifacts/contracts/components/Product.sol/Product.dbg.json +0 -4
  506. package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +0 -4
  507. package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +0 -1206
  508. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +0 -4
  509. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +0 -778
  510. package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +0 -4
  511. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +0 -4
  512. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +0 -1330
  513. package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +0 -4
  514. package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +0 -256
  515. package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.dbg.json +0 -4
  516. package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +0 -4
  517. package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +0 -4
  518. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +0 -4
  519. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +0 -532
  520. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +0 -4
  521. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +0 -194
  522. package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +0 -4
  523. package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +0 -4
  524. package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.json +0 -10
  525. package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.dbg.json +0 -4
  526. package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.json +0 -1039
  527. package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +0 -4
  528. package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.json +0 -673
  529. package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +0 -4
  530. package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +0 -1231
  531. package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +0 -4
  532. package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +0 -721
  533. package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.dbg.json +0 -4
  534. package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.json +0 -817
  535. package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +0 -4
  536. package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.json +0 -641
  537. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +0 -4
  538. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +0 -1798
  539. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +0 -4
  540. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +0 -805
  541. package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.dbg.json +0 -4
  542. package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +0 -4
  543. package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.dbg.json +0 -4
  544. package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +0 -4
  545. package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +0 -4
  546. package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +0 -4
  547. package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +0 -4
  548. package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +0 -4
  549. package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +0 -1092
  550. package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +0 -4
  551. package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +0 -697
  552. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +0 -4
  553. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +0 -1237
  554. package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +0 -4
  555. package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +0 -661
  556. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +0 -4
  557. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +0 -840
  558. package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
  559. package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +0 -653
  560. package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +0 -4
  561. package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +0 -285
  562. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +0 -4
  563. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +0 -559
  564. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +0 -4
  565. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +0 -107
  566. package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +0 -4
  567. package/artifacts/contracts/shared/ERC165.sol/ERC165.json +0 -73
  568. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +0 -4
  569. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +0 -4
  570. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +0 -582
  571. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +0 -4
  572. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +0 -129
  573. package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +0 -4
  574. package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +0 -4
  575. package/artifacts/contracts/test/TestFee.sol/TestFee.json +0 -119
  576. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +0 -4
  577. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +0 -383
  578. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +0 -4
  579. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +0 -116
  580. package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +0 -4
  581. package/artifacts/contracts/test/TestService.sol/TestService.json +0 -596
  582. package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +0 -4
  583. package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +0 -376
  584. package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +0 -4
  585. package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +0 -218
  586. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +0 -4
  587. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +0 -104
  588. package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +0 -4
  589. package/artifacts/contracts/test/Usdc.sol/USDC.json +0 -376
  590. package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +0 -4
  591. package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.json +0 -10
  592. package/artifacts/contracts/types/Amount.sol/AmountLib.dbg.json +0 -4
  593. package/artifacts/contracts/types/Amount.sol/AmountLib.json +0 -161
  594. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +0 -4
  595. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +0 -174
  596. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +0 -4
  597. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +0 -10
  598. package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.dbg.json +0 -4
  599. package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.json +0 -100
  600. package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +0 -4
  601. package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.json +0 -104
  602. package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +0 -4
  603. package/artifacts/contracts/types/Fee.sol/FeeLib.json +0 -288
  604. package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +0 -4
  605. package/artifacts/contracts/types/Key32.sol/Key32Lib.json +0 -125
  606. package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +0 -4
  607. package/artifacts/contracts/types/NftId.sol/NftIdLib.json +0 -166
  608. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +0 -4
  609. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.json +0 -33
  610. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +0 -4
  611. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.json +0 -100
  612. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +0 -4
  613. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +0 -92
  614. package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.dbg.json +0 -4
  615. package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.json +0 -100
  616. package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +0 -4
  617. package/artifacts/contracts/types/Referral.sol/ReferralLib.json +0 -142
  618. package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +0 -4
  619. package/artifacts/contracts/types/RiskId.sol/RiskIdLib.json +0 -86
  620. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +0 -4
  621. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +0 -156
  622. package/artifacts/contracts/types/Seconds.sol/SecondsLib.dbg.json +0 -4
  623. package/artifacts/contracts/types/Seconds.sol/SecondsLib.json +0 -124
  624. package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +0 -4
  625. package/artifacts/contracts/types/StateId.sol/StateIdLib.json +0 -92
  626. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +0 -4
  627. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +0 -267
  628. package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +0 -4
  629. package/artifacts/contracts/types/UFixed.sol/MathLib.json +0 -10
  630. package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +0 -4
  631. package/artifacts/contracts/types/UFixed.sol/UFixedLib.json +0 -479
  632. package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +0 -4
  633. package/artifacts/contracts/types/Version.sol/VersionLib.json +0 -177
  634. package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +0 -4
  635. package/artifacts/contracts/types/Version.sol/VersionPartLib.json +0 -49
  636. package/contracts/components/Component.sol +0 -253
  637. package/contracts/components/IComponent.sol +0 -76
  638. package/contracts/components/IDistributionComponent.sol +0 -71
  639. package/contracts/components/IPoolComponent.sol +0 -113
  640. package/contracts/components/IProductComponent.sol +0 -40
  641. package/contracts/components/Pool.sol +0 -303
  642. package/contracts/components/Product.sol +0 -293
  643. package/contracts/instance/AccessManagerUpgradeableInitializeable.sol +0 -13
  644. package/contracts/instance/BundleManager.sol +0 -127
  645. package/contracts/instance/Cloneable.sol +0 -51
  646. package/contracts/instance/InstanceAccessManager.sol +0 -527
  647. package/contracts/instance/ObjectManager.sol +0 -82
  648. package/contracts/instance/base/ComponentService.sol +0 -121
  649. package/contracts/instance/base/KeyValueStore.sol +0 -180
  650. package/contracts/instance/base/Lifecycle.sol +0 -109
  651. package/contracts/instance/module/ISetup.sol +0 -33
  652. package/contracts/instance/module/ITreasury.sol +0 -23
  653. package/contracts/instance/service/ApplicationService.sol +0 -350
  654. package/contracts/instance/service/BundleService.sol +0 -431
  655. package/contracts/instance/service/BundleServiceManager.sol +0 -51
  656. package/contracts/instance/service/ClaimService.sol +0 -151
  657. package/contracts/instance/service/DistributionService.sol +0 -435
  658. package/contracts/instance/service/DistributionServiceManager.sol +0 -51
  659. package/contracts/instance/service/IBundleService.sol +0 -93
  660. package/contracts/instance/service/IClaimService.sol +0 -61
  661. package/contracts/instance/service/IPolicyService.sol +0 -72
  662. package/contracts/instance/service/IPoolService.sol +0 -99
  663. package/contracts/instance/service/IProductService.sol +0 -40
  664. package/contracts/instance/service/PolicyService.sol +0 -362
  665. package/contracts/instance/service/PolicyServiceManager.sol +0 -54
  666. package/contracts/instance/service/PoolService.sol +0 -303
  667. package/contracts/instance/service/PoolServiceManager.sol +0 -51
  668. package/contracts/instance/service/ProductService.sol +0 -210
  669. package/contracts/instance/service/ProductServiceManager.sol +0 -54
  670. package/contracts/registry/RegistryAccessManager.sol +0 -216
  671. package/contracts/registry/ReleaseManager.sol +0 -324
  672. package/contracts/shared/ContractDeployerLib.sol +0 -72
  673. package/contracts/test/TestFee.sol +0 -25
  674. package/contracts/test/TestRegisterable.sol +0 -18
  675. package/contracts/test/TestRoleId.sol +0 -14
  676. package/contracts/test/TestService.sol +0 -25
  677. package/contracts/test/TestToken.sol +0 -26
  678. package/contracts/test/TestVersion.sol +0 -44
  679. package/contracts/test/TestVersionable.sol +0 -17
  680. package/contracts/types/Amount.sol +0 -60
  681. package/contracts/types/ChainId.sol +0 -38
  682. package/contracts/types/NumberId.sol +0 -52
  683. package/contracts/types/ObjectType.sol +0 -157
  684. package/contracts/types/PayoutId.sol +0 -54
  685. package/contracts/types/RoleId.sol +0 -97
  686. package/contracts/types/Seconds.sol +0 -54
  687. /package/contracts/{types → type}/DistributorType.sol +0 -0
@@ -2,35 +2,76 @@
2
2
  pragma solidity ^0.8.20;
3
3
 
4
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";
5
8
 
6
- import {NftId, toNftId, zeroNftId} from "../types/NftId.sol";
7
- import {VersionPart} from "../types/Version.sol";
8
- import {ObjectType, PROTOCOL, REGISTRY, TOKEN, SERVICE, INSTANCE, STAKE, PRODUCT, DISTRIBUTION, DISTRIBUTOR, ORACLE, POOL, POLICY, BUNDLE} from "../types/ObjectType.sol";
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";
9
12
 
10
13
  import {ChainNft} from "./ChainNft.sol";
11
14
  import {IRegistry} from "./IRegistry.sol";
12
- import {ReleaseManager} from "./ReleaseManager.sol";
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";
13
20
 
14
- // IMPORTANT
21
+ /// @dev IMPORTANT
15
22
  // Each NFT minted by registry is accosiated with:
16
23
  // 1) NFT owner
17
24
  // 2) registred contract OR object stored in registered (parent) contract
18
- // Four registration flows:
19
- // 1) IService address by release manager (SERVICE of domain SERVICE aka registry service aka release creation)
20
- // 2) IService address by release manager (SERVICE of domain !SERVICE aka regular service)
21
- // 3) IRegisterable address by regular service (INSTANCE, PRODUCT, POOL, DISTRIBUTION, ORACLE)
22
- // 4) state object by regular service (POLICY, BUNDLE, STAKE)
23
-
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.
24
35
  contract Registry is
36
+ Initializable,
37
+ AccessManaged,
25
38
  IRegistry
26
39
  {
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
+
27
61
  address public constant NFT_LOCK_ADDRESS = address(0x1);
28
62
  uint256 public constant REGISTRY_TOKEN_SEQUENCE_ID = 2;
63
+ uint256 public constant STAKING_TOKEN_SEQUENCE_ID = 3;
29
64
  string public constant EMPTY_URI = "";
30
65
 
66
+ /// @dev keep track of different registries on different chains
67
+ mapping(uint256 chainId => NftId registryNftId) private _registryNftIdByChainId;
68
+ uint256[] private _chainId;
69
+
70
+ /// @dev keep track of object info and address reverse lookup
31
71
  mapping(NftId nftId => ObjectInfo info) private _info;
32
72
  mapping(address object => NftId nftId) private _nftIdByAddress;
33
73
 
74
+ /// @dev keep track of service addresses by version and domain
34
75
  mapping(VersionPart version => mapping(ObjectType serviceDomain => address)) private _service;
35
76
 
36
77
  mapping(ObjectType objectType => bool) private _coreTypes;
@@ -41,178 +82,292 @@ contract Registry is
41
82
  mapping(ObjectType objectType => mapping(
42
83
  ObjectType parentType => bool)) private _coreObjectCombinations;
43
84
 
44
- NftId private _registryNftId;
45
- ChainNft private _chainNft;
85
+ NftId private _stakingNftId;
46
86
 
47
- ReleaseManager private _releaseManager;
87
+ ReleaseRegistry private _releaseRegistry;
88
+ address private _tokenRegistryAddress;
89
+ address private _stakingAddress;
48
90
 
49
- modifier onlyRegistryService() {
50
- if(!_releaseManager.isActiveRegistryService(msg.sender)) {
51
- revert CallerNotRegistryService();
91
+ modifier onlyDeployer() {
92
+ if (msg.sender != DEPLOYER) {
93
+ revert ErrorRegistryCallerNotDeployer();
52
94
  }
53
95
  _;
54
96
  }
55
97
 
56
- modifier onlyReleaseManager() {
57
- if(msg.sender != address(_releaseManager)) {
58
- revert CallerNotReleaseManager();
59
- }
60
- _;
61
- }
62
-
63
- constructor()
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())
64
105
  {
65
- _releaseManager = ReleaseManager(msg.sender);
106
+ DEPLOYER = msg.sender;
107
+ ADMIN = admin;
108
+ GLOBAL_REGISTRY_ADDRESS = _getGlobalRegistryAddress(globalRegistry);
66
109
 
67
110
  // deploy NFT
68
- _chainNft = new ChainNft(address(this));
111
+ CHAIN_NFT = new ChainNft(address(this));
112
+ GLOBAL_REGISTRY_NFT_ID = NftIdLib.toNftId(
113
+ CHAIN_NFT.GLOBAL_REGISTRY_ID());
69
114
 
70
115
  // initial registry setup
71
- _registerProtocol();
72
- _registerRegistry();
116
+ PROTOCOL_NFT_ID = _registerProtocol();
117
+ REGISTRY_NFT_ID = _registerRegistry();
73
118
 
74
119
  // set object types and object parent relations
75
120
  _setupValidCoreTypesAndCombinations();
76
121
  }
77
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;
139
+
140
+ // register staking contract
141
+ _stakingNftId = _registerStaking();
142
+ }
143
+
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
78
192
  function registerService(
79
193
  ObjectInfo memory info,
80
194
  VersionPart version,
81
195
  ObjectType domain
82
196
  )
83
197
  external
84
- onlyReleaseManager
198
+ restricted()
85
199
  returns(NftId nftId)
86
200
  {
87
- /* must be guaranteed by release manager
201
+ // service address is defined
202
+ address service = info.objectAddress;
203
+ if(service == address(0)) {
204
+ revert ErrorRegistryServiceAddressZero();
205
+ }
206
+
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);
214
+ }
215
+
216
+ // service has proper type
88
217
  if(info.objectType != SERVICE()) {
89
- revert();
218
+ revert ErrorRegistryNotService(service, info.objectType);
90
219
  }
91
- if(info.parentType != REGISTRY()) {
92
- revert();
93
- }
94
- info.initialOwner == NFT_LOCK_ADDRESS <- if services are access managed
95
- */
96
-
97
- if(_service[version][domain] > address(0)) {
98
- revert ServiceAlreadyRegistered(info.objectAddress);
220
+
221
+ // service parent has registry type
222
+ if(info.parentNftId != REGISTRY_NFT_ID) {
223
+ revert ErrorRegistryServiceParentNotRegistry(service, version, info.parentNftId);
99
224
  }
100
225
 
101
- _service[version][domain] = info.objectAddress; // nftId;
226
+ // service has not already been registered
227
+ if(_service[version][domain] != address(0)) {
228
+ revert ErrorRegistryServiceDomainAlreadyRegistered(service, version, domain);
229
+ }
102
230
 
103
- nftId = _register(info);
231
+ _service[version][domain] = service;
104
232
 
105
233
  emit LogServiceRegistration(version, domain);
234
+
235
+ nftId = _register(info);
106
236
  }
107
237
 
238
+
239
+ /// @inheritdoc IRegistry
108
240
  function register(ObjectInfo memory info)
109
241
  external
110
- onlyRegistryService
242
+ restricted()
111
243
  returns(NftId nftId)
112
244
  {
245
+ address objectAddress = info.objectAddress;
113
246
  ObjectType objectType = info.objectType;
114
- ObjectType parentType = _info[info.parentNftId].objectType;
115
247
 
116
- // TODO do not need it here -> SERVICE is no longer part of _coreContractCombinations
117
- // no service registrations
118
- if(objectType == SERVICE()) {
119
- revert ServiceRegistration();
120
- }
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;
121
251
 
122
- // only valid core types combinations
123
- if(info.objectAddress == address(0))
124
- {
252
+ // check type combinations for core objects
253
+ if(objectAddress == address(0)) {
125
254
  if(_coreObjectCombinations[objectType][parentType] == false) {
126
- revert InvalidTypesCombination(objectType, parentType);
255
+ revert ErrorRegistryTypesCombinationInvalid(objectAddress, objectType, parentType);
127
256
  }
128
257
  }
129
- else
130
- {
258
+ // check type combinations for contract objects
259
+ else {
131
260
  if(_coreContractCombinations[objectType][parentType] == false) {
132
- revert InvalidTypesCombination(objectType, parentType);
261
+ revert ErrorRegistryTypesCombinationInvalid(objectAddress, objectType, parentType);
133
262
  }
134
263
  }
135
264
 
136
265
  nftId = _register(info);
137
266
  }
138
267
 
268
+
269
+ /// @inheritdoc IRegistry
139
270
  function registerWithCustomType(ObjectInfo memory info)
140
271
  external
141
- onlyRegistryService
272
+ restricted()
142
273
  returns(NftId nftId)
143
274
  {
144
275
  ObjectType objectType = info.objectType;
145
276
  ObjectType parentType = _info[info.parentNftId].objectType;
146
277
 
147
278
  if(_coreTypes[objectType]) {
148
- revert CoreTypeRegistration();
279
+ revert ErrorRegistryCoreTypeRegistration();
149
280
  }
150
281
 
151
282
  if(
283
+ objectType == ObjectTypeLib.zero() ||
284
+ parentType == ObjectTypeLib.zero() ||
152
285
  parentType == PROTOCOL() ||
153
- parentType == REGISTRY() ||
154
286
  parentType == SERVICE()
155
287
  ) {
156
- revert InvalidTypesCombination(objectType, parentType);
288
+ revert ErrorRegistryTypesCombinationInvalid(info.objectAddress, objectType, parentType);
157
289
  }
158
290
 
159
- _register(info);
291
+ nftId = _register(info);
160
292
  }
161
293
 
162
294
 
163
295
  /// @dev earliest GIF major version
164
296
  function getInitialVersion() external view returns (VersionPart) {
165
- return _releaseManager.getInitialVersion();
297
+ return VersionPartLib.toVersionPart(_releaseRegistry.INITIAL_GIF_VERSION());
166
298
  }
167
299
 
168
- // TODO make distinction between active an not yet active version
169
- // need to be thought trough, not yet clear if necessary
170
- // need to answer question: what is the latest version during the upgrade process?
171
- // likely setting up a new gif version does not fit into a single tx
172
- // in this case we might want to have a period where the latest version is
173
- // in the process of being set up while the latest active version is 1 major release smaller
174
- /// @dev latest GIF major version (might not yet be active)
300
+ /// @dev next GIF release version to be released
175
301
  function getNextVersion() external view returns (VersionPart) {
176
- return _releaseManager.getNextVersion();
302
+ return _releaseRegistry.getNextVersion();
177
303
  }
178
304
 
179
305
  /// @dev latest active GIF release version
180
306
  function getLatestVersion() external view returns (VersionPart) {
181
- return _releaseManager.getLatestVersion();
307
+ return _releaseRegistry.getLatestVersion();
182
308
  }
183
309
 
184
310
  function getReleaseInfo(VersionPart version) external view returns (ReleaseInfo memory) {
185
- return _releaseManager.getReleaseInfo(version);
311
+ return _releaseRegistry.getReleaseInfo(version);
186
312
  }
187
313
 
188
- function getObjectCount() external view returns (uint256) {
189
- return _chainNft.totalSupply();
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];
190
324
  }
191
325
 
192
- function getReleaseManagerAddress() external view returns (address) {
193
- return address(_releaseManager);
326
+ function getObjectCount() external view returns (uint256) {
327
+ return CHAIN_NFT.totalSupply();
194
328
  }
195
329
 
196
330
  function getNftId() external view returns (NftId nftId) {
197
- return _registryNftId;
331
+ return REGISTRY_NFT_ID;
198
332
  }
199
333
 
200
- function getNftId(address object) external view returns (NftId id) {
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) {
201
339
  return _nftIdByAddress[object];
202
340
  }
203
341
 
204
342
  function ownerOf(NftId nftId) public view returns (address) {
205
- return _chainNft.ownerOf(nftId.toInt());
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;
206
348
  }
207
349
 
208
350
  function ownerOf(address contractAddress) public view returns (address) {
209
- return _chainNft.ownerOf(_nftIdByAddress[contractAddress].toInt());
351
+ return CHAIN_NFT.ownerOf(_nftIdByAddress[contractAddress].toInt());
210
352
  }
211
353
 
212
354
  function getObjectInfo(NftId nftId) external view returns (ObjectInfo memory) {
213
355
  return _info[nftId];
214
356
  }
215
357
 
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
+
216
371
  function getObjectInfo(address object) external view returns (ObjectInfo memory) {
217
372
  return _info[_nftIdByAddress[object]];
218
373
  }
@@ -234,9 +389,17 @@ contract Registry is
234
389
  return _info[objectParentNftId].objectType == INSTANCE();
235
390
  }
236
391
 
237
- function isValidRelease(VersionPart version) external view returns (bool)
392
+ function isActiveRelease(VersionPart version) external view returns (bool)
238
393
  {
239
- return _releaseManager.isValidRelease(version);
394
+ return _releaseRegistry.isActiveRelease(version);
395
+ }
396
+
397
+ function getStakingAddress() external view returns (address staking) {
398
+ return _stakingAddress;
399
+ }
400
+
401
+ function getTokenRegistryAddress() external view returns (address tokenRegistry) {
402
+ return _tokenRegistryAddress;
240
403
  }
241
404
 
242
405
  function getServiceAddress(
@@ -244,14 +407,23 @@ contract Registry is
244
407
  VersionPart releaseVersion
245
408
  ) external view returns (address service)
246
409
  {
247
- // TODO how can I get service address while release is not validated/activated ?!! -> user will check validity of release on its own
248
- //if(_releaseManager.isValidRelease(releaseVersion)) {
249
- service = _service[releaseVersion][serviceDomain];
250
- //}
410
+ service = _service[releaseVersion][serviceDomain];
411
+ }
412
+
413
+ function getReleaseRegistryAddress() external view returns (address) {
414
+ return address(_releaseRegistry);
251
415
  }
252
416
 
253
417
  function getChainNftAddress() external view override returns (address) {
254
- return address(_chainNft);
418
+ return address(CHAIN_NFT);
419
+ }
420
+
421
+ function getRegistryAdminAddress() external view returns (address) {
422
+ return address(ADMIN);
423
+ }
424
+
425
+ function getAuthority() external view returns (address) {
426
+ return ADMIN.authority();
255
427
  }
256
428
 
257
429
  function getOwner() public view returns (address owner) {
@@ -271,65 +443,83 @@ contract Registry is
271
443
  // Internals
272
444
 
273
445
  /// @dev registry protects only against tampering existing records, registering with invalid types pairs and 0 parent address
274
- // TODO registration of precompile addresses
275
446
  function _register(ObjectInfo memory info)
276
447
  internal
277
448
  returns(NftId nftId)
278
449
  {
279
- ObjectType objectType = info.objectType;
280
- NftId parentNftId = info.parentNftId;
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
454
+
455
+ NftId parentNftId = info.parentNftId; // do not care here, can not be 0
281
456
  ObjectInfo memory parentInfo = _info[parentNftId];
282
- ObjectType parentType = parentInfo.objectType; // see function header
283
- address parentAddress = parentInfo.objectAddress;
457
+ address parentAddress = parentInfo.objectAddress; // can be 0
284
458
 
285
459
  // parent is contract -> need to check? -> check before minting
286
- // special case: global registry nft as parent when not on mainnet -> global registry address is 0
287
- // special case: when parentNftId == _chainNft.mint(), check for zero parent address before mint
288
- // special case: when parentNftId == _chainNft.mint() && objectAddress == initialOwner
289
- if(parentAddress == address(0)) {
290
- revert ZeroParentAddress();
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
+ }
291
477
  }
292
478
 
293
- address interceptor = _getInterceptor(info.isInterceptor, info.objectAddress, parentInfo.isInterceptor, parentAddress);
294
- uint256 tokenId = _chainNft.getNextTokenId();
295
- nftId = toNftId(tokenId);
479
+ address interceptorAddress = _getInterceptor(
480
+ isInterceptor,
481
+ objectType,
482
+ objectAddress,
483
+ parentInfo.isInterceptor,
484
+ parentAddress);
296
485
 
486
+ uint256 tokenId = CHAIN_NFT.getNextTokenId();
487
+ nftId = NftIdLib.toNftId(tokenId);
297
488
  info.nftId = nftId;
298
- _info[nftId] = info;
299
-
300
- if(info.objectAddress > address(0))
301
- {
302
- address contractAddress = info.objectAddress;
303
489
 
304
- if(_nftIdByAddress[contractAddress].gtz()) {
305
- revert ContractAlreadyRegistered(contractAddress);
306
- }
307
-
308
- _nftIdByAddress[contractAddress] = nftId;
309
- }
490
+ _info[nftId] = info;
491
+ _setAddressForNftId(nftId, objectAddress);
310
492
 
311
- emit LogRegistration(nftId, parentNftId, objectType, info.isInterceptor, info.objectAddress, info.initialOwner);
493
+ emit LogRegistration(nftId, parentNftId, objectType, isInterceptor, objectAddress, owner);
312
494
 
313
495
  // calls nft receiver(1) and interceptor(2)
314
- uint256 mintedTokenId = _chainNft.mint(
315
- info.initialOwner,
316
- interceptor,
496
+ uint256 mintedTokenId = CHAIN_NFT.mint(
497
+ owner,
498
+ interceptorAddress,
317
499
  EMPTY_URI);
318
- assert(mintedTokenId == tokenId);
319
-
500
+
501
+ assert(mintedTokenId == tokenId);
320
502
  }
321
503
 
322
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:
323
507
  function _getInterceptor(
324
508
  bool isInterceptor,
509
+ ObjectType objectType,
325
510
  address objectAddress,
326
511
  bool parentIsInterceptor,
327
512
  address parentObjectAddress
328
513
  )
329
514
  internal
330
- view
515
+ pure
331
516
  returns (address interceptor)
332
517
  {
518
+ // no intercepting calls for stakes
519
+ if (objectType == STAKE()) {
520
+ return address(0);
521
+ }
522
+
333
523
  if (objectAddress == address(0)) {
334
524
  if (parentIsInterceptor) {
335
525
  return parentObjectAddress;
@@ -350,118 +540,186 @@ contract Registry is
350
540
  /// @dev protocol registration used to anchor the dip ecosystem relations
351
541
  function _registerProtocol()
352
542
  private
543
+ returns (NftId protocolNftId)
353
544
  {
354
- uint256 protocolId = _chainNft.PROTOCOL_NFT_ID();
355
- NftId protocolNftId = toNftId(protocolId);
356
-
357
- _info[protocolNftId] = ObjectInfo({
358
- nftId: protocolNftId,
359
- parentNftId: zeroNftId(),
360
- objectType: PROTOCOL(),
361
- isInterceptor: false,
362
- objectAddress: address(0),
363
- initialOwner: NFT_LOCK_ADDRESS,
364
- data: ""
365
- });
366
-
367
- _chainNft.mint(NFT_LOCK_ADDRESS, protocolId);
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()
562
+ internal
563
+ virtual
564
+ returns (NftId registryNftId)
565
+ {
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
+ }
368
601
  }
369
602
 
370
- /// @dev registry registration
371
- /// might also register the global registry when not on mainnet
372
- function _registerRegistry()
603
+ /// @dev staking registration
604
+ function _registerRegistryForNft(
605
+ uint256 chainId,
606
+ ObjectInfo memory info,
607
+ bool updateAddressLookup
608
+ )
373
609
  private
374
610
  {
375
- uint256 registryId = _chainNft.calculateTokenId(REGISTRY_TOKEN_SEQUENCE_ID);
376
- NftId registryNftId = toNftId(registryId);
377
- NftId parentNftId;
378
-
379
- if(registryId != _chainNft.GLOBAL_REGISTRY_ID())
380
- {// we're not the global registry
381
- _registerGlobalRegistry();
382
- parentNftId = toNftId(_chainNft.GLOBAL_REGISTRY_ID());
383
- }
384
- else
385
- {// we are global registry
386
- parentNftId = toNftId(_chainNft.PROTOCOL_NFT_ID());
611
+ if (!_registryNftIdByChainId[chainId].eqz()) {
612
+ revert ErrorRegistryChainRegistryAlreadyRegistered(info.nftId, chainId);
387
613
  }
388
614
 
389
- _info[registryNftId] = ObjectInfo({
390
- nftId: registryNftId,
391
- parentNftId: parentNftId,
392
- objectType: REGISTRY(),
393
- isInterceptor: false,
394
- objectAddress: address(this),
395
- initialOwner: NFT_LOCK_ADDRESS,
396
- data: ""
397
- });
398
- _nftIdByAddress[address(this)] = registryNftId;
399
- _registryNftId = registryNftId;
615
+ // update registry lookup variables
616
+ _registryNftIdByChainId[chainId] = info.nftId;
617
+ _chainId.push(chainId);
400
618
 
401
- _chainNft.mint(NFT_LOCK_ADDRESS, registryId);
619
+ // register the registry info
620
+ _registerForNft(
621
+ info,
622
+ updateAddressLookup);
402
623
  }
403
624
 
404
- /// @dev global registry registration for non mainnet registries
405
- function _registerGlobalRegistry()
625
+ /// @dev staking registration
626
+ function _registerStaking()
406
627
  private
628
+ returns (NftId stakingNftId)
407
629
  {
408
- uint256 globalRegistryId = _chainNft.GLOBAL_REGISTRY_ID();
409
- NftId globalRegistryNftId = toNftId(globalRegistryId);
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;
410
656
 
411
- _info[globalRegistryNftId] = ObjectInfo({
412
- nftId: globalRegistryNftId,
413
- parentNftId: toNftId(_chainNft.PROTOCOL_NFT_ID()),
414
- objectType: REGISTRY(),
415
- isInterceptor: false,
416
- objectAddress: address(0),
417
- initialOwner: NFT_LOCK_ADDRESS,
418
- data: ""
419
- });
657
+ if (updateAddressLookup) {
658
+ _setAddressForNftId(info.nftId, info.objectAddress);
659
+ }
420
660
 
421
- _chainNft.mint(NFT_LOCK_ADDRESS, globalRegistryId);
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
+ }
422
683
  }
423
684
 
424
685
  /// @dev defines which object - parent types relations are allowed to register
425
- // IMPORTANT:
426
- // 1) EACH object type MUST have only one parent type across ALL mappings
427
- // 2) DO NOT use object type (e.g. POLCY, BUNDLE, STAKE) as parent type
428
- // 3) DO NOT use REGISTRY as object type
429
- // 2) DO NOT use PROTOCOL and "zeroObjectType"
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
430
688
  function _setupValidCoreTypesAndCombinations()
431
- private
689
+ private
432
690
  {
691
+ _coreTypes[PROTOCOL()] = true;
433
692
  _coreTypes[REGISTRY()] = true;
434
693
  _coreTypes[SERVICE()] = true;
435
- _coreTypes[TOKEN()] = true;
436
694
  _coreTypes[INSTANCE()] = true;
437
695
  _coreTypes[PRODUCT()] = true;
438
696
  _coreTypes[POOL()] = true;
439
697
  _coreTypes[DISTRIBUTION()] = true;
698
+ _coreTypes[DISTRIBUTOR()] = true;
699
+ _coreTypes[ORACLE()] = true;
440
700
  _coreTypes[POLICY()] = true;
441
701
  _coreTypes[BUNDLE()] = true;
702
+ _coreTypes[STAKING()] = true;
442
703
  _coreTypes[STAKE()] = true;
443
-
444
- // registry as parent, ONLY registry owner
445
- //_coreContractCombinations[REGISTRY()][REGISTRY()] = true; // only for global regstry
446
- _coreContractCombinations[TOKEN()][REGISTRY()] = true;
447
- //_coreContractCombinations[SERVICE()][REGISTRY()] = true;// do not need it here -> registerService() registers exactly this combination
448
704
 
449
- // registry as parent, ONLY approved
705
+ // types combinations allowed to use with register() function ONLY
450
706
  _coreContractCombinations[INSTANCE()][REGISTRY()] = true;
451
707
 
452
- // instance as parent, ONLY approved
708
+ // components with instance parent
453
709
  _coreContractCombinations[PRODUCT()][INSTANCE()] = true;
454
- _coreContractCombinations[DISTRIBUTION()][INSTANCE()] = true;
455
- _coreContractCombinations[ORACLE()][INSTANCE()] = true;
456
- _coreContractCombinations[POOL()][INSTANCE()] = true;
457
710
 
458
- _coreObjectCombinations[DISTRIBUTOR()][DISTRIBUTION()] = true;
711
+ // components with product parent
712
+ _coreContractCombinations[DISTRIBUTION()][PRODUCT()] = true;
713
+ _coreContractCombinations[ORACLE()][PRODUCT()] = true;
714
+ _coreContractCombinations[POOL()][PRODUCT()] = true;
459
715
 
460
- // product as parent, ONLY approved
716
+ // objects with component parents
461
717
  _coreObjectCombinations[POLICY()][PRODUCT()] = true;
462
-
463
- // pool as parent, ONLY approved
718
+ _coreObjectCombinations[DISTRIBUTOR()][DISTRIBUTION()] = true;
464
719
  _coreObjectCombinations[BUNDLE()][POOL()] = true;
465
- _coreObjectCombinations[STAKE()][POOL()] = true;
720
+
721
+ // staking
722
+ _coreObjectCombinations[STAKE()][PROTOCOL()] = true;
723
+ _coreObjectCombinations[STAKE()][INSTANCE()] = true;
466
724
  }
467
725
  }