@etherisc/gif-next 0.0.2-cd89a0b-062 → 0.0.2-cdd6310-176

Sign up to get free protection for your applications and to get access to all the features.
Files changed (682) hide show
  1. package/README.md +179 -14
  2. package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +4 -0
  3. package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +1416 -0
  4. package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +4 -0
  5. package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +1378 -0
  6. package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
  7. package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +826 -0
  8. package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +4 -0
  9. package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +975 -0
  10. package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +4 -0
  11. package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +827 -0
  12. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +4 -0
  13. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +709 -0
  14. package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
  15. package/artifacts/contracts/instance/IInstance.sol/IInstance.json +358 -1865
  16. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +4 -0
  17. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +769 -0
  18. package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
  19. package/artifacts/contracts/instance/Instance.sol/Instance.json +445 -2059
  20. package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +4 -0
  21. package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +708 -0
  22. package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +4 -0
  23. package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +228 -0
  24. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +4 -0
  25. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +1701 -0
  26. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +4 -0
  27. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +1220 -0
  28. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +4 -0
  29. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +758 -0
  30. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +4 -0
  31. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +3598 -0
  32. package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +4 -0
  33. package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +318 -0
  34. package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +4 -0
  35. package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.json +137 -0
  36. package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +4 -0
  37. package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +10 -0
  38. package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +4 -0
  39. package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +187 -0
  40. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +4 -0
  41. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +129 -0
  42. package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +4 -0
  43. package/artifacts/contracts/instance/module/{bundle/IBundle.sol → IBundle.sol}/IBundle.json +1 -1
  44. package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +4 -0
  45. package/artifacts/contracts/instance/module/{access/IAccess.sol/IAccess.json → IComponents.sol/IComponents.json} +2 -2
  46. package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +4 -0
  47. package/artifacts/contracts/instance/module/{distribution/IDistribution.sol → IDistribution.sol}/IDistribution.json +1 -1
  48. package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +4 -0
  49. package/artifacts/contracts/instance/module/{policy/IPolicy.sol → IPolicy.sol}/IPolicy.json +1 -1
  50. package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +4 -0
  51. package/artifacts/contracts/instance/module/{risk/IRisk.sol → IRisk.sol}/IRisk.json +1 -1
  52. package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +4 -0
  53. package/artifacts/contracts/mock/Dip.sol/Dip.json +376 -0
  54. package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +4 -0
  55. package/artifacts/contracts/{instance/base/ModuleBase.sol/ModuleBase.json → oracle/IOracle.sol/IOracle.json} +2 -2
  56. package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +4 -0
  57. package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +759 -0
  58. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +4 -0
  59. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +675 -0
  60. package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +4 -0
  61. package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +1146 -0
  62. package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +4 -0
  63. package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +1034 -0
  64. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +4 -0
  65. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +730 -0
  66. package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +4 -0
  67. package/artifacts/contracts/pool/BundleService.sol/BundleService.json +1134 -0
  68. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
  69. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +754 -0
  70. package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +4 -0
  71. package/artifacts/contracts/{instance/service/IProductService.sol/IProductService.json → pool/IBundleService.sol/IBundleService.json} +342 -313
  72. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
  73. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +1154 -0
  74. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +4 -0
  75. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +1078 -0
  76. package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +4 -0
  77. package/artifacts/contracts/pool/Pool.sol/Pool.json +1565 -0
  78. package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +4 -0
  79. package/artifacts/contracts/pool/PoolService.sol/PoolService.json +1453 -0
  80. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
  81. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +742 -0
  82. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +4 -0
  83. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +863 -0
  84. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
  85. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +730 -0
  86. package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +4 -0
  87. package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +1315 -0
  88. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
  89. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +822 -0
  90. package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +4 -0
  91. package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +512 -0
  92. package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +4 -0
  93. package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +772 -0
  94. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +4 -0
  95. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +720 -0
  96. package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +4 -0
  97. package/artifacts/contracts/{instance/service/IPoolService.sol/IPoolService.json → product/IPricingService.sol/IPricingService.json} +320 -255
  98. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +4 -0
  99. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +995 -0
  100. package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +4 -0
  101. package/artifacts/contracts/{instance/service/IComponentOwnerService.sol/IComponentOwnerService.json → product/IProductService.sol/IProductService.json} +187 -176
  102. package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +4 -0
  103. package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +1183 -0
  104. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
  105. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +766 -0
  106. package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +4 -0
  107. package/artifacts/contracts/product/PricingService.sol/PricingService.json +1012 -0
  108. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +4 -0
  109. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +786 -0
  110. package/artifacts/contracts/product/Product.sol/Product.dbg.json +4 -0
  111. package/artifacts/contracts/product/Product.sol/Product.json +1397 -0
  112. package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +4 -0
  113. package/artifacts/contracts/product/ProductService.sol/ProductService.json +708 -0
  114. package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +4 -0
  115. package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +702 -0
  116. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
  117. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +60 -2
  118. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
  119. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +408 -60
  120. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
  121. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +621 -166
  122. package/artifacts/contracts/registry/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +4 -0
  123. package/artifacts/contracts/registry/IServiceAuthorization.sol/IServiceAuthorization.json +129 -0
  124. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
  125. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +18 -0
  126. package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
  127. package/artifacts/contracts/registry/Registry.sol/Registry.json +565 -170
  128. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +4 -0
  129. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +1901 -0
  130. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
  131. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +889 -322
  132. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
  133. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +371 -110
  134. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +4 -0
  135. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +1218 -0
  136. package/artifacts/contracts/registry/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +4 -0
  137. package/artifacts/contracts/registry/ServiceAuthorization.sol/ServiceAuthorization.json +171 -0
  138. package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +4 -0
  139. package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +187 -0
  140. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +4 -0
  141. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +661 -0
  142. package/artifacts/contracts/shared/AccessAdmin.sol/AccessAdmin.dbg.json +4 -0
  143. package/artifacts/contracts/shared/AccessAdmin.sol/AccessAdmin.json +1559 -0
  144. package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.dbg.json +4 -0
  145. package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.json +1193 -0
  146. package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.dbg.json +4 -0
  147. package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.json +1747 -0
  148. package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.dbg.json +4 -0
  149. package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.json +1760 -0
  150. package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.dbg.json +4 -0
  151. package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.json +1838 -0
  152. package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.dbg.json +4 -0
  153. package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.json +1856 -0
  154. package/artifacts/contracts/shared/Component.sol/Component.dbg.json +4 -0
  155. package/artifacts/contracts/shared/Component.sol/Component.json +896 -0
  156. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +4 -0
  157. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +1511 -0
  158. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +4 -0
  159. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +796 -0
  160. package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +4 -0
  161. package/artifacts/contracts/{instance/base/ComponentServiceBase.sol/ComponentServiceBase.json → shared/ComponentVerifyingService.sol/ComponentVerifyingService.json} +298 -152
  162. package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
  163. package/artifacts/contracts/shared/ERC165.sol/ERC165.json +41 -3
  164. package/artifacts/contracts/shared/IAccessAdmin.sol/IAccessAdmin.dbg.json +4 -0
  165. package/artifacts/contracts/shared/IAccessAdmin.sol/IAccessAdmin.json +1189 -0
  166. package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.dbg.json +4 -0
  167. package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.json +1562 -0
  168. package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.dbg.json +4 -0
  169. package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.json +1600 -0
  170. package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +4 -0
  171. package/artifacts/contracts/shared/IComponent.sol/IComponent.json +631 -0
  172. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +4 -0
  173. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +880 -0
  174. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +4 -0
  175. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +705 -0
  176. package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
  177. package/artifacts/contracts/{instance/base → shared}/IKeyValueStore.sol/IKeyValueStore.json +77 -169
  178. package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +4 -0
  179. package/artifacts/contracts/{instance/base → shared}/ILifecycle.sol/ILifecycle.json +1 -1
  180. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +4 -0
  181. package/artifacts/contracts/{instance/module/component/IComponent.sol/IComponentModule.json → shared/INftOwnable.sol/INftOwnable.json} +66 -52
  182. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +4 -0
  183. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +207 -0
  184. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
  185. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +65 -8
  186. package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +4 -0
  187. package/artifacts/contracts/{experiment/inheritance/IA.sol/ISharedA.json → shared/IRegistryLinked.sol/IRegistryLinked.json} +15 -17
  188. package/artifacts/contracts/shared/IService.sol/IService.dbg.json +4 -0
  189. package/artifacts/contracts/{instance/base → shared}/IService.sol/IService.json +155 -153
  190. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
  191. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +2 -152
  192. package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.dbg.json +4 -0
  193. package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.json +39 -0
  194. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +4 -0
  195. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +1036 -0
  196. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +4 -0
  197. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +571 -0
  198. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +4 -0
  199. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +194 -0
  200. package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.dbg.json +4 -0
  201. package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.json +306 -0
  202. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
  203. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +139 -27
  204. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +4 -0
  205. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +320 -0
  206. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
  207. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +333 -60
  208. package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
  209. package/artifacts/contracts/shared/Registerable.sol/Registerable.json +205 -12
  210. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +4 -0
  211. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +71 -0
  212. package/artifacts/contracts/shared/Service.sol/Service.dbg.json +4 -0
  213. package/artifacts/contracts/{instance/base/InstanceBase.sol/InstanceBase.json → shared/Service.sol/Service.json} +242 -191
  214. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +4 -0
  215. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +150 -0
  216. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
  217. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +2 -2
  218. package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
  219. package/artifacts/contracts/shared/Versionable.sol/Versionable.json +2 -152
  220. package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +4 -0
  221. package/artifacts/contracts/staking/IStaking.sol/IStaking.json +1438 -0
  222. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +4 -0
  223. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +1035 -0
  224. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +4 -0
  225. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +460 -0
  226. package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +4 -0
  227. package/artifacts/contracts/staking/Staking.sol/Staking.json +2005 -0
  228. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +4 -0
  229. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +761 -0
  230. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +4 -0
  231. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +592 -0
  232. package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +4 -0
  233. package/artifacts/contracts/staking/StakingService.sol/StakingService.json +1343 -0
  234. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +4 -0
  235. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +718 -0
  236. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +4 -0
  237. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +2261 -0
  238. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +4 -0
  239. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +571 -0
  240. package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +4 -0
  241. package/artifacts/contracts/{types → type}/AddressSet.sol/LibAddressSet.json +3 -3
  242. package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +4 -0
  243. package/artifacts/contracts/type/Amount.sol/AmountLib.json +345 -0
  244. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +4 -0
  245. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +225 -0
  246. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
  247. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +179 -0
  248. package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +4 -0
  249. package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +104 -0
  250. package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +4 -0
  251. package/artifacts/contracts/type/Fee.sol/FeeLib.json +312 -0
  252. package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +4 -0
  253. package/artifacts/contracts/type/Key32.sol/Key32Lib.json +125 -0
  254. package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +4 -0
  255. package/artifacts/contracts/type/NftId.sol/NftIdLib.json +209 -0
  256. package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +4 -0
  257. package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +33 -0
  258. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +4 -0
  259. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +186 -0
  260. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
  261. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +209 -0
  262. package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +4 -0
  263. package/artifacts/contracts/type/Referral.sol/ReferralLib.json +142 -0
  264. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +4 -0
  265. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +204 -0
  266. package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +4 -0
  267. package/artifacts/contracts/{types → type}/RiskId.sol/RiskIdLib.json +5 -5
  268. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +4 -0
  269. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +266 -0
  270. package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +4 -0
  271. package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +198 -0
  272. package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +4 -0
  273. package/artifacts/contracts/type/Selector.sol/SelectorLib.json +129 -0
  274. package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +4 -0
  275. package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +10 -0
  276. package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +4 -0
  277. package/artifacts/contracts/{types → type}/StateId.sol/StateIdLib.json +3 -3
  278. package/artifacts/contracts/type/String.sol/StrLib.dbg.json +4 -0
  279. package/artifacts/contracts/type/String.sol/StrLib.json +132 -0
  280. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +4 -0
  281. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +293 -0
  282. package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +4 -0
  283. package/artifacts/contracts/{types/ChainId.sol/ChainIdLib.json → type/UFixed.sol/MathLib.json} +4 -4
  284. package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +4 -0
  285. package/artifacts/contracts/{types/UFixed.sol/UFixedMathLib.json → type/UFixed.sol/UFixedLib.json} +4 -4
  286. package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +4 -0
  287. package/artifacts/contracts/{types → type}/Version.sol/VersionLib.json +3 -3
  288. package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +4 -0
  289. package/artifacts/contracts/type/Version.sol/VersionPartLib.json +49 -0
  290. package/contracts/distribution/Distribution.sol +261 -0
  291. package/contracts/distribution/DistributionService.sol +297 -0
  292. package/contracts/distribution/DistributionServiceManager.sol +42 -0
  293. package/contracts/distribution/IDistributionComponent.sol +66 -0
  294. package/contracts/distribution/IDistributionService.sol +81 -0
  295. package/contracts/instance/BundleManager.sol +126 -0
  296. package/contracts/instance/IInstance.sol +79 -46
  297. package/contracts/instance/IInstanceService.sol +97 -0
  298. package/contracts/instance/Instance.sol +247 -69
  299. package/contracts/instance/InstanceAdmin.sol +331 -0
  300. package/contracts/instance/InstanceAuthorizationsLib.sol +377 -0
  301. package/contracts/instance/InstanceReader.sol +392 -0
  302. package/contracts/instance/InstanceService.sol +439 -0
  303. package/contracts/instance/InstanceServiceManager.sol +44 -0
  304. package/contracts/instance/InstanceStore.sol +269 -0
  305. package/contracts/instance/base/BalanceStore.sol +123 -0
  306. package/contracts/instance/base/Cloneable.sol +28 -0
  307. package/contracts/instance/base/ObjectCounter.sol +21 -0
  308. package/contracts/instance/base/ObjectManager.sol +80 -0
  309. package/contracts/instance/module/IAccess.sol +46 -0
  310. package/contracts/instance/module/IBundle.sol +20 -0
  311. package/contracts/instance/module/IComponents.sol +52 -0
  312. package/contracts/instance/module/IDistribution.sol +42 -0
  313. package/contracts/instance/module/IPolicy.sol +84 -0
  314. package/contracts/instance/module/IRisk.sol +11 -0
  315. package/contracts/{test/Usdc.sol → mock/Dip.sol} +5 -5
  316. package/contracts/oracle/IOracle.sol +20 -0
  317. package/contracts/oracle/IOracleComponent.sol +32 -0
  318. package/contracts/oracle/IOracleService.sol +65 -0
  319. package/contracts/oracle/Oracle.sol +145 -0
  320. package/contracts/oracle/OracleService.sol +278 -0
  321. package/contracts/oracle/OracleServiceManager.sol +42 -0
  322. package/contracts/pool/BundleService.sol +296 -0
  323. package/contracts/pool/BundleServiceManager.sol +42 -0
  324. package/contracts/pool/IBundleService.sol +106 -0
  325. package/contracts/pool/IPoolComponent.sol +112 -0
  326. package/contracts/pool/IPoolService.sol +150 -0
  327. package/contracts/pool/Pool.sol +299 -0
  328. package/contracts/pool/PoolService.sol +452 -0
  329. package/contracts/pool/PoolServiceManager.sol +42 -0
  330. package/contracts/product/ApplicationService.sol +254 -0
  331. package/contracts/product/ApplicationServiceManager.sol +38 -0
  332. package/contracts/product/ClaimService.sol +442 -0
  333. package/contracts/product/ClaimServiceManager.sol +38 -0
  334. package/contracts/product/IApplicationService.sol +62 -0
  335. package/contracts/product/IClaimService.sol +99 -0
  336. package/contracts/product/IPolicyService.sol +78 -0
  337. package/contracts/product/IPricingService.sol +39 -0
  338. package/contracts/product/IProductComponent.sol +42 -0
  339. package/contracts/product/IProductService.sol +33 -0
  340. package/contracts/product/PolicyService.sol +475 -0
  341. package/contracts/product/PolicyServiceManager.sol +42 -0
  342. package/contracts/product/PricingService.sol +300 -0
  343. package/contracts/product/PricingServiceManager.sol +42 -0
  344. package/contracts/product/Product.sol +377 -0
  345. package/contracts/product/ProductService.sol +124 -0
  346. package/contracts/product/ProductServiceManager.sol +42 -0
  347. package/contracts/registry/ChainNft.sol +55 -25
  348. package/contracts/registry/IRegistry.sol +85 -34
  349. package/contracts/registry/IRegistryService.sol +56 -16
  350. package/contracts/registry/IServiceAuthorization.sol +35 -0
  351. package/contracts/registry/ITransferInterceptor.sol +1 -0
  352. package/contracts/registry/Registry.sol +416 -324
  353. package/contracts/registry/RegistryAdmin.sol +333 -0
  354. package/contracts/registry/RegistryService.sol +158 -267
  355. package/contracts/registry/RegistryServiceManager.sol +26 -25
  356. package/contracts/registry/ReleaseManager.sol +527 -0
  357. package/contracts/registry/ServiceAuthorization.sol +86 -0
  358. package/contracts/registry/ServiceAuthorizationV3.sol +200 -0
  359. package/contracts/registry/TokenRegistry.sol +315 -0
  360. package/contracts/shared/AccessAdmin.sol +759 -0
  361. package/contracts/shared/AccessManagerCustom.sol +741 -0
  362. package/contracts/shared/AccessManagerExtended.sol +481 -0
  363. package/contracts/shared/AccessManagerExtendedInitializeable.sol +13 -0
  364. package/contracts/shared/AccessManagerExtendedWithDisable.sol +137 -0
  365. package/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol +14 -0
  366. package/contracts/shared/Component.sol +281 -0
  367. package/contracts/shared/ComponentService.sol +617 -0
  368. package/contracts/shared/ComponentServiceManager.sol +35 -0
  369. package/contracts/shared/ComponentVerifyingService.sol +117 -0
  370. package/contracts/shared/ERC165.sol +16 -10
  371. package/contracts/shared/IAccessAdmin.sol +168 -0
  372. package/contracts/shared/IAccessManagerExtended.sol +74 -0
  373. package/contracts/shared/IAccessManagerExtendedWithDisable.sol +18 -0
  374. package/contracts/shared/IComponent.sol +70 -0
  375. package/contracts/shared/IComponentService.sol +102 -0
  376. package/contracts/shared/IInstanceLinkedComponent.sol +46 -0
  377. package/contracts/shared/IKeyValueStore.sol +53 -0
  378. package/contracts/{instance/base → shared}/ILifecycle.sol +4 -4
  379. package/contracts/shared/INftOwnable.sol +23 -0
  380. package/contracts/shared/IPolicyHolder.sol +45 -0
  381. package/contracts/shared/IRegisterable.sol +5 -12
  382. package/contracts/shared/IRegistryLinked.sol +11 -0
  383. package/contracts/shared/IService.sol +25 -0
  384. package/contracts/shared/IVersionable.sol +5 -48
  385. package/contracts/shared/InitializableCustom.sol +177 -0
  386. package/contracts/shared/InstanceLinkedComponent.sol +144 -0
  387. package/contracts/shared/KeyValueStore.sol +127 -0
  388. package/contracts/{instance/base → shared}/Lifecycle.sol +38 -8
  389. package/contracts/shared/NftIdSetManager.sol +65 -0
  390. package/contracts/shared/NftOwnable.sol +73 -53
  391. package/contracts/shared/PolicyHolder.sol +102 -0
  392. package/contracts/shared/ProxyManager.sol +127 -31
  393. package/contracts/shared/Registerable.sol +33 -75
  394. package/contracts/shared/RegistryLinked.sol +43 -0
  395. package/contracts/shared/Service.sol +83 -0
  396. package/contracts/shared/TokenHandler.sol +58 -0
  397. package/contracts/shared/UpgradableProxyWithAdmin.sol +2 -2
  398. package/contracts/shared/Versionable.sol +5 -93
  399. package/contracts/staking/IStaking.sol +168 -0
  400. package/contracts/staking/IStakingService.sol +153 -0
  401. package/contracts/staking/StakeManagerLib.sol +231 -0
  402. package/contracts/staking/Staking.sol +513 -0
  403. package/contracts/staking/StakingManager.sol +54 -0
  404. package/contracts/staking/StakingReader.sol +187 -0
  405. package/contracts/staking/StakingService.sol +411 -0
  406. package/contracts/staking/StakingServiceManager.sol +44 -0
  407. package/contracts/staking/StakingStore.sol +613 -0
  408. package/contracts/staking/TargetManagerLib.sol +207 -0
  409. package/contracts/{types → type}/AddressSet.sol +1 -1
  410. package/contracts/type/Amount.sol +128 -0
  411. package/contracts/{types → type}/Blocknumber.sol +21 -3
  412. package/contracts/type/ClaimId.sol +75 -0
  413. package/contracts/type/DistributorType.sol +55 -0
  414. package/contracts/type/Fee.sol +66 -0
  415. package/contracts/{types → type}/Key32.sol +8 -3
  416. package/contracts/{types → type}/NftId.sol +21 -15
  417. package/contracts/type/NftIdSet.sol +62 -0
  418. package/contracts/type/ObjectType.sol +241 -0
  419. package/contracts/type/PayoutId.sol +82 -0
  420. package/contracts/type/Referral.sol +89 -0
  421. package/contracts/type/RequestId.sol +75 -0
  422. package/contracts/{types → type}/RiskId.sol +1 -1
  423. package/contracts/type/RoleId.sol +201 -0
  424. package/contracts/type/Seconds.sol +81 -0
  425. package/contracts/type/Selector.sol +102 -0
  426. package/contracts/{types → type}/StateId.sol +39 -5
  427. package/contracts/type/String.sol +53 -0
  428. package/contracts/{types → type}/Timestamp.sol +27 -14
  429. package/contracts/{types → type}/UFixed.sol +129 -12
  430. package/contracts/{types → type}/Version.sol +6 -2
  431. package/package.json +8 -7
  432. package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +0 -4
  433. package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.json +0 -213
  434. package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +0 -4
  435. package/artifacts/contracts/components/Distribution.sol/Distribution.json +0 -445
  436. package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +0 -4
  437. package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.json +0 -177
  438. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +0 -4
  439. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +0 -343
  440. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +0 -4
  441. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +0 -474
  442. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +0 -4
  443. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +0 -373
  444. package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +0 -4
  445. package/artifacts/contracts/components/Pool.sol/Pool.json +0 -602
  446. package/artifacts/contracts/components/Product.sol/Product.dbg.json +0 -4
  447. package/artifacts/contracts/components/Product.sol/Product.json +0 -502
  448. package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +0 -4
  449. package/artifacts/contracts/experiment/errors/Require.sol/Require.json +0 -105
  450. package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +0 -4
  451. package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +0 -105
  452. package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +0 -4
  453. package/artifacts/contracts/experiment/inheritance/A.sol/A.json +0 -128
  454. package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +0 -4
  455. package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +0 -42
  456. package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +0 -4
  457. package/artifacts/contracts/experiment/inheritance/B.sol/B.json +0 -76
  458. package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +0 -4
  459. package/artifacts/contracts/experiment/inheritance/C.sol/C.json +0 -89
  460. package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +0 -4
  461. package/artifacts/contracts/experiment/inheritance/IA.sol/IA.json +0 -128
  462. package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +0 -4
  463. package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +0 -4
  464. package/artifacts/contracts/experiment/inheritance/IB.sol/IB.json +0 -50
  465. package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +0 -4
  466. package/artifacts/contracts/experiment/inheritance/IC.sol/IC.json +0 -63
  467. package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.dbg.json +0 -4
  468. package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +0 -59
  469. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +0 -4
  470. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.json +0 -124
  471. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +0 -4
  472. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.json +0 -74
  473. package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +0 -4
  474. package/artifacts/contracts/experiment/statemachine/SM.sol/SM.json +0 -124
  475. package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +0 -4
  476. package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.json +0 -207
  477. package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +0 -4
  478. package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.json +0 -10
  479. package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +0 -4
  480. package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.json +0 -10
  481. package/artifacts/contracts/instance/IInstanceLinked.sol/IInstanceLinked.dbg.json +0 -4
  482. package/artifacts/contracts/instance/IInstanceLinked.sol/IInstanceLinked.json +0 -24
  483. package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +0 -4
  484. package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +0 -4
  485. package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.json +0 -113
  486. package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +0 -4
  487. package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +0 -4
  488. package/artifacts/contracts/instance/base/IService.sol/IService.dbg.json +0 -4
  489. package/artifacts/contracts/instance/base/InstanceBase.sol/InstanceBase.dbg.json +0 -4
  490. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +0 -4
  491. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +0 -710
  492. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +0 -4
  493. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +0 -169
  494. package/artifacts/contracts/instance/base/ModuleBase.sol/ModuleBase.dbg.json +0 -4
  495. package/artifacts/contracts/instance/base/ServiceBase.sol/ServiceBase.dbg.json +0 -4
  496. package/artifacts/contracts/instance/base/ServiceBase.sol/ServiceBase.json +0 -380
  497. package/artifacts/contracts/instance/module/access/Access.sol/AccessModule.dbg.json +0 -4
  498. package/artifacts/contracts/instance/module/access/Access.sol/AccessModule.json +0 -333
  499. package/artifacts/contracts/instance/module/access/IAccess.sol/IAccess.dbg.json +0 -4
  500. package/artifacts/contracts/instance/module/access/IAccess.sol/IAccessModule.dbg.json +0 -4
  501. package/artifacts/contracts/instance/module/access/IAccess.sol/IAccessModule.json +0 -333
  502. package/artifacts/contracts/instance/module/bundle/BundleModule.sol/BundleModule.dbg.json +0 -4
  503. package/artifacts/contracts/instance/module/bundle/BundleModule.sol/BundleModule.json +0 -297
  504. package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundle.dbg.json +0 -4
  505. package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundleModule.dbg.json +0 -4
  506. package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundleModule.json +0 -297
  507. package/artifacts/contracts/instance/module/component/ComponentModule.sol/ComponentModule.dbg.json +0 -4
  508. package/artifacts/contracts/instance/module/component/ComponentModule.sol/ComponentModule.json +0 -117
  509. package/artifacts/contracts/instance/module/component/IComponent.sol/IComponent.dbg.json +0 -4
  510. package/artifacts/contracts/instance/module/component/IComponent.sol/IComponent.json +0 -10
  511. package/artifacts/contracts/instance/module/component/IComponent.sol/IComponentModule.dbg.json +0 -4
  512. package/artifacts/contracts/instance/module/distribution/DistributionModule.sol/DistributionModule.dbg.json +0 -4
  513. package/artifacts/contracts/instance/module/distribution/DistributionModule.sol/DistributionModule.json +0 -10
  514. package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistribution.dbg.json +0 -4
  515. package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistributionModule.dbg.json +0 -4
  516. package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistributionModule.json +0 -10
  517. package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicy.dbg.json +0 -4
  518. package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicyModule.dbg.json +0 -4
  519. package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicyModule.json +0 -284
  520. package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.dbg.json +0 -4
  521. package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.json +0 -284
  522. package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPool.dbg.json +0 -4
  523. package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPool.json +0 -10
  524. package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPoolModule.dbg.json +0 -4
  525. package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPoolModule.json +0 -164
  526. package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.dbg.json +0 -4
  527. package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.json +0 -164
  528. package/artifacts/contracts/instance/module/risk/IRisk.sol/IRisk.dbg.json +0 -4
  529. package/artifacts/contracts/instance/module/risk/IRisk.sol/IRiskModule.dbg.json +0 -4
  530. package/artifacts/contracts/instance/module/risk/IRisk.sol/IRiskModule.json +0 -113
  531. package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.dbg.json +0 -4
  532. package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.json +0 -131
  533. package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasury.dbg.json +0 -4
  534. package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasury.json +0 -10
  535. package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasuryModule.dbg.json +0 -4
  536. package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasuryModule.json +0 -638
  537. package/artifacts/contracts/instance/module/treasury/TokenHandler.sol/TokenHandler.dbg.json +0 -4
  538. package/artifacts/contracts/instance/module/treasury/TokenHandler.sol/TokenHandler.json +0 -76
  539. package/artifacts/contracts/instance/module/treasury/TreasuryModule.sol/TreasuryModule.dbg.json +0 -4
  540. package/artifacts/contracts/instance/module/treasury/TreasuryModule.sol/TreasuryModule.json +0 -638
  541. package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +0 -4
  542. package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +0 -690
  543. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +0 -4
  544. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +0 -526
  545. package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +0 -4
  546. package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +0 -4
  547. package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.json +0 -369
  548. package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +0 -4
  549. package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +0 -4
  550. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +0 -4
  551. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +0 -649
  552. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +0 -4
  553. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +0 -964
  554. package/artifacts/contracts/registry/IChainNft.sol/IChainNft.dbg.json +0 -4
  555. package/artifacts/contracts/registry/IChainNft.sol/IChainNft.json +0 -457
  556. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +0 -4
  557. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +0 -107
  558. package/artifacts/contracts/shared/IOwnable.sol/IOwnable.dbg.json +0 -4
  559. package/artifacts/contracts/shared/IOwnable.sol/IOwnable.json +0 -24
  560. package/artifacts/contracts/test/TestDistribution.sol/TestDistribution.dbg.json +0 -4
  561. package/artifacts/contracts/test/TestDistribution.sol/TestDistribution.json +0 -445
  562. package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +0 -4
  563. package/artifacts/contracts/test/TestFee.sol/TestFee.json +0 -119
  564. package/artifacts/contracts/test/TestPool.sol/TestPool.dbg.json +0 -4
  565. package/artifacts/contracts/test/TestPool.sol/TestPool.json +0 -602
  566. package/artifacts/contracts/test/TestProduct.sol/TestProduct.dbg.json +0 -4
  567. package/artifacts/contracts/test/TestProduct.sol/TestProduct.json +0 -632
  568. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +0 -4
  569. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +0 -191
  570. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +0 -4
  571. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +0 -116
  572. package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +0 -4
  573. package/artifacts/contracts/test/TestService.sol/TestService.json +0 -472
  574. package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +0 -4
  575. package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +0 -338
  576. package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +0 -4
  577. package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +0 -218
  578. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +0 -4
  579. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +0 -270
  580. package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +0 -4
  581. package/artifacts/contracts/test/Usdc.sol/USDC.json +0 -338
  582. package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +0 -4
  583. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +0 -4
  584. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +0 -174
  585. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +0 -4
  586. package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +0 -4
  587. package/artifacts/contracts/types/Fee.sol/FeeLib.json +0 -257
  588. package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +0 -4
  589. package/artifacts/contracts/types/Key32.sol/Key32Lib.json +0 -111
  590. package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +0 -4
  591. package/artifacts/contracts/types/NftId.sol/NftIdLib.json +0 -153
  592. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +0 -4
  593. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.json +0 -10
  594. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +0 -4
  595. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +0 -92
  596. package/artifacts/contracts/types/ReferralId.sol/ReferralIdLib.dbg.json +0 -4
  597. package/artifacts/contracts/types/ReferralId.sol/ReferralIdLib.json +0 -99
  598. package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +0 -4
  599. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +0 -4
  600. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +0 -30
  601. package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +0 -4
  602. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +0 -4
  603. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +0 -236
  604. package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.dbg.json +0 -4
  605. package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +0 -4
  606. package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +0 -4
  607. package/artifacts/contracts/types/Version.sol/VersionPartLib.json +0 -30
  608. package/contracts/components/BaseComponent.sol +0 -79
  609. package/contracts/components/Distribution.sol +0 -155
  610. package/contracts/components/IBaseComponent.sol +0 -19
  611. package/contracts/components/IDistributionComponent.sol +0 -47
  612. package/contracts/components/IPoolComponent.sol +0 -65
  613. package/contracts/components/IProductComponent.sol +0 -39
  614. package/contracts/components/Pool.sol +0 -246
  615. package/contracts/components/Product.sol +0 -299
  616. package/contracts/experiment/errors/Require.sol +0 -38
  617. package/contracts/experiment/errors/Revert.sol +0 -44
  618. package/contracts/experiment/inheritance/A.sol +0 -53
  619. package/contracts/experiment/inheritance/B.sol +0 -28
  620. package/contracts/experiment/inheritance/C.sol +0 -34
  621. package/contracts/experiment/inheritance/IA.sol +0 -13
  622. package/contracts/experiment/inheritance/IB.sol +0 -10
  623. package/contracts/experiment/inheritance/IC.sol +0 -12
  624. package/contracts/experiment/statemachine/Dummy.sol +0 -27
  625. package/contracts/experiment/statemachine/ISM.sol +0 -25
  626. package/contracts/experiment/statemachine/SM.sol +0 -57
  627. package/contracts/experiment/statemachine/SimpleStateMachine.sol +0 -31
  628. package/contracts/experiment/types/TypeA.sol +0 -47
  629. package/contracts/experiment/types/TypeB.sol +0 -29
  630. package/contracts/instance/IInstanceLinked.sol +0 -8
  631. package/contracts/instance/base/ComponentServiceBase.sol +0 -49
  632. package/contracts/instance/base/IInstanceBase.sol +0 -23
  633. package/contracts/instance/base/IKeyValueStore.sol +0 -50
  634. package/contracts/instance/base/IService.sol +0 -15
  635. package/contracts/instance/base/InstanceBase.sol +0 -89
  636. package/contracts/instance/base/KeyValueStore.sol +0 -161
  637. package/contracts/instance/base/ModuleBase.sol +0 -57
  638. package/contracts/instance/base/ServiceBase.sol +0 -43
  639. package/contracts/instance/module/access/Access.sol +0 -149
  640. package/contracts/instance/module/access/IAccess.sol +0 -53
  641. package/contracts/instance/module/bundle/BundleModule.sol +0 -134
  642. package/contracts/instance/module/bundle/IBundle.sol +0 -53
  643. package/contracts/instance/module/component/ComponentModule.sol +0 -71
  644. package/contracts/instance/module/component/IComponent.sol +0 -28
  645. package/contracts/instance/module/distribution/DistributionModule.sol +0 -17
  646. package/contracts/instance/module/distribution/IDistribution.sol +0 -10
  647. package/contracts/instance/module/policy/IPolicy.sol +0 -63
  648. package/contracts/instance/module/policy/PolicyModule.sol +0 -91
  649. package/contracts/instance/module/pool/IPoolModule.sol +0 -41
  650. package/contracts/instance/module/pool/PoolModule.sol +0 -95
  651. package/contracts/instance/module/risk/IRisk.sol +0 -26
  652. package/contracts/instance/module/risk/RiskModule.sol +0 -62
  653. package/contracts/instance/module/treasury/ITreasury.sol +0 -84
  654. package/contracts/instance/module/treasury/TokenHandler.sol +0 -48
  655. package/contracts/instance/module/treasury/TreasuryModule.sol +0 -131
  656. package/contracts/instance/service/ComponentOwnerService.sol +0 -272
  657. package/contracts/instance/service/DistributionService.sol +0 -54
  658. package/contracts/instance/service/IComponentOwnerService.sol +0 -20
  659. package/contracts/instance/service/IDistributionService.sol +0 -12
  660. package/contracts/instance/service/IPoolService.sol +0 -37
  661. package/contracts/instance/service/IProductService.sol +0 -107
  662. package/contracts/instance/service/PoolService.sol +0 -149
  663. package/contracts/instance/service/ProductService.sol +0 -509
  664. package/contracts/registry/IChainNft.sol +0 -22
  665. package/contracts/shared/ContractDeployerLib.sol +0 -72
  666. package/contracts/shared/IOwnable.sol +0 -6
  667. package/contracts/test/TestDistribution.sol +0 -22
  668. package/contracts/test/TestFee.sol +0 -25
  669. package/contracts/test/TestPool.sol +0 -27
  670. package/contracts/test/TestProduct.sol +0 -74
  671. package/contracts/test/TestRegisterable.sol +0 -18
  672. package/contracts/test/TestRoleId.sol +0 -14
  673. package/contracts/test/TestService.sol +0 -26
  674. package/contracts/test/TestToken.sol +0 -26
  675. package/contracts/test/TestVersion.sol +0 -44
  676. package/contracts/test/TestVersionable.sol +0 -17
  677. package/contracts/types/ChainId.sol +0 -38
  678. package/contracts/types/Fee.sol +0 -56
  679. package/contracts/types/NftIdSet.sol +0 -60
  680. package/contracts/types/ObjectType.sol +0 -131
  681. package/contracts/types/ReferralId.sol +0 -48
  682. package/contracts/types/RoleId.sol +0 -38
@@ -1,448 +1,416 @@
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
6
 
7
- import {IChainNft} from "./IChainNft.sol";
8
- import {ChainNft} from "./ChainNft.sol";
9
- 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";
7
+ import {InitializableCustom} from "../shared/InitializableCustom.sol";
14
8
 
15
- import {IOwnable} from "../shared/IOwnable.sol";
16
- import {ERC165} from "../shared/ERC165.sol";
9
+ import {NftId, NftIdLib} from "../type/NftId.sol";
10
+ import {VersionPart} from "../type/Version.sol";
11
+ import {ObjectType, PROTOCOL, REGISTRY, TOKEN, SERVICE, INSTANCE, STAKE, STAKING, PRODUCT, DISTRIBUTION, DISTRIBUTOR, ORACLE, POOL, POLICY, BUNDLE} from "../type/ObjectType.sol";
17
12
 
13
+ import {ChainNft} from "./ChainNft.sol";
14
+ import {IRegistry} from "./IRegistry.sol";
15
+ import {IRegisterable} from "../shared/IRegisterable.sol";
16
+ import {ReleaseManager} from "./ReleaseManager.sol";
17
+ import {TokenRegistry} from "./TokenRegistry.sol";
18
+ import {RegistryAdmin} from "./RegistryAdmin.sol";
18
19
 
19
20
  // IMPORTANT
20
21
  // Each NFT minted by registry is accosiated with:
21
22
  // 1) NFT owner
22
23
  // 2) registred contract OR object stored in registered (parent) contract
23
24
  // 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)
25
+ // 1) IService address by release manager (SERVICE of domain SERVICE aka registry service aka release creation)
26
+ // 2) IService address by release manager (SERVICE of domain !SERVICE aka regular service)
27
+ // 3) IRegisterable address by regular service (INSTANCE, PRODUCT, POOL, DISTRIBUTION, ORACLE)
28
+ // 4) state object by regular service (POLICY, BUNDLE, STAKE)
28
29
 
29
30
  contract Registry is
30
- ERC165,
31
+ InitializableCustom,
31
32
  IRegistry
32
33
  {
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;
47
- address public constant NFT_LOCK_ADDRESS = address(0x1);
48
- uint256 public constant REGISTRY_SERVICE_TOKEN_SEQUENCE_ID = 3;
34
+ address public NFT_LOCK_ADDRESS = address(0x1);
35
+ uint256 public constant REGISTRY_TOKEN_SEQUENCE_ID = 2;
36
+ uint256 public constant STAKING_TOKEN_SEQUENCE_ID = 3;
49
37
  string public constant EMPTY_URI = "";
50
38
 
51
- mapping(NftId nftId => ObjectInfo info) _info;
52
- mapping(address object => NftId nftId) _nftIdByAddress;
39
+ mapping(NftId nftId => ObjectInfo info) private _info;
40
+ mapping(address object => NftId nftId) private _nftIdByAddress;
53
41
 
54
- mapping(NftId registrator => mapping(
55
- ObjectType objectType => bool)) _isApproved;
42
+ mapping(VersionPart version => mapping(ObjectType serviceDomain => address)) private _service;
43
+
44
+ mapping(ObjectType objectType => bool) private _coreTypes;
56
45
 
57
46
  mapping(ObjectType objectType => mapping(
58
- ObjectType parentType => bool)) _isValidContractCombination;
47
+ ObjectType parentType => bool)) private _coreContractCombinations;
59
48
 
60
49
  mapping(ObjectType objectType => mapping(
61
- ObjectType parentType => bool)) _isValidObjectCombination;
50
+ ObjectType parentType => bool)) private _coreObjectCombinations;
62
51
 
63
- mapping(NftId nftId => string name) _string;
64
- mapping(bytes32 serviceNameHash => mapping(
65
- VersionPart majorVersion => address service)) _service;
52
+ RegistryAdmin public immutable _admin;
53
+ ChainNft public immutable _chainNft;
66
54
 
67
- NftId _registryNftId;
68
- NftId _serviceNftId; // set in stone upon registry creation
69
- IChainNft _chainNft;
70
- ChainNft _chainNftInternal;
55
+ NftId public immutable _protocolNftId;
56
+ NftId public immutable _registryNftId;
57
+ NftId public _stakingNftId;
71
58
 
72
- /*
73
- modifier onlyInitialOwner() {
74
- if(
75
- msg.sender != getOwner() ||
76
- msg.sender != _info[_registryNftId].initialOwner) {
77
- revert NotInitialOwner();
78
- }
79
- }*/
59
+ address public _tokenRegistryAddress;
60
+ address public _stakingAddress;
61
+ ReleaseManager public _releaseManager;
80
62
 
81
- modifier onlyOwner() {
82
- if(msg.sender != getOwner()) {
83
- revert NotOwner();
63
+ // TODO
64
+ // 1). Registry and ReleaseManager must be treated as whole single entity.
65
+ // But current limitations of EVM does not allow it -> require it to be splitted
66
+ // 2). Keep onlyReleaseManager modifier
67
+ // 3). Delete onlyRegistryService in favor of restricted, introduce aditional "domain role", REGISTRY_SERVICE_ROLE
68
+ // 4). (For GlobalRegistry ONLY) make registerChainRegistry() restricted to GIF_ADMIN_ROLE
69
+ modifier onlyRegistryService() {
70
+ if(!_releaseManager.isActiveRegistryService(msg.sender)) {
71
+ revert ErrorRegistryCallerNotRegistryService();
84
72
  }
85
73
  _;
86
74
  }
87
75
 
88
- modifier onlyRegistryService() {
89
-
90
- if(msg.sender != _info[_serviceNftId].objectAddress) {
91
- revert NotRegistryService();
76
+
77
+ modifier onlyReleaseManager() {
78
+ if(msg.sender != address(_releaseManager)) {
79
+ revert ErrorRegistryCallerNotReleaseManager();
92
80
  }
93
81
  _;
94
82
  }
95
83
 
96
- constructor(address registryOwner, VersionPart majorVersion)
97
- {
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");
100
84
 
85
+ constructor(RegistryAdmin admin)
86
+ InitializableCustom()
87
+ {
88
+ _admin = admin;
101
89
  // deploy NFT
102
- _chainNftInternal = new ChainNft(address(this));// adds 10kb to deployment size
103
- _chainNft = IChainNft(_chainNftInternal);
90
+ _chainNft = new ChainNft(address(this));
104
91
 
105
92
  // initial registry setup
106
- _registerProtocol();
107
- _registerRegistry(registryOwner);
108
- _registerRegistryService(registryOwner);
93
+ _protocolNftId = _registerProtocol();
94
+ _registryNftId = _registerRegistry();
95
+
96
+ // set object types and object parent relations
97
+ _setupValidCoreTypesAndCombinations();
98
+ }
109
99
 
110
- // set object parent relations
111
- _setupValidObjectParentCombinations();
112
100
 
113
- _registerInterface(type(IRegistry).interfaceId);
114
- _registerInterface(type(IOwnable).interfaceId);
101
+ /// @dev wires release manager and token to registry (this contract).
102
+ /// MUST be called by release manager.
103
+ function initialize(
104
+ address releaseManager,
105
+ address tokenRegistry,
106
+ address staking
107
+ )
108
+ external
109
+ initializer()
110
+ {
111
+ _releaseManager = ReleaseManager(releaseManager);
112
+ _tokenRegistryAddress = tokenRegistry;
113
+ _stakingAddress = staking;
114
+
115
+ _stakingNftId = _registerStaking();
115
116
  }
116
117
 
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)
118
+ function registerService(
119
+ ObjectInfo memory info,
120
+ VersionPart version,
121
+ ObjectType domain
122
+ )
122
123
  external
123
- onlyRegistryService
124
+ onlyReleaseManager
124
125
  returns(NftId nftId)
125
126
  {
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;
127
+ address service = info.objectAddress;
128
+ /* must be guaranteed by release manager
129
+ if(service == address(0)) {
130
+ revert();
131
+ }
131
132
 
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();
133
+ if(version.eqz()) {
134
+ revert();
138
135
  }
139
136
 
140
- address interceptor = _getInterceptor(info.isInterceptor, info.objectAddress, parentInfo.isInterceptor, parentAddress);
137
+ if(info.objectType != SERVICE()) {
138
+ revert();
139
+ }
140
+ if(info.parentType != REGISTRY()) {
141
+ revert();
142
+ }
143
+ info.initialOwner == NFT_LOCK_ADDRESS <- if services are access managed
144
+ */
145
+
146
+ if(domain.eqz()) {
147
+ revert ErrorRegistryDomainZero(service);
148
+ }
141
149
 
142
- uint256 mintedTokenId = _chainNft.mint(
143
- info.initialOwner,
144
- interceptor,
145
- EMPTY_URI);
146
- nftId = toNftId(mintedTokenId);
150
+ if(_service[version][domain] > address(0)) {
151
+ revert ErrorRegistryDomainAlreadyRegistered(service, version, domain);
152
+ }
153
+
154
+ _service[version][domain] = service;
147
155
 
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;
156
+ nftId = _register(info);
153
157
 
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
- }
161
-
162
- address contractAddress = info.objectAddress;
158
+ emit LogServiceRegistration(version, domain);
159
+ }
163
160
 
164
- if(_nftIdByAddress[contractAddress].gtz()) {
165
- revert ContractAlreadyRegistered(contractAddress);
166
- }
161
+ function register(ObjectInfo memory info)
162
+ external
163
+ onlyRegistryService
164
+ returns(NftId nftId)
165
+ {
166
+ ObjectType objectType = info.objectType;
167
+ ObjectType parentType = _info[info.parentNftId].objectType;
167
168
 
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);
169
+ // only valid core types combinations
170
+ if(info.objectAddress == address(0))
171
+ {
172
+ if(_coreObjectCombinations[objectType][parentType] == false) {
173
+ revert ErrorRegistryTypesCombinationInvalid(objectType, parentType);
198
174
  }
199
175
  }
200
176
  else
201
177
  {
202
- if(_isValidObjectCombination[objectType][parentType] == false) {
203
- revert InvalidTypesCombination(objectType, parentType);
178
+ if(_coreContractCombinations[objectType][parentType] == false) {
179
+ revert ErrorRegistryTypesCombinationInvalid(objectType, parentType);
204
180
  }
205
181
  }
206
182
 
207
- emit LogRegistration(nftId, info.parentNftId, info.objectType, info.objectAddress, info.initialOwner);
183
+ nftId = _register(info);
208
184
  }
209
185
 
210
- function registerFrom(
211
- address from,
212
- ObjectInfo memory info
213
- ) external returns (NftId nftId)
214
- {
215
- revert();
216
- }
217
-
218
-
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()
186
+ function registerWithCustomType(ObjectInfo memory info)
187
+ external
188
+ onlyRegistryService
189
+ returns(NftId nftId)
234
190
  {
235
- address serviceAddress = _info[serviceNftId].objectAddress;
236
-
237
- if(_nftIdByAddress[serviceAddress].eqz()) {
238
- revert NotRegisteredContract(serviceNftId);
239
- }
191
+ ObjectType objectType = info.objectType;
192
+ ObjectType parentType = _info[info.parentNftId].objectType;
240
193
 
241
- if(_info[serviceNftId].objectType != SERVICE()) {
242
- revert NotService(serviceNftId);
194
+ if(_coreTypes[objectType]) {
195
+ revert ErrorRegistryCoreTypeRegistration();
243
196
  }
244
197
 
245
198
  if(
246
- _isValidContractCombination[objectType][parentType] == false &&
247
- _isValidObjectCombination[objectType][parentType] == false) {
248
- revert InvalidTypesCombination(objectType, parentType);
199
+ parentType == PROTOCOL() ||
200
+ parentType == REGISTRY() ||
201
+ parentType == SERVICE()
202
+ ) {
203
+ revert ErrorRegistryTypesCombinationInvalid(objectType, parentType);
249
204
  }
250
205
 
251
- _isApproved[serviceNftId][objectType] = true;
206
+ _register(info);
207
+ }
252
208
 
253
- emit LogApproval(serviceNftId, objectType);
209
+
210
+ /// @dev earliest GIF major version
211
+ function getInitialVersion() external view returns (VersionPart) {
212
+ return _releaseManager.getInitialVersion();
254
213
  }
255
214
 
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];
215
+ /// @dev next GIF release version to be released
216
+ function getNextVersion() external view returns (VersionPart) {
217
+ return _releaseManager.getNextVersion();
268
218
  }
269
219
 
270
- // from IRegistry
271
- function getObjectCount() external view override returns (uint256) {
272
-
220
+ /// @dev latest active GIF release version
221
+ function getLatestVersion() external view returns (VersionPart) {
222
+ return _releaseManager.getLatestVersion();
223
+ }
224
+
225
+ function getReleaseInfo(VersionPart version) external view returns (ReleaseInfo memory) {
226
+ return _releaseManager.getReleaseInfo(version);
227
+ }
228
+
229
+ function getObjectCount() external view returns (uint256) {
273
230
  return _chainNft.totalSupply();
274
231
  }
275
232
 
276
- function getNftId(address object) external view override returns (NftId id) {
233
+ function getNftId() external view returns (NftId nftId) {
234
+ return _registryNftId;
235
+ }
236
+
237
+ function getProtocolNftId() external view returns (NftId nftId) {
238
+ return _protocolNftId;
239
+ }
240
+
241
+ function getNftId(address object) external view returns (NftId id) {
277
242
  return _nftIdByAddress[object];
278
243
  }
279
244
 
280
- function ownerOf(NftId nftId) public view override returns (address) {
245
+ function ownerOf(NftId nftId) public view returns (address) {
281
246
  return _chainNft.ownerOf(nftId.toInt());
282
247
  }
283
248
 
284
249
  function ownerOf(address contractAddress) public view returns (address) {
285
-
286
250
  return _chainNft.ownerOf(_nftIdByAddress[contractAddress].toInt());
287
251
  }
288
252
 
289
- function getObjectInfo(NftId nftId) external view override returns (ObjectInfo memory) {
253
+ function getObjectInfo(NftId nftId) external view returns (ObjectInfo memory) {
290
254
  return _info[nftId];
291
255
  }
292
256
 
293
- function getObjectInfo(address object) external view override returns (ObjectInfo memory) {
294
-
257
+ function getObjectInfo(address object) external view returns (ObjectInfo memory) {
295
258
  return _info[_nftIdByAddress[object]];
296
259
  }
297
260
 
298
- function isRegistered(NftId nftId) public view override returns (bool) {
261
+ function isRegistered(NftId nftId) public view returns (bool) {
299
262
  return _info[nftId].objectType.gtz();
300
263
  }
301
264
 
302
- function isRegistered(address object) external view override returns (bool) {
265
+ function isRegistered(address object) external view returns (bool) {
303
266
  return _nftIdByAddress[object].gtz();
304
267
  }
305
268
 
306
- function getServiceName(NftId nftId) external view returns (string memory) {
307
- return _string[nftId];
269
+ function isRegisteredService(address object) external view returns (bool) {
270
+ return _info[_nftIdByAddress[object]].objectType == SERVICE();
308
271
  }
309
272
 
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];
273
+ function isRegisteredComponent(address object) external view returns (bool) {
274
+ NftId objectParentNftId = _info[_nftIdByAddress[object]].parentNftId;
275
+ return _info[objectParentNftId].objectType == INSTANCE();
318
276
  }
319
277
 
320
- function getChainNft() external view override returns (IChainNft) {
321
- return _chainNft;
278
+ function isActiveRelease(VersionPart version) external view returns (bool)
279
+ {
280
+ return _releaseManager.isActiveRelease(version);
322
281
  }
323
282
 
324
- // from IOwnable
325
- function getOwner() public view returns (address owner) {
326
- return ownerOf(address(this));
283
+ function getStakingAddress() external view returns (address staking) {
284
+ //return getObjectInfo(_stakingNftId).objectAddress;
285
+ //return _info[_stakingNftId].objectAddress;
286
+ return _stakingAddress;
327
287
  }
328
288
 
329
- // Internals, called only in constructor
289
+ function getTokenRegistryAddress() external view returns (address tokenRegistry) {
290
+ return _tokenRegistryAddress;
291
+ }
330
292
 
331
- /// @dev protocol registration used to anchor the dip ecosystem relations
332
- function _registerProtocol()
333
- internal
293
+ function getServiceAddress(
294
+ ObjectType serviceDomain,
295
+ VersionPart releaseVersion
296
+ ) external view returns (address service)
334
297
  {
335
- uint256 protocolId = _chainNftInternal.PROTOCOL_NFT_ID();
336
- NftId protocolNftId = toNftId(protocolId);
298
+ service = _service[releaseVersion][serviceDomain];
299
+ }
337
300
 
338
- _chainNftInternal.mint(NFT_LOCK_ADDRESS, protocolId);
301
+ function getReleaseAccessManagerAddress(VersionPart version) external view returns (address) {
302
+ return address(_releaseManager.getReleaseAccessManager(version));
303
+ }
339
304
 
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
- );
305
+ function getReleaseManagerAddress() external view returns (address) {
306
+ return address(_releaseManager);
349
307
  }
350
308
 
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);
309
+ function getChainNftAddress() external view override returns (address) {
310
+ return address(_chainNft);
311
+ }
358
312
 
359
- NftId parentNftId;
313
+ function getRegistryAdminAddress() external view returns (address) {
314
+ return address(_admin);
315
+ }
360
316
 
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());
317
+ function getAuthority() external view returns (address) {
318
+ return _admin.authority();
319
+ }
320
+
321
+ function getOwner() public view returns (address owner) {
322
+ return ownerOf(address(this));
323
+ }
324
+
325
+ // IERC165
326
+
327
+ function supportsInterface(bytes4 interfaceId) external pure returns (bool) {
328
+ if(interfaceId == type(IERC165).interfaceId || interfaceId == type(IRegistry).interfaceId) {
329
+ return true;
369
330
  }
370
331
 
371
- _chainNftInternal.mint(registryOwner, registryId);
372
-
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;
332
+ return false;
384
333
  }
385
334
 
335
+ // Internals
386
336
 
387
- /// @dev global registry registration for non mainnet registries
388
- function _registerGlobalRegistry()
337
+ /// @dev registry protects only against tampering existing records, registering with invalid types pairs and 0 parent address
338
+ // TODO registration of precompile addresses
339
+ function _register(ObjectInfo memory info)
389
340
  internal
341
+ returns(NftId nftId)
390
342
  {
391
- uint256 globalRegistryId = _chainNftInternal.GLOBAL_REGISTRY_ID();
343
+ ObjectType objectType = info.objectType;
344
+ bool isInterceptor = info.isInterceptor;
345
+ address objectAddress = info.objectAddress;
346
+ address owner = info.initialOwner;
392
347
 
393
- _chainNftInternal.mint(NFT_LOCK_ADDRESS, globalRegistryId);
348
+ NftId parentNftId = info.parentNftId;
349
+ ObjectInfo memory parentInfo = _info[parentNftId];
350
+ ObjectType parentType = parentInfo.objectType; // see function header
351
+ address parentAddress = parentInfo.objectAddress;
394
352
 
395
- NftId globalRegistryNftId = toNftId(globalRegistryId);
353
+ // parent is contract -> need to check? -> check before minting
354
+ // special case: staking: to protocol possible as well
355
+ // special case: global registry nft as parent when not on mainnet -> global registry address is 0
356
+ // special case: when parentNftId == _chainNft.mint(), check for zero parent address before mint
357
+ // special case: when parentNftId == _chainNft.mint() && objectAddress == initialOwner
358
+ if(objectType != STAKE()) {
359
+ if(parentAddress == address(0)) {
360
+ revert ErrorRegistryParentAddressZero();
361
+ }
362
+ }
396
363
 
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
- }
364
+ address interceptorAddress = _getInterceptor(
365
+ isInterceptor,
366
+ objectType,
367
+ objectAddress,
368
+ parentInfo.isInterceptor,
369
+ parentAddress);
407
370
 
408
- function _registerRegistryService(address registryOwner)
409
- internal
410
- {
411
- uint256 serviceId = _chainNftInternal.calculateTokenId(REGISTRY_SERVICE_TOKEN_SEQUENCE_ID);
412
- NftId serviceNftId = toNftId(serviceId);
371
+ uint256 tokenId = _chainNft.getNextTokenId();
372
+ nftId = NftIdLib.toNftId(tokenId);
373
+ info.nftId = nftId;
374
+ _info[nftId] = info;
375
+
376
+ if(objectAddress > address(0)) {
377
+ if(_nftIdByAddress[objectAddress].gtz()) {
378
+ revert ErrorRegistryContractAlreadyRegistered(objectAddress);
379
+ }
413
380
 
414
- _chainNftInternal.mint(registryOwner, serviceId);
381
+ _nftIdByAddress[objectAddress] = nftId;
382
+ }
415
383
 
416
- _info[serviceNftId] = ObjectInfo(
417
- serviceNftId,
418
- _registryNftId,
419
- SERVICE(),
420
- false, // isInterceptor
421
- msg.sender, // service deploys registry
422
- registryOwner, // initialOwner,
423
- ""
424
- );
384
+ emit LogRegistration(nftId, parentNftId, objectType, isInterceptor, objectAddress, owner);
425
385
 
426
- _nftIdByAddress[msg.sender] = serviceNftId;
386
+ // calls nft receiver(1) and interceptor(2)
387
+ uint256 mintedTokenId = _chainNft.mint(
388
+ owner,
389
+ interceptorAddress,
390
+ EMPTY_URI);
427
391
 
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;
392
+ assert(mintedTokenId == tokenId);
433
393
  }
434
394
 
435
395
  /// @dev obtain interceptor address for this nft if applicable, address(0) otherwise
396
+ /// special case: STAKES (parent may be any type) -> no intercept call
397
+ /// default case:
436
398
  function _getInterceptor(
437
399
  bool isInterceptor,
400
+ ObjectType objectType,
438
401
  address objectAddress,
439
402
  bool parentIsInterceptor,
440
403
  address parentObjectAddress
441
404
  )
442
405
  internal
443
- view
406
+ pure
444
407
  returns (address interceptor)
445
408
  {
409
+ // no intercepting calls for stakes
410
+ if (objectType == STAKE()) {
411
+ return address(0);
412
+ }
413
+
446
414
  if (objectAddress == address(0)) {
447
415
  if (parentIsInterceptor) {
448
416
  return parentObjectAddress;
@@ -458,33 +426,157 @@ contract Registry is
458
426
  return address(0);
459
427
  }
460
428
 
429
+ // Internals called only in constructor
430
+
431
+ /// @dev protocol registration used to anchor the dip ecosystem relations
432
+ function _registerProtocol()
433
+ private
434
+ returns (NftId protocolNftId)
435
+ {
436
+ uint256 protocolId = _chainNft.PROTOCOL_NFT_ID();
437
+ protocolNftId = NftIdLib.toNftId(protocolId);
438
+
439
+ _info[protocolNftId] = ObjectInfo({
440
+ nftId: protocolNftId,
441
+ parentNftId: NftIdLib.zero(),
442
+ objectType: PROTOCOL(),
443
+ isInterceptor: false,
444
+ objectAddress: address(0),
445
+ initialOwner: NFT_LOCK_ADDRESS,
446
+ data: ""
447
+ });
448
+
449
+ _chainNft.mint(NFT_LOCK_ADDRESS, protocolId);
450
+ }
451
+
452
+ /// @dev registry registration
453
+ /// might also register the global registry when not on mainnet
454
+ function _registerRegistry()
455
+ private
456
+ returns (NftId registryNftId)
457
+ {
458
+ uint256 registryId = _chainNft.calculateTokenId(REGISTRY_TOKEN_SEQUENCE_ID);
459
+ registryNftId = NftIdLib.toNftId(registryId);
460
+ NftId parentNftId;
461
+
462
+ if(registryId != _chainNft.GLOBAL_REGISTRY_ID())
463
+ {// we're not the global registry
464
+ _registerGlobalRegistry();
465
+ parentNftId = NftIdLib.toNftId(_chainNft.GLOBAL_REGISTRY_ID());
466
+ }
467
+ else
468
+ {// we are global registry
469
+ parentNftId = _protocolNftId;
470
+ }
471
+
472
+ _info[registryNftId] = ObjectInfo({
473
+ nftId: registryNftId,
474
+ parentNftId: parentNftId,
475
+ objectType: REGISTRY(),
476
+ isInterceptor: false,
477
+ objectAddress: address(this),
478
+ initialOwner: NFT_LOCK_ADDRESS,
479
+ data: ""
480
+ });
481
+
482
+ _nftIdByAddress[address(this)] = registryNftId;
483
+ _chainNft.mint(NFT_LOCK_ADDRESS, registryId);
484
+ }
485
+
486
+ /// @dev global registry registration for non mainnet registries
487
+ function _registerGlobalRegistry()
488
+ private
489
+ {
490
+ uint256 globalRegistryId = _chainNft.GLOBAL_REGISTRY_ID();
491
+ NftId globalRegistryNftId = NftIdLib.toNftId(globalRegistryId);
492
+
493
+ _info[globalRegistryNftId] = ObjectInfo({
494
+ nftId: globalRegistryNftId,
495
+ parentNftId: NftIdLib.toNftId(_chainNft.PROTOCOL_NFT_ID()),
496
+ objectType: REGISTRY(),
497
+ isInterceptor: false,
498
+ objectAddress: address(0),
499
+ initialOwner: NFT_LOCK_ADDRESS,
500
+ data: ""
501
+ });
502
+
503
+ _chainNft.mint(NFT_LOCK_ADDRESS, globalRegistryId);
504
+ }
505
+ // depends on _registryNftId and _stakingAddress
506
+ function _registerStaking()
507
+ private
508
+ returns (NftId stakingNftId)
509
+ {
510
+ address stakingOwner = IRegisterable(_stakingAddress).getOwner();
511
+ uint256 stakingId = _chainNft.calculateTokenId(STAKING_TOKEN_SEQUENCE_ID);
512
+ stakingNftId = NftIdLib.toNftId(stakingId);
513
+
514
+ _info[stakingNftId] = ObjectInfo({
515
+ nftId: stakingNftId,
516
+ parentNftId: _registryNftId,
517
+ objectType: STAKING(),
518
+ isInterceptor: false,
519
+ objectAddress: _stakingAddress,
520
+ initialOwner: stakingOwner,
521
+ data: ""
522
+ });
523
+
524
+ _nftIdByAddress[_stakingAddress] = stakingNftId;
525
+ // reverts if nftId was already minted
526
+ _chainNft.mint(stakingOwner, stakingId);
527
+ }
528
+
461
529
  /// @dev defines which object - parent types relations are allowed to register
462
530
  // IMPORTANT:
463
531
  // 1) EACH object type MUST have only one parent type across ALL mappings
464
532
  // 2) DO NOT use object type (e.g. POLCY, BUNDLE, STAKE) as parent type
465
533
  // 3) DO NOT use REGISTRY as object type
466
- // 2) DO NOT use PROTOCOL and "zeroObjectType"
467
- function _setupValidObjectParentCombinations()
468
- internal
534
+ // 2) DO NOT use PROTOCOL and "ObjectTypeLib.zero"
535
+ function _setupValidCoreTypesAndCombinations()
536
+ private
469
537
  {
470
- // registry as parent, ONLY registry owner
471
- _isValidContractCombination[TOKEN()][REGISTRY()] = true;
472
- _isValidContractCombination[SERVICE()][REGISTRY()] = true;
473
-
474
- // registry as parent, ONLY approved
475
- _isValidContractCombination[INSTANCE()][REGISTRY()] = true;
476
-
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;
482
-
483
- // product as parent, ONLY approved
484
- _isValidObjectCombination[POLICY()][PRODUCT()] = true;
485
-
486
- // pool as parent, ONLY approved
487
- _isValidObjectCombination[BUNDLE()][POOL()] = true;
488
- _isValidObjectCombination[STAKE()][POOL()] = true;
538
+ _coreTypes[REGISTRY()] = true;
539
+ _coreTypes[SERVICE()] = true;
540
+ _coreTypes[TOKEN()] = true;
541
+ _coreTypes[INSTANCE()] = true;
542
+ _coreTypes[PRODUCT()] = true;
543
+ _coreTypes[POOL()] = true;
544
+ _coreTypes[DISTRIBUTION()] = true;
545
+ _coreTypes[DISTRIBUTOR()] = true;
546
+ _coreTypes[ORACLE()] = true;
547
+ _coreTypes[POLICY()] = true;
548
+ _coreTypes[BUNDLE()] = true;
549
+ _coreTypes[STAKING()] = true;
550
+ _coreTypes[STAKE()] = true;
551
+
552
+ uint256 registryId = _chainNft.calculateTokenId(REGISTRY_TOKEN_SEQUENCE_ID);
553
+ if(registryId == _chainNft.GLOBAL_REGISTRY_ID()) {
554
+ // we are global registry
555
+ // object is registry from different chain
556
+ // parent is global registry, this contract
557
+ _coreContractCombinations[REGISTRY()][REGISTRY()] = true; // only for global regstry
558
+ //_coreObjectCombinations[REGISTRY()][REGISTRY()] = true;
559
+ } else {
560
+ // we are not global registry
561
+ // object is local registry, this contract
562
+ // parent is global registry, object with 0 address or registry from mainnet???
563
+ }
564
+ _coreContractCombinations[STAKING()][REGISTRY()] = true; // only for chain staking contract
565
+ _coreContractCombinations[TOKEN()][REGISTRY()] = true;
566
+ //_coreContractCombinations[SERVICE()][REGISTRY()] = true;// do not need it here -> registerService() registers exactly this combination
567
+ _coreContractCombinations[INSTANCE()][REGISTRY()] = true;
568
+
569
+ _coreContractCombinations[PRODUCT()][INSTANCE()] = true;
570
+ _coreContractCombinations[DISTRIBUTION()][INSTANCE()] = true;
571
+ _coreContractCombinations[ORACLE()][INSTANCE()] = true;
572
+ _coreContractCombinations[POOL()][INSTANCE()] = true;
573
+
574
+ _coreObjectCombinations[DISTRIBUTOR()][DISTRIBUTION()] = true;
575
+ _coreObjectCombinations[POLICY()][PRODUCT()] = true;
576
+ _coreObjectCombinations[BUNDLE()][POOL()] = true;
577
+
578
+ // staking
579
+ _coreObjectCombinations[STAKE()][PROTOCOL()] = true;
580
+ _coreObjectCombinations[STAKE()][INSTANCE()] = true;
489
581
  }
490
582
  }