@etherisc/gif-next 0.0.2-8d47fa1-080 → 0.0.2-8f5f625-515

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (477) hide show
  1. package/README.md +243 -2
  2. package/artifacts/contracts/components/Component.sol/Component.dbg.json +4 -0
  3. package/artifacts/contracts/components/Component.sol/Component.json +832 -0
  4. package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +1 -1
  5. package/artifacts/contracts/components/Distribution.sol/Distribution.json +1038 -164
  6. package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +4 -0
  7. package/artifacts/contracts/{instance/base/InstanceBase.sol/InstanceBase.json → components/IComponent.sol/IComponent.json} +240 -191
  8. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
  9. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +561 -35
  10. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
  11. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +584 -104
  12. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +1 -1
  13. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +408 -51
  14. package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
  15. package/artifacts/contracts/components/Pool.sol/Pool.json +1027 -273
  16. package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
  17. package/artifacts/contracts/components/Product.sol/Product.json +799 -144
  18. package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +4 -0
  19. package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +1206 -0
  20. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +4 -0
  21. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +778 -0
  22. package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +4 -0
  23. package/artifacts/contracts/instance/Cloneable.sol/Cloneable.json +190 -0
  24. package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
  25. package/artifacts/contracts/instance/IInstance.sol/IInstance.json +1357 -1182
  26. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +4 -0
  27. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +567 -0
  28. package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
  29. package/artifacts/contracts/instance/Instance.sol/Instance.json +2000 -1310
  30. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +4 -0
  31. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +1311 -0
  32. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +4 -0
  33. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +1279 -0
  34. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +4 -0
  35. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +1033 -0
  36. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +4 -0
  37. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +701 -0
  38. package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +4 -0
  39. package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +256 -0
  40. package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.dbg.json +4 -0
  41. package/artifacts/contracts/instance/base/{ServiceBase.sol/ServiceBase.json → ComponentService.sol/ComponentService.json} +294 -122
  42. package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
  43. package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.json +27 -158
  44. package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +1 -1
  45. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
  46. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +67 -245
  47. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +1 -1
  48. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +36 -11
  49. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +4 -0
  50. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +237 -0
  51. package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +4 -0
  52. package/artifacts/contracts/instance/module/{bundle/IBundle.sol → IBundle.sol}/IBundle.json +1 -1
  53. package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +4 -0
  54. package/artifacts/contracts/instance/module/{access/IAccess.sol/IAccess.json → IComponents.sol/IComponents.json} +2 -2
  55. package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +4 -0
  56. package/artifacts/contracts/instance/module/{distribution/IDistribution.sol → IDistribution.sol}/IDistribution.json +1 -1
  57. package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +4 -0
  58. package/artifacts/contracts/instance/module/{policy/IPolicy.sol → IPolicy.sol}/IPolicy.json +1 -1
  59. package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +4 -0
  60. package/artifacts/contracts/instance/module/{risk/IRisk.sol → IRisk.sol}/IRisk.json +1 -1
  61. package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +4 -0
  62. package/artifacts/contracts/instance/{base/ModuleBase.sol/ModuleBase.json → module/ISetup.sol/ISetup.json} +2 -2
  63. package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +4 -0
  64. package/artifacts/contracts/instance/module/{treasury/ITreasury.sol → ITreasury.sol}/ITreasury.json +1 -1
  65. package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.dbg.json +4 -0
  66. package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.json +968 -0
  67. package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
  68. package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.json +665 -0
  69. package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +4 -0
  70. package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +1093 -0
  71. package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
  72. package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +661 -0
  73. package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.dbg.json +4 -0
  74. package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.json +754 -0
  75. package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
  76. package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.json +637 -0
  77. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +1 -1
  78. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +1544 -338
  79. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
  80. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +805 -0
  81. package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.dbg.json +4 -0
  82. package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.json +556 -0
  83. package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +4 -0
  84. package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.json +630 -0
  85. package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.dbg.json +4 -0
  86. package/artifacts/contracts/instance/service/{IComponentOwnerService.sol/IComponentOwnerService.json → IClaimService.sol/IClaimService.json} +209 -189
  87. package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +1 -1
  88. package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.json +768 -124
  89. package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +4 -0
  90. package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.json +540 -0
  91. package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +1 -1
  92. package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +135 -191
  93. package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +1 -1
  94. package/artifacts/contracts/instance/service/IProductService.sol/IProductService.json +65 -355
  95. package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +4 -0
  96. package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +1021 -0
  97. package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
  98. package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +689 -0
  99. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +1 -1
  100. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +388 -213
  101. package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
  102. package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +657 -0
  103. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +1 -1
  104. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +285 -472
  105. package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +4 -0
  106. package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +649 -0
  107. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
  108. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +60 -2
  109. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
  110. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +250 -65
  111. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
  112. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +391 -169
  113. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
  114. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +18 -0
  115. package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
  116. package/artifacts/contracts/registry/Registry.sol/Registry.json +229 -206
  117. package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +4 -0
  118. package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +285 -0
  119. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
  120. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +511 -195
  121. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +4 -0
  122. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +670 -0
  123. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +4 -0
  124. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +547 -0
  125. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +4 -0
  126. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +498 -0
  127. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +4 -0
  128. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +107 -0
  129. package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
  130. package/artifacts/contracts/shared/ERC165.sol/ERC165.json +41 -3
  131. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +4 -0
  132. package/artifacts/contracts/{instance/module/component/ComponentModule.sol/ComponentModule.json → shared/INftOwnable.sol/INftOwnable.json} +71 -50
  133. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +4 -0
  134. package/artifacts/contracts/{instance/module/component/IComponent.sol/IComponentModule.json → shared/IPolicyHolder.sol/IPolicyHolder.json} +69 -57
  135. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
  136. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +72 -8
  137. package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +4 -0
  138. package/artifacts/contracts/{experiment/inheritance/IB.sol/IB.json → shared/IRegistryLinked.sol/IRegistryLinked.json} +18 -20
  139. package/artifacts/contracts/shared/IService.sol/IService.dbg.json +4 -0
  140. package/artifacts/contracts/{components/BaseComponent.sol/BaseComponent.json → shared/IService.sol/IService.json} +93 -37
  141. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
  142. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +2 -152
  143. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +4 -0
  144. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +251 -0
  145. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +4 -0
  146. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +248 -0
  147. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
  148. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +355 -83
  149. package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
  150. package/artifacts/contracts/shared/Registerable.sol/Registerable.json +204 -12
  151. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +4 -0
  152. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +84 -0
  153. package/artifacts/contracts/shared/Service.sol/Service.dbg.json +4 -0
  154. package/artifacts/contracts/{instance/base/ComponentServiceBase.sol/ComponentServiceBase.json → shared/Service.sol/Service.json} +172 -140
  155. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +4 -0
  156. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +96 -0
  157. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
  158. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +2 -2
  159. package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
  160. package/artifacts/contracts/shared/Versionable.sol/Versionable.json +2 -152
  161. package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +1 -1
  162. package/artifacts/contracts/test/TestFee.sol/TestFee.json +4 -4
  163. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +1 -1
  164. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +204 -12
  165. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +1 -1
  166. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +14 -14
  167. package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +1 -1
  168. package/artifacts/contracts/test/TestService.sol/TestService.json +209 -160
  169. package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +1 -1
  170. package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +91 -53
  171. package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +1 -1
  172. package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +2 -2
  173. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +1 -1
  174. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +8 -174
  175. package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +1 -1
  176. package/artifacts/contracts/test/Usdc.sol/USDC.json +91 -53
  177. package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +1 -1
  178. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
  179. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +2 -2
  180. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +1 -1
  181. package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
  182. package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.json +100 -0
  183. package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +4 -0
  184. package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.json +104 -0
  185. package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +1 -1
  186. package/artifacts/contracts/types/Fee.sol/FeeLib.json +4 -4
  187. package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +1 -1
  188. package/artifacts/contracts/types/Key32.sol/Key32Lib.json +31 -17
  189. package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
  190. package/artifacts/contracts/types/NftId.sol/NftIdLib.json +17 -4
  191. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
  192. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.json +26 -3
  193. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +4 -0
  194. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.json +100 -0
  195. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
  196. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +2 -2
  197. package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
  198. package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.json +100 -0
  199. package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +4 -0
  200. package/artifacts/contracts/types/Referral.sol/ReferralLib.json +142 -0
  201. package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +1 -1
  202. package/artifacts/contracts/types/RiskId.sol/RiskIdLib.json +2 -2
  203. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +1 -1
  204. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +134 -8
  205. package/artifacts/contracts/types/Seconds.sol/SecondsLib.dbg.json +4 -0
  206. package/artifacts/contracts/types/Seconds.sol/SecondsLib.json +124 -0
  207. package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +1 -1
  208. package/artifacts/contracts/types/StateId.sol/StateIdLib.json +2 -2
  209. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +1 -1
  210. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +38 -7
  211. package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +4 -0
  212. package/artifacts/contracts/{experiment/types/TypeB.sol/TypeBLib.json → types/UFixed.sol/MathLib.json} +4 -4
  213. package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +4 -0
  214. package/artifacts/contracts/types/UFixed.sol/{UFixedMathLib.json → UFixedLib.json} +3 -3
  215. package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +1 -1
  216. package/artifacts/contracts/types/Version.sol/VersionLib.json +2 -2
  217. package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +1 -1
  218. package/artifacts/contracts/types/Version.sol/VersionPartLib.json +22 -3
  219. package/contracts/components/Component.sol +251 -0
  220. package/contracts/components/Distribution.sol +204 -79
  221. package/contracts/components/IComponent.sol +74 -0
  222. package/contracts/components/IDistributionComponent.sol +43 -19
  223. package/contracts/components/IPoolComponent.sol +88 -40
  224. package/contracts/components/IProductComponent.sol +11 -10
  225. package/contracts/components/Pool.sol +216 -163
  226. package/contracts/components/Product.sol +137 -143
  227. package/contracts/instance/AccessManagerUpgradeableInitializeable.sol +13 -0
  228. package/contracts/instance/BundleManager.sol +127 -0
  229. package/contracts/instance/Cloneable.sol +51 -0
  230. package/contracts/instance/IInstance.sol +86 -42
  231. package/contracts/instance/IInstanceService.sol +72 -0
  232. package/contracts/instance/Instance.sol +310 -68
  233. package/contracts/instance/InstanceAccessManager.sol +524 -0
  234. package/contracts/instance/InstanceReader.sol +290 -0
  235. package/contracts/instance/InstanceService.sol +495 -0
  236. package/contracts/instance/InstanceServiceManager.sol +54 -0
  237. package/contracts/instance/ObjectManager.sol +82 -0
  238. package/contracts/instance/base/ComponentService.sol +134 -0
  239. package/contracts/instance/base/IKeyValueStore.sol +13 -14
  240. package/contracts/instance/base/ILifecycle.sol +3 -3
  241. package/contracts/instance/base/KeyValueStore.sol +52 -38
  242. package/contracts/instance/base/Lifecycle.sol +12 -3
  243. package/contracts/instance/module/IAccess.sol +54 -0
  244. package/contracts/instance/module/IBundle.sol +21 -0
  245. package/contracts/instance/module/IComponents.sol +35 -0
  246. package/contracts/instance/module/IDistribution.sol +41 -0
  247. package/contracts/instance/module/IPolicy.sol +72 -0
  248. package/contracts/instance/module/IRisk.sol +11 -0
  249. package/contracts/instance/module/ISetup.sol +33 -0
  250. package/contracts/instance/module/ITreasury.sol +23 -0
  251. package/contracts/instance/service/ApplicationService.sol +350 -0
  252. package/contracts/instance/service/ApplicationServiceManager.sol +35 -0
  253. package/contracts/instance/service/BundleService.sol +336 -0
  254. package/contracts/instance/service/BundleServiceManager.sol +51 -0
  255. package/contracts/instance/service/ClaimService.sol +151 -0
  256. package/contracts/instance/service/ClaimServiceManager.sol +35 -0
  257. package/contracts/instance/service/DistributionService.sol +435 -22
  258. package/contracts/instance/service/DistributionServiceManager.sol +51 -0
  259. package/contracts/instance/service/IApplicationService.sol +82 -0
  260. package/contracts/instance/service/IBundleService.sol +62 -0
  261. package/contracts/instance/service/IClaimService.sol +61 -0
  262. package/contracts/instance/service/IDistributionService.sol +87 -1
  263. package/contracts/instance/service/IPolicyService.sol +72 -0
  264. package/contracts/instance/service/IPoolService.sol +22 -24
  265. package/contracts/instance/service/IProductService.sol +9 -76
  266. package/contracts/instance/service/PolicyService.sol +403 -0
  267. package/contracts/instance/service/PolicyServiceManager.sol +54 -0
  268. package/contracts/instance/service/PoolService.sol +181 -110
  269. package/contracts/instance/service/PoolServiceManager.sol +51 -0
  270. package/contracts/instance/service/ProductService.sol +165 -433
  271. package/contracts/instance/service/ProductServiceManager.sol +54 -0
  272. package/contracts/registry/ChainNft.sol +49 -26
  273. package/contracts/registry/IRegistry.sol +57 -31
  274. package/contracts/registry/IRegistryService.sol +54 -16
  275. package/contracts/registry/ITransferInterceptor.sol +1 -0
  276. package/contracts/registry/Registry.sol +288 -324
  277. package/contracts/registry/RegistryAccessManager.sol +216 -0
  278. package/contracts/registry/RegistryService.sol +160 -260
  279. package/contracts/registry/RegistryServiceManager.sol +62 -0
  280. package/contracts/registry/ReleaseManager.sol +322 -0
  281. package/contracts/registry/TokenRegistry.sol +116 -0
  282. package/contracts/shared/ContractDeployerLib.sol +72 -0
  283. package/contracts/shared/ERC165.sol +15 -9
  284. package/contracts/shared/INftOwnable.sol +23 -0
  285. package/contracts/shared/IPolicyHolder.sol +26 -0
  286. package/contracts/shared/IRegisterable.sol +5 -12
  287. package/contracts/shared/IRegistryLinked.sol +12 -0
  288. package/contracts/shared/IService.sol +18 -0
  289. package/contracts/shared/IVersionable.sol +4 -47
  290. package/contracts/shared/NftOwnable.sol +120 -0
  291. package/contracts/shared/PolicyHolder.sol +81 -0
  292. package/contracts/shared/ProxyManager.sol +112 -58
  293. package/contracts/shared/Registerable.sol +23 -66
  294. package/contracts/shared/RegistryLinked.sol +48 -0
  295. package/contracts/shared/Service.sol +58 -0
  296. package/contracts/shared/TokenHandler.sol +33 -0
  297. package/contracts/shared/UpgradableProxyWithAdmin.sol +2 -2
  298. package/contracts/shared/Versionable.sol +5 -93
  299. package/contracts/test/TestFee.sol +2 -2
  300. package/contracts/test/TestRegisterable.sol +1 -1
  301. package/contracts/test/TestRoleId.sol +1 -1
  302. package/contracts/test/TestService.sol +6 -7
  303. package/contracts/types/Blocknumber.sol +1 -0
  304. package/contracts/types/ClaimId.sol +52 -0
  305. package/contracts/types/DistributorType.sol +55 -0
  306. package/contracts/types/Fee.sol +4 -3
  307. package/contracts/types/Key32.sol +8 -3
  308. package/contracts/types/NftId.sol +8 -0
  309. package/contracts/types/NftIdSet.sol +26 -24
  310. package/contracts/types/NumberId.sol +52 -0
  311. package/contracts/types/ObjectType.sol +40 -14
  312. package/contracts/types/PayoutId.sol +54 -0
  313. package/contracts/types/Referral.sol +89 -0
  314. package/contracts/types/RoleId.sol +68 -9
  315. package/contracts/types/Seconds.sol +54 -0
  316. package/contracts/types/StateId.sol +6 -1
  317. package/contracts/types/Timestamp.sol +17 -13
  318. package/contracts/types/UFixed.sol +129 -12
  319. package/contracts/types/Version.sol +5 -1
  320. package/package.json +6 -5
  321. package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +0 -4
  322. package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +0 -4
  323. package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.json +0 -177
  324. package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +0 -4
  325. package/artifacts/contracts/experiment/errors/Require.sol/Require.json +0 -105
  326. package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +0 -4
  327. package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +0 -105
  328. package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +0 -4
  329. package/artifacts/contracts/experiment/inheritance/A.sol/A.json +0 -128
  330. package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +0 -4
  331. package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +0 -42
  332. package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +0 -4
  333. package/artifacts/contracts/experiment/inheritance/B.sol/B.json +0 -76
  334. package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +0 -4
  335. package/artifacts/contracts/experiment/inheritance/C.sol/C.json +0 -89
  336. package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +0 -4
  337. package/artifacts/contracts/experiment/inheritance/IA.sol/IA.json +0 -128
  338. package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +0 -4
  339. package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.json +0 -37
  340. package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +0 -4
  341. package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +0 -4
  342. package/artifacts/contracts/experiment/inheritance/IC.sol/IC.json +0 -63
  343. package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.dbg.json +0 -4
  344. package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +0 -59
  345. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +0 -4
  346. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.json +0 -124
  347. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +0 -4
  348. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.json +0 -74
  349. package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +0 -4
  350. package/artifacts/contracts/experiment/statemachine/SM.sol/SM.json +0 -124
  351. package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +0 -4
  352. package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.json +0 -207
  353. package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +0 -4
  354. package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.json +0 -10
  355. package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +0 -4
  356. package/artifacts/contracts/instance/IInstanceLinked.sol/IInstanceLinked.dbg.json +0 -4
  357. package/artifacts/contracts/instance/IInstanceLinked.sol/IInstanceLinked.json +0 -24
  358. package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +0 -4
  359. package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +0 -4
  360. package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.json +0 -113
  361. package/artifacts/contracts/instance/base/IService.sol/IService.dbg.json +0 -4
  362. package/artifacts/contracts/instance/base/IService.sol/IService.json +0 -344
  363. package/artifacts/contracts/instance/base/InstanceBase.sol/InstanceBase.dbg.json +0 -4
  364. package/artifacts/contracts/instance/base/ModuleBase.sol/ModuleBase.dbg.json +0 -4
  365. package/artifacts/contracts/instance/base/ServiceBase.sol/ServiceBase.dbg.json +0 -4
  366. package/artifacts/contracts/instance/module/access/Access.sol/AccessModule.dbg.json +0 -4
  367. package/artifacts/contracts/instance/module/access/Access.sol/AccessModule.json +0 -333
  368. package/artifacts/contracts/instance/module/access/IAccess.sol/IAccess.dbg.json +0 -4
  369. package/artifacts/contracts/instance/module/access/IAccess.sol/IAccessModule.dbg.json +0 -4
  370. package/artifacts/contracts/instance/module/access/IAccess.sol/IAccessModule.json +0 -333
  371. package/artifacts/contracts/instance/module/bundle/BundleModule.sol/BundleModule.dbg.json +0 -4
  372. package/artifacts/contracts/instance/module/bundle/BundleModule.sol/BundleModule.json +0 -297
  373. package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundle.dbg.json +0 -4
  374. package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundleModule.dbg.json +0 -4
  375. package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundleModule.json +0 -297
  376. package/artifacts/contracts/instance/module/component/ComponentModule.sol/ComponentModule.dbg.json +0 -4
  377. package/artifacts/contracts/instance/module/component/IComponent.sol/IComponent.dbg.json +0 -4
  378. package/artifacts/contracts/instance/module/component/IComponent.sol/IComponent.json +0 -10
  379. package/artifacts/contracts/instance/module/component/IComponent.sol/IComponentModule.dbg.json +0 -4
  380. package/artifacts/contracts/instance/module/distribution/DistributionModule.sol/DistributionModule.dbg.json +0 -4
  381. package/artifacts/contracts/instance/module/distribution/DistributionModule.sol/DistributionModule.json +0 -10
  382. package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistribution.dbg.json +0 -4
  383. package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistributionModule.dbg.json +0 -4
  384. package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistributionModule.json +0 -10
  385. package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicy.dbg.json +0 -4
  386. package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicyModule.dbg.json +0 -4
  387. package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicyModule.json +0 -284
  388. package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.dbg.json +0 -4
  389. package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.json +0 -284
  390. package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPool.dbg.json +0 -4
  391. package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPool.json +0 -10
  392. package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPoolModule.dbg.json +0 -4
  393. package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPoolModule.json +0 -164
  394. package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.dbg.json +0 -4
  395. package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.json +0 -164
  396. package/artifacts/contracts/instance/module/risk/IRisk.sol/IRisk.dbg.json +0 -4
  397. package/artifacts/contracts/instance/module/risk/IRisk.sol/IRiskModule.dbg.json +0 -4
  398. package/artifacts/contracts/instance/module/risk/IRisk.sol/IRiskModule.json +0 -113
  399. package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.dbg.json +0 -4
  400. package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.json +0 -131
  401. package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasury.dbg.json +0 -4
  402. package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasuryModule.dbg.json +0 -4
  403. package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasuryModule.json +0 -638
  404. package/artifacts/contracts/instance/module/treasury/TokenHandler.sol/TokenHandler.dbg.json +0 -4
  405. package/artifacts/contracts/instance/module/treasury/TokenHandler.sol/TokenHandler.json +0 -76
  406. package/artifacts/contracts/instance/module/treasury/TreasuryModule.sol/TreasuryModule.dbg.json +0 -4
  407. package/artifacts/contracts/instance/module/treasury/TreasuryModule.sol/TreasuryModule.json +0 -638
  408. package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +0 -4
  409. package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +0 -690
  410. package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +0 -4
  411. package/artifacts/contracts/registry/IChainNft.sol/IChainNft.dbg.json +0 -4
  412. package/artifacts/contracts/registry/IChainNft.sol/IChainNft.json +0 -457
  413. package/artifacts/contracts/registry/IRegistryLinked.sol/IRegistryLinked.dbg.json +0 -4
  414. package/artifacts/contracts/registry/IRegistryLinked.sol/IRegistryLinked.json +0 -24
  415. package/artifacts/contracts/registry/RegistryInstaller.sol/RegistryInstaller.dbg.json +0 -4
  416. package/artifacts/contracts/registry/RegistryInstaller.sol/RegistryInstaller.json +0 -344
  417. package/artifacts/contracts/shared/IOwnable.sol/IOwnable.dbg.json +0 -4
  418. package/artifacts/contracts/shared/IOwnable.sol/IOwnable.json +0 -24
  419. package/artifacts/contracts/test/TestDistribution.sol/TestDistribution.dbg.json +0 -4
  420. package/artifacts/contracts/test/TestDistribution.sol/TestDistribution.json +0 -445
  421. package/artifacts/contracts/test/TestPool.sol/TestPool.dbg.json +0 -4
  422. package/artifacts/contracts/test/TestPool.sol/TestPool.json +0 -602
  423. package/artifacts/contracts/test/TestProduct.sol/TestProduct.dbg.json +0 -4
  424. package/artifacts/contracts/test/TestProduct.sol/TestProduct.json +0 -632
  425. package/artifacts/contracts/types/ReferralId.sol/ReferralIdLib.dbg.json +0 -4
  426. package/artifacts/contracts/types/ReferralId.sol/ReferralIdLib.json +0 -99
  427. package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.dbg.json +0 -4
  428. package/contracts/components/BaseComponent.sol +0 -79
  429. package/contracts/components/IBaseComponent.sol +0 -19
  430. package/contracts/experiment/errors/Require.sol +0 -38
  431. package/contracts/experiment/errors/Revert.sol +0 -44
  432. package/contracts/experiment/inheritance/A.sol +0 -53
  433. package/contracts/experiment/inheritance/B.sol +0 -28
  434. package/contracts/experiment/inheritance/C.sol +0 -34
  435. package/contracts/experiment/inheritance/IA.sol +0 -13
  436. package/contracts/experiment/inheritance/IB.sol +0 -10
  437. package/contracts/experiment/inheritance/IC.sol +0 -12
  438. package/contracts/experiment/statemachine/Dummy.sol +0 -27
  439. package/contracts/experiment/statemachine/ISM.sol +0 -25
  440. package/contracts/experiment/statemachine/SM.sol +0 -57
  441. package/contracts/experiment/statemachine/SimpleStateMachine.sol +0 -31
  442. package/contracts/experiment/types/TypeA.sol +0 -47
  443. package/contracts/experiment/types/TypeB.sol +0 -29
  444. package/contracts/instance/IInstanceLinked.sol +0 -8
  445. package/contracts/instance/base/ComponentServiceBase.sol +0 -49
  446. package/contracts/instance/base/IInstanceBase.sol +0 -23
  447. package/contracts/instance/base/IService.sol +0 -15
  448. package/contracts/instance/base/InstanceBase.sol +0 -89
  449. package/contracts/instance/base/ModuleBase.sol +0 -57
  450. package/contracts/instance/base/ServiceBase.sol +0 -43
  451. package/contracts/instance/module/access/Access.sol +0 -149
  452. package/contracts/instance/module/access/IAccess.sol +0 -53
  453. package/contracts/instance/module/bundle/BundleModule.sol +0 -134
  454. package/contracts/instance/module/bundle/IBundle.sol +0 -53
  455. package/contracts/instance/module/component/ComponentModule.sol +0 -71
  456. package/contracts/instance/module/component/IComponent.sol +0 -28
  457. package/contracts/instance/module/distribution/DistributionModule.sol +0 -17
  458. package/contracts/instance/module/distribution/IDistribution.sol +0 -10
  459. package/contracts/instance/module/policy/IPolicy.sol +0 -63
  460. package/contracts/instance/module/policy/PolicyModule.sol +0 -91
  461. package/contracts/instance/module/pool/IPoolModule.sol +0 -41
  462. package/contracts/instance/module/pool/PoolModule.sol +0 -95
  463. package/contracts/instance/module/risk/IRisk.sol +0 -26
  464. package/contracts/instance/module/risk/RiskModule.sol +0 -62
  465. package/contracts/instance/module/treasury/ITreasury.sol +0 -84
  466. package/contracts/instance/module/treasury/TokenHandler.sol +0 -48
  467. package/contracts/instance/module/treasury/TreasuryModule.sol +0 -131
  468. package/contracts/instance/service/ComponentOwnerService.sol +0 -272
  469. package/contracts/instance/service/IComponentOwnerService.sol +0 -20
  470. package/contracts/registry/IChainNft.sol +0 -22
  471. package/contracts/registry/IRegistryLinked.sol +0 -8
  472. package/contracts/registry/RegistryInstaller.sol +0 -100
  473. package/contracts/shared/IOwnable.sol +0 -6
  474. package/contracts/test/TestDistribution.sol +0 -22
  475. package/contracts/test/TestPool.sol +0 -27
  476. package/contracts/test/TestProduct.sol +0 -74
  477. package/contracts/types/ReferralId.sol +0 -48
@@ -1,450 +1,324 @@
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
+
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";
6
9
 
7
- import {IChainNft} from "./IChainNft.sol";
8
10
  import {ChainNft} from "./ChainNft.sol";
9
11
  import {IRegistry} from "./IRegistry.sol";
10
- import {NftId, toNftId, zeroNftId, NftIdLib} from "../types/NftId.sol";
11
- import {Version, VersionPart, VersionLib} from "../types/Version.sol";
12
- import {ObjectType, PROTOCOL, REGISTRY, TOKEN, SERVICE, INSTANCE, STAKE, PRODUCT, DISTRIBUTION, ORACLE, POOL, POLICY, BUNDLE} from "../types/ObjectType.sol";
13
- import {ITransferInterceptor} from "./ITransferInterceptor.sol";
14
-
15
- import {IOwnable} from "../shared/IOwnable.sol";
16
- import {ERC165} from "../shared/ERC165.sol";
17
-
12
+ import {ReleaseManager} from "./ReleaseManager.sol";
18
13
 
19
14
  // IMPORTANT
20
15
  // Each NFT minted by registry is accosiated with:
21
16
  // 1) NFT owner
22
17
  // 2) registred contract OR object stored in registered (parent) contract
23
18
  // 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)
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)
28
23
 
29
24
  contract Registry is
30
- ERC165,
31
25
  IRegistry
32
26
  {
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
-
27
+ address public constant NFT_LOCK_ADDRESS = address(0x1);
28
+ uint256 public constant REGISTRY_TOKEN_SEQUENCE_ID = 2;
48
29
  string public constant EMPTY_URI = "";
49
30
 
50
- address constant public NFT_LOCK_ADDRESS = address(0x1);
31
+ mapping(NftId nftId => ObjectInfo info) private _info;
32
+ mapping(address object => NftId nftId) private _nftIdByAddress;
51
33
 
52
- mapping(NftId nftId => ObjectInfo info) _info;
53
- mapping(address object => NftId nftId) _nftIdByAddress;
34
+ mapping(VersionPart version => mapping(ObjectType serviceDomain => address)) private _service;
54
35
 
55
- mapping(NftId registrator => mapping(
56
- ObjectType objectType => bool)) _isApproved;
36
+ mapping(ObjectType objectType => bool) private _coreTypes;
57
37
 
58
38
  mapping(ObjectType objectType => mapping(
59
- ObjectType parentType => bool)) _isValidContractCombination;
39
+ ObjectType parentType => bool)) private _coreContractCombinations;
60
40
 
61
41
  mapping(ObjectType objectType => mapping(
62
- ObjectType parentType => bool)) _isValidObjectCombination;
42
+ ObjectType parentType => bool)) private _coreObjectCombinations;
63
43
 
64
- mapping(NftId nftId => string name) _string;
65
- mapping(bytes32 serviceNameHash => mapping(
66
- VersionPart majorVersion => address service)) _service;
44
+ NftId private _registryNftId;
45
+ ChainNft private _chainNft;
67
46
 
68
- NftId _registryNftId;
69
- NftId _serviceNftId; // set in stone upon registry creation
70
- IChainNft _chainNft;
71
- ChainNft _chainNftInternal;
72
-
73
- /// @dev will own protocol, global registry, registry and registry service nfts minted during creation
74
- // TODO registry nft can be transfered while protocol, global registry and registry service nfts are not transferable
75
- // TODO get owner from one place -> nft contract
76
- address _protocolOwner;
77
-
78
- /*
79
- modifier onlyInitialOwner() {
80
- if(
81
- msg.sender != getOwner() ||
82
- msg.sender != _info[_registryNftId].initialOwner) {
83
- revert NotInitialOwner();
84
- }
85
- }*/
47
+ ReleaseManager private _releaseManager;
86
48
 
87
- modifier onlyOwner() {
88
- if(msg.sender != getOwner()) {
89
- revert NotOwner();
49
+ modifier onlyRegistryService() {
50
+ if(!_releaseManager.isActiveRegistryService(msg.sender)) {
51
+ revert CallerNotRegistryService();
90
52
  }
91
53
  _;
92
54
  }
93
55
 
94
- modifier onlyRegistryService() {
95
-
96
- if(msg.sender != _info[_serviceNftId].objectAddress) {
97
- revert NotRegistryService();
56
+ modifier onlyReleaseManager() {
57
+ if(msg.sender != address(_releaseManager)) {
58
+ revert CallerNotReleaseManager();
98
59
  }
99
60
  _;
100
61
  }
101
62
 
102
- constructor(address protocolOwner, VersionPart majorVersion)
63
+ constructor()
103
64
  {
104
- require(protocolOwner > address(0), "Registry: protocol owner is 0");
105
- require(majorVersion.toInt() == MAJOR_VERSION_MIN, "Registry: initial major version of registry service is not MAJOR_VERSION_MIN");
106
-
107
- // TODO registry owner can change, while protocol is not?
108
- _protocolOwner = protocolOwner;
65
+ _releaseManager = ReleaseManager(msg.sender);
109
66
 
110
67
  // deploy NFT
111
- _chainNftInternal = new ChainNft(address(this));// adds 10kb to deployment size
112
- _chainNft = IChainNft(_chainNftInternal);
68
+ _chainNft = new ChainNft(address(this));
113
69
 
114
70
  // initial registry setup
115
71
  _registerProtocol();
116
-
117
72
  _registerRegistry();
118
73
 
119
- _registerRegistryService();
74
+ // set object types and object parent relations
75
+ _setupValidCoreTypesAndCombinations();
76
+ }
120
77
 
121
- // set object parent relations
122
- _setupValidObjectParentCombinations();
78
+ function registerService(
79
+ ObjectInfo memory info,
80
+ VersionPart version,
81
+ ObjectType domain
82
+ )
83
+ external
84
+ onlyReleaseManager
85
+ returns(NftId nftId)
86
+ {
87
+ /* must be guaranteed by release manager
88
+ if(info.objectType != SERVICE()) {
89
+ revert();
90
+ }
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);
99
+ }
100
+
101
+ _service[version][domain] = info.objectAddress; // nftId;
102
+
103
+ nftId = _register(info);
123
104
 
124
- _registerInterface(type(IRegistry).interfaceId);
125
- _registerInterface(type(IOwnable).interfaceId);
105
+ emit LogServiceRegistration(version, domain);
126
106
  }
127
107
 
128
- /// @dev registry protects only from tampering existing records and invalid types pairs
129
- // IMPORTANT: rare case when parentNftId is not registered and == next nftId -> technincally this is ZeroParentAddress error
130
- // to catch this check parent address before minting !!!!
131
- // TODO service registration means its approval for some type?
132
108
  function register(ObjectInfo memory info)
133
109
  external
134
110
  onlyRegistryService
135
111
  returns(NftId nftId)
136
112
  {
137
113
  ObjectType objectType = info.objectType;
138
- NftId parentNftId = info.parentNftId;
139
- ObjectInfo memory parentInfo = _info[parentNftId];
140
- ObjectType parentType = parentInfo.objectType; // see function header
141
- address parentAddress = parentInfo.objectAddress;
114
+ ObjectType parentType = _info[info.parentNftId].objectType;
142
115
 
143
- // parent is contract -> need to check? -> check before minting
144
- // special case: global registry nft as parent when not on mainnet -> global registry address is 0
145
- // special case: when parentNftId == _chainNft.mint(), check for zero parent address before mint
146
- // special case: when parentNftId == _chainNft.mint() && objectAddress == initialOwner
147
- if(parentAddress == address(0)) {
148
- revert ZeroParentAddress();
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();
149
120
  }
150
121
 
151
- address interceptor = _getInterceptor(info.isInterceptor, info.objectAddress, parentInfo.isInterceptor, parentAddress);
152
-
153
- uint256 mintedTokenId = _chainNft.mint(
154
- info.initialOwner,
155
- interceptor,
156
- EMPTY_URI);
157
- nftId = toNftId(mintedTokenId);
158
-
159
- // TODO move nftId out of info struct
160
- // getters by nftId -> return struct without nftId
161
- // getters by address -> return nftId AND struct
162
- info.nftId = nftId;
163
- _info[nftId] = info;
164
-
165
- if(info.objectAddress > address(0))
122
+ // only valid core types combinations
123
+ if(info.objectAddress == address(0))
166
124
  {
167
- // TODO if need to add types latter -> at least call this check from registry service
168
- // parent is registered + object-parent types are valid
169
- if(_isValidContractCombination[objectType][parentType] == false) {
125
+ if(_coreObjectCombinations[objectType][parentType] == false) {
170
126
  revert InvalidTypesCombination(objectType, parentType);
171
127
  }
172
-
173
- address contractAddress = info.objectAddress;
174
-
175
- if(_nftIdByAddress[contractAddress].gtz()) {
176
- revert ContractAlreadyRegistered(contractAddress);
177
- }
178
-
179
- _nftIdByAddress[contractAddress] = nftId;
180
-
181
- // special case
182
- if(objectType == SERVICE())
183
- {
184
- (
185
- string memory serviceName,
186
- VersionPart majorVersion
187
- ) = abi.decode(info.data, (string, VersionPart));
188
- bytes32 serviceNameHash = keccak256(abi.encode(serviceName));
189
-
190
- // TODO MUST guarantee consistency of registerable.getVersion() and majorVersion here
191
- // TODO update _serviceNftId when registryService with new major version is registered? -> it is fixed in current setup
192
- // TODO do not use names -> each object type is registered by corresponding service -> conflicting with approve()
193
- if(
194
- majorVersion.toInt() < MAJOR_VERSION_MIN ||
195
- (majorVersion.toInt() > MAJOR_VERSION_MIN &&
196
- _service[serviceNameHash][VersionLib.toVersionPart(majorVersion.toInt() - 1)] == address(0) )
197
- ) {
198
- revert InvalidServiceVersion(majorVersion);
199
- }
200
-
201
- if(_service[serviceNameHash][majorVersion] != address(0)) {
202
- revert ServiceNameAlreadyRegistered(serviceName, majorVersion);
203
- }
204
-
205
- _string[nftId] = serviceName;
206
- _service[serviceNameHash][majorVersion] = contractAddress;
207
-
208
- emit LogServiceNameRegistration(serviceName, majorVersion);
209
- }
210
128
  }
211
129
  else
212
130
  {
213
- if(_isValidObjectCombination[objectType][parentType] == false) {
131
+ if(_coreContractCombinations[objectType][parentType] == false) {
214
132
  revert InvalidTypesCombination(objectType, parentType);
215
133
  }
216
134
  }
217
135
 
218
- emit LogRegistration(nftId, info.parentNftId, info.objectType, info.objectAddress, info.initialOwner);
136
+ nftId = _register(info);
219
137
  }
220
138
 
221
- function registerFrom(
222
- address from,
223
- ObjectInfo memory info
224
- ) external returns (NftId nftId)
225
- {
226
- revert();
227
- }
228
-
229
-
230
- /// @dev
231
- // msg.sender - registry owner
232
- // CAN approve only registered service contract
233
- // CAN approve any combination specified in _isValidCombination
234
- // CAN NOT approve itself
235
- // TODO in case where exists exactly one registered service per objectType (and major version):
236
- // - registration and approve is a single operation, no need for separate approve() function
237
- // - then approve can be used to adding new valid object-parent combinations???
238
- function approve(
239
- NftId serviceNftId,
240
- ObjectType objectType,
241
- ObjectType parentType
242
- )
243
- public
244
- onlyOwner()
139
+ function registerWithCustomType(ObjectInfo memory info)
140
+ external
141
+ onlyRegistryService
142
+ returns(NftId nftId)
245
143
  {
246
- address serviceAddress = _info[serviceNftId].objectAddress;
247
-
248
- if(_nftIdByAddress[serviceAddress].eqz()) {
249
- revert NotRegisteredContract(serviceNftId);
250
- }
144
+ ObjectType objectType = info.objectType;
145
+ ObjectType parentType = _info[info.parentNftId].objectType;
251
146
 
252
- if(_info[serviceNftId].objectType != SERVICE()) {
253
- revert NotService(serviceNftId);
147
+ if(_coreTypes[objectType]) {
148
+ revert CoreTypeRegistration();
254
149
  }
255
150
 
256
151
  if(
257
- _isValidContractCombination[objectType][parentType] == false &&
258
- _isValidObjectCombination[objectType][parentType] == false) {
152
+
153
+ parentType == PROTOCOL() ||
154
+ parentType == REGISTRY() ||
155
+ parentType == SERVICE()
156
+ ) {
259
157
  revert InvalidTypesCombination(objectType, parentType);
260
158
  }
261
159
 
262
- _isApproved[serviceNftId][objectType] = true;
160
+ _register(info);
161
+ }
263
162
 
264
- emit LogApproval(serviceNftId, objectType);
163
+
164
+ /// @dev earliest GIF major version
165
+ function getInitialVersion() external view returns (VersionPart) {
166
+ return _releaseManager.getInitialVersion();
265
167
  }
266
168
 
267
- /// @dev returns false for registry owner nft
268
- // TODO allowance by address?
269
- // TODO checked by registry service -> but registry owner can upgrade registry service not to check allowance....
270
- function allowance(
271
- NftId nftId,
272
- ObjectType object
273
- )
274
- public
275
- view
276
- returns (bool)
277
- {
278
- return _isApproved[nftId][object];
169
+ // TODO make distinction between active an not yet active version
170
+ // need to be thought trough, not yet clear if necessary
171
+ // need to answer question: what is the latest version during the upgrade process?
172
+ // likely setting up a new gif version does not fit into a single tx
173
+ // in this case we might want to have a period where the latest version is
174
+ // in the process of being set up while the latest active version is 1 major release smaller
175
+ /// @dev latest GIF major version (might not yet be active)
176
+ function getNextVersion() external view returns (VersionPart) {
177
+ return _releaseManager.getNextVersion();
279
178
  }
280
179
 
281
- // from IRegistry
282
- function getObjectCount() external view override returns (uint256) {
283
-
180
+ /// @dev latest active GIF release version
181
+ function getLatestVersion() external view returns (VersionPart) {
182
+ return _releaseManager.getLatestVersion();
183
+ }
184
+
185
+ function getReleaseInfo(VersionPart version) external view returns (ReleaseInfo memory) {
186
+ return _releaseManager.getReleaseInfo(version);
187
+ }
188
+
189
+ function getObjectCount() external view returns (uint256) {
284
190
  return _chainNft.totalSupply();
285
191
  }
286
192
 
287
- function getNftId(address object) external view override returns (NftId id) {
193
+ function getReleaseManagerAddress() external view returns (address) {
194
+ return address(_releaseManager);
195
+ }
196
+
197
+ function getNftId() external view returns (NftId nftId) {
198
+ return _registryNftId;
199
+ }
200
+
201
+ function getNftId(address object) external view returns (NftId id) {
288
202
  return _nftIdByAddress[object];
289
203
  }
290
204
 
291
- function ownerOf(NftId nftId) public view override returns (address) {
205
+ function ownerOf(NftId nftId) public view returns (address) {
292
206
  return _chainNft.ownerOf(nftId.toInt());
293
207
  }
294
208
 
295
209
  function ownerOf(address contractAddress) public view returns (address) {
296
-
297
210
  return _chainNft.ownerOf(_nftIdByAddress[contractAddress].toInt());
298
211
  }
299
212
 
300
- function getObjectInfo(NftId nftId) external view override returns (ObjectInfo memory) {
213
+ function getObjectInfo(NftId nftId) external view returns (ObjectInfo memory) {
301
214
  return _info[nftId];
302
215
  }
303
216
 
304
- function getObjectInfo(address object) external view override returns (ObjectInfo memory) {
305
-
217
+ function getObjectInfo(address object) external view returns (ObjectInfo memory) {
306
218
  return _info[_nftIdByAddress[object]];
307
219
  }
308
220
 
309
- function isRegistered(NftId nftId) public view override returns (bool) {
221
+ function isRegistered(NftId nftId) public view returns (bool) {
310
222
  return _info[nftId].objectType.gtz();
311
223
  }
312
224
 
313
- function isRegistered(address object) external view override returns (bool) {
225
+ function isRegistered(address object) external view returns (bool) {
314
226
  return _nftIdByAddress[object].gtz();
315
227
  }
316
228
 
317
- function getServiceName(NftId nftId) external view returns (string memory) {
318
- return _string[nftId];
229
+ function isRegisteredService(address object) external view returns (bool) {
230
+ return _info[_nftIdByAddress[object]].objectType == SERVICE();
319
231
  }
320
232
 
321
- // special case to retrive a gif service
322
- function getServiceAddress(
323
- string memory serviceName,
324
- VersionPart majorVersion
325
- ) external view returns (address)
233
+ function isRegisteredComponent(address object) external view returns (bool) {
234
+ NftId objectParentNftId = _info[_nftIdByAddress[object]].parentNftId;
235
+ return _info[objectParentNftId].objectType == INSTANCE();
236
+ }
237
+
238
+ function isValidRelease(VersionPart version) external view returns (bool)
326
239
  {
327
- bytes32 serviceNameHash = keccak256(abi.encode(serviceName));
328
- return _service[serviceNameHash][majorVersion];
240
+ return _releaseManager.isValidRelease(version);
329
241
  }
330
242
 
331
- function getProtocolOwner() external view override returns (address) {
332
- return _protocolOwner;
243
+ function getServiceAddress(
244
+ ObjectType serviceDomain,
245
+ VersionPart releaseVersion
246
+ ) external view returns (address service)
247
+ {
248
+ // TODO how can I get service address while release is not validated/activated ?!! -> user will check validity of release on its own
249
+ //if(_releaseManager.isValidRelease(releaseVersion)) {
250
+ service = _service[releaseVersion][serviceDomain];
251
+ //}
333
252
  }
334
253
 
335
- function getChainNft() external view override returns (IChainNft) {
336
- return _chainNft;
254
+ function getChainNftAddress() external view override returns (address) {
255
+ return address(_chainNft);
337
256
  }
338
257
 
339
- // from IOwnable
340
258
  function getOwner() public view returns (address owner) {
341
259
  return ownerOf(address(this));
342
260
  }
343
261
 
344
- // Internals, called only in constructor
345
-
346
- /// @dev protocol registration used to anchor the dip ecosystem relations
347
- function _registerProtocol()
348
- internal
349
- {
350
- uint256 protocolId = _chainNftInternal.PROTOCOL_NFT_ID();
351
- NftId protocolNftId = toNftId(protocolId);
352
-
353
- _chainNftInternal.mint(NFT_LOCK_ADDRESS, protocolId);
354
-
355
- _info[protocolNftId] = ObjectInfo(
356
- protocolNftId,
357
- zeroNftId(), // parent
358
- PROTOCOL(),
359
- false, // isInterceptor
360
- address(0), // objectAddress
361
- NFT_LOCK_ADDRESS,// initialOwner
362
- ""
363
- );
364
- }
262
+ // IERC165
365
263
 
366
- /// @dev registry registration
367
- /// might also register the global registry when not on mainnet
368
- function _registerRegistry()
369
- internal
370
- {
371
- uint256 registryId = _chainNftInternal.calculateTokenId(2);
372
- NftId registryNftId = toNftId(registryId);
373
-
374
- NftId parentNftId;
375
-
376
- if(registryId != _chainNftInternal.GLOBAL_REGISTRY_ID())
377
- {// we're not the global registry
378
- _registerGlobalRegistry();
379
- parentNftId = toNftId(_chainNftInternal.GLOBAL_REGISTRY_ID());
380
- }
381
- else
382
- {// we are global registry
383
- parentNftId = toNftId(_chainNftInternal.PROTOCOL_NFT_ID());
264
+ function supportsInterface(bytes4 interfaceId) external pure returns (bool) {
265
+ if(interfaceId == type(IERC165).interfaceId || interfaceId == type(IRegistry).interfaceId) {
266
+ return true;
384
267
  }
385
268
 
386
- _chainNftInternal.mint(_protocolOwner, registryId);
387
-
388
- _info[registryNftId] = ObjectInfo(
389
- registryNftId,
390
- parentNftId,
391
- REGISTRY(),
392
- false, // isInterceptor
393
- address(this),
394
- _protocolOwner,
395
- ""
396
- );
397
- _nftIdByAddress[address(this)] = registryNftId;
398
- _registryNftId = registryNftId;
269
+ return false;
399
270
  }
400
271
 
272
+ // Internals
401
273
 
402
- /// @dev global registry registration for non mainnet registries
403
- function _registerGlobalRegistry()
274
+ /// @dev registry protects only against tampering existing records, registering with invalid types pairs and 0 parent address
275
+ // TODO registration of precompile addresses
276
+ function _register(ObjectInfo memory info)
404
277
  internal
278
+ returns(NftId nftId)
405
279
  {
406
- uint256 globalRegistryId = _chainNftInternal.GLOBAL_REGISTRY_ID();
280
+ ObjectType objectType = info.objectType;
281
+ NftId parentNftId = info.parentNftId;
282
+ ObjectInfo memory parentInfo = _info[parentNftId];
283
+ ObjectType parentType = parentInfo.objectType; // see function header
284
+ address parentAddress = parentInfo.objectAddress;
407
285
 
408
- _chainNftInternal.mint(NFT_LOCK_ADDRESS, globalRegistryId);
286
+ // parent is contract -> need to check? -> check before minting
287
+ // special case: global registry nft as parent when not on mainnet -> global registry address is 0
288
+ // special case: when parentNftId == _chainNft.mint(), check for zero parent address before mint
289
+ // special case: when parentNftId == _chainNft.mint() && objectAddress == initialOwner
290
+ if(parentAddress == address(0)) {
291
+ revert ZeroParentAddress();
292
+ }
409
293
 
410
- NftId globalRegistryNftId = toNftId(globalRegistryId);
294
+ address interceptor = _getInterceptor(info.isInterceptor, info.objectAddress, parentInfo.isInterceptor, parentAddress);
411
295
 
412
- _info[globalRegistryNftId] = ObjectInfo(
413
- globalRegistryNftId,
414
- toNftId(_chainNftInternal.PROTOCOL_NFT_ID()), // parent
415
- REGISTRY(),
416
- false, // isInterceptor
417
- address(0), // objectAddress
418
- NFT_LOCK_ADDRESS, // initialOwner
419
- "" // data
420
- );
421
- }
296
+ // TODO does external call
297
+ // compute next nftId, do all checks and stores, mint() at most end...
298
+ uint256 mintedTokenId = _chainNft.mint(
299
+ info.initialOwner,
300
+ interceptor,
301
+ EMPTY_URI);
302
+ nftId = toNftId(mintedTokenId);
422
303
 
423
- function _registerRegistryService()
424
- internal
425
- {
426
- uint256 serviceId = _chainNftInternal.calculateTokenId(3);
427
- NftId serviceNftId = toNftId(serviceId);
304
+ // TODO move nftId out of info struct
305
+ // getters by nftId -> return struct without nftId
306
+ // getters by address -> return nftId AND struct
307
+ info.nftId = nftId;
308
+ _info[nftId] = info;
428
309
 
429
- _chainNftInternal.mint(NFT_LOCK_ADDRESS, serviceId);
310
+ if(info.objectAddress > address(0))
311
+ {
312
+ address contractAddress = info.objectAddress;
430
313
 
431
- _info[serviceNftId] = ObjectInfo(
432
- serviceNftId,
433
- _registryNftId,
434
- SERVICE(),
435
- false, // isInterceptor
436
- msg.sender, // service deploys registry
437
- NFT_LOCK_ADDRESS, // initialOwner,
438
- ""
439
- );
314
+ if(_nftIdByAddress[contractAddress].gtz()) {
315
+ revert ContractAlreadyRegistered(contractAddress);
316
+ }
440
317
 
441
- _nftIdByAddress[msg.sender] = serviceNftId;
318
+ _nftIdByAddress[contractAddress] = nftId;
319
+ }
442
320
 
443
- string memory serviceName = "RegistryService";
444
- bytes32 serviceNameHash = keccak256(abi.encode(serviceName));
445
- _service[serviceNameHash][VersionLib.toVersionPart(MAJOR_VERSION_MIN)] = msg.sender;
446
- _string[serviceNftId] = serviceName;
447
- _serviceNftId = serviceNftId;
321
+ emit LogRegistration(nftId, parentNftId, objectType, info.isInterceptor, info.objectAddress, info.initialOwner);
448
322
  }
449
323
 
450
324
  /// @dev obtain interceptor address for this nft if applicable, address(0) otherwise
@@ -473,33 +347,123 @@ contract Registry is
473
347
  return address(0);
474
348
  }
475
349
 
350
+ // Internals called only in constructor
351
+
352
+ /// @dev protocol registration used to anchor the dip ecosystem relations
353
+ function _registerProtocol()
354
+ private
355
+ {
356
+ uint256 protocolId = _chainNft.PROTOCOL_NFT_ID();
357
+ NftId protocolNftId = toNftId(protocolId);
358
+
359
+ _info[protocolNftId] = ObjectInfo({
360
+ nftId: protocolNftId,
361
+ parentNftId: zeroNftId(),
362
+ objectType: PROTOCOL(),
363
+ isInterceptor: false,
364
+ objectAddress: address(0),
365
+ initialOwner: NFT_LOCK_ADDRESS,
366
+ data: ""
367
+ });
368
+
369
+ _chainNft.mint(NFT_LOCK_ADDRESS, protocolId);
370
+ }
371
+
372
+ /// @dev registry registration
373
+ /// might also register the global registry when not on mainnet
374
+ function _registerRegistry()
375
+ private
376
+ {
377
+ uint256 registryId = _chainNft.calculateTokenId(REGISTRY_TOKEN_SEQUENCE_ID);
378
+ NftId registryNftId = toNftId(registryId);
379
+ NftId parentNftId;
380
+
381
+ if(registryId != _chainNft.GLOBAL_REGISTRY_ID())
382
+ {// we're not the global registry
383
+ _registerGlobalRegistry();
384
+ parentNftId = toNftId(_chainNft.GLOBAL_REGISTRY_ID());
385
+ }
386
+ else
387
+ {// we are global registry
388
+ parentNftId = toNftId(_chainNft.PROTOCOL_NFT_ID());
389
+ }
390
+
391
+ _info[registryNftId] = ObjectInfo({
392
+ nftId: registryNftId,
393
+ parentNftId: parentNftId,
394
+ objectType: REGISTRY(),
395
+ isInterceptor: false,
396
+ objectAddress: address(this),
397
+ initialOwner: NFT_LOCK_ADDRESS,
398
+ data: ""
399
+ });
400
+ _nftIdByAddress[address(this)] = registryNftId;
401
+ _registryNftId = registryNftId;
402
+
403
+ _chainNft.mint(NFT_LOCK_ADDRESS, registryId);
404
+ }
405
+
406
+ /// @dev global registry registration for non mainnet registries
407
+ function _registerGlobalRegistry()
408
+ private
409
+ {
410
+ uint256 globalRegistryId = _chainNft.GLOBAL_REGISTRY_ID();
411
+ NftId globalRegistryNftId = toNftId(globalRegistryId);
412
+
413
+ _info[globalRegistryNftId] = ObjectInfo({
414
+ nftId: globalRegistryNftId,
415
+ parentNftId: toNftId(_chainNft.PROTOCOL_NFT_ID()),
416
+ objectType: REGISTRY(),
417
+ isInterceptor: false,
418
+ objectAddress: address(0),
419
+ initialOwner: NFT_LOCK_ADDRESS,
420
+ data: ""
421
+ });
422
+
423
+ _chainNft.mint(NFT_LOCK_ADDRESS, globalRegistryId);
424
+ }
425
+
476
426
  /// @dev defines which object - parent types relations are allowed to register
477
427
  // IMPORTANT:
478
428
  // 1) EACH object type MUST have only one parent type across ALL mappings
479
429
  // 2) DO NOT use object type (e.g. POLCY, BUNDLE, STAKE) as parent type
480
430
  // 3) DO NOT use REGISTRY as object type
481
431
  // 2) DO NOT use PROTOCOL and "zeroObjectType"
482
- function _setupValidObjectParentCombinations()
483
- internal
432
+ function _setupValidCoreTypesAndCombinations()
433
+ private
484
434
  {
435
+ _coreTypes[REGISTRY()] = true;
436
+ _coreTypes[SERVICE()] = true;
437
+ _coreTypes[TOKEN()] = true;
438
+ _coreTypes[INSTANCE()] = true;
439
+ _coreTypes[PRODUCT()] = true;
440
+ _coreTypes[POOL()] = true;
441
+ _coreTypes[DISTRIBUTION()] = true;
442
+ _coreTypes[POLICY()] = true;
443
+ _coreTypes[BUNDLE()] = true;
444
+ _coreTypes[STAKE()] = true;
445
+
485
446
  // registry as parent, ONLY registry owner
486
- _isValidContractCombination[TOKEN()][REGISTRY()] = true;
487
- _isValidContractCombination[SERVICE()][REGISTRY()] = true;
447
+ //_coreContractCombinations[REGISTRY()][REGISTRY()] = true; // only for global regstry
448
+ _coreContractCombinations[TOKEN()][REGISTRY()] = true;
449
+ //_coreContractCombinations[SERVICE()][REGISTRY()] = true;// do not need it here -> registerService() registers exactly this combination
488
450
 
489
451
  // registry as parent, ONLY approved
490
- _isValidContractCombination[INSTANCE()][REGISTRY()] = true;
452
+ _coreContractCombinations[INSTANCE()][REGISTRY()] = true;
491
453
 
492
454
  // instance as parent, ONLY approved
493
- _isValidContractCombination[PRODUCT()][INSTANCE()] = true;
494
- _isValidContractCombination[DISTRIBUTION()][INSTANCE()] = true;
495
- _isValidContractCombination[ORACLE()][INSTANCE()] = true;
496
- _isValidContractCombination[POOL()][INSTANCE()] = true;
455
+ _coreContractCombinations[PRODUCT()][INSTANCE()] = true;
456
+ _coreContractCombinations[DISTRIBUTION()][INSTANCE()] = true;
457
+ _coreContractCombinations[ORACLE()][INSTANCE()] = true;
458
+ _coreContractCombinations[POOL()][INSTANCE()] = true;
459
+
460
+ _coreObjectCombinations[DISTRIBUTOR()][DISTRIBUTION()] = true;
497
461
 
498
462
  // product as parent, ONLY approved
499
- _isValidObjectCombination[POLICY()][PRODUCT()] = true;
463
+ _coreObjectCombinations[POLICY()][PRODUCT()] = true;
500
464
 
501
465
  // pool as parent, ONLY approved
502
- _isValidObjectCombination[BUNDLE()][POOL()] = true;
503
- _isValidObjectCombination[STAKE()][POOL()] = true;
466
+ _coreObjectCombinations[BUNDLE()][POOL()] = true;
467
+ _coreObjectCombinations[STAKE()][POOL()] = true;
504
468
  }
505
469
  }