@etherisc/gif-next 0.0.2-84e1050-545 → 0.0.2-86e23a6-752

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 (286) hide show
  1. package/README.md +73 -1
  2. package/artifacts/contracts/components/Component.sol/Component.dbg.json +4 -0
  3. package/artifacts/contracts/components/Component.sol/Component.json +897 -0
  4. package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +1 -1
  5. package/artifacts/contracts/components/Distribution.sol/Distribution.json +896 -235
  6. package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +4 -0
  7. package/artifacts/contracts/components/{BaseComponent.sol/BaseComponent.json → IComponent.sol/IComponent.json} +137 -86
  8. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
  9. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +798 -0
  10. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
  11. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +662 -43
  12. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +1 -1
  13. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +661 -5
  14. package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
  15. package/artifacts/contracts/components/Pool.sol/Pool.json +603 -204
  16. package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
  17. package/artifacts/contracts/components/Product.sol/Product.json +529 -122
  18. package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.dbg.json +1 -1
  19. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.dbg.json +1 -1
  20. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.dbg.json +1 -1
  21. package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +1 -1
  22. package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +1 -1
  23. package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +1 -1
  24. package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +1 -1
  25. package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +1 -1
  26. package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +1 -1
  27. package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +1 -1
  28. package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +1 -1
  29. package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +1 -1
  30. package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +1 -1
  31. package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.dbg.json +1 -1
  32. package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +2 -2
  33. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +1 -1
  34. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +1 -1
  35. package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +1 -1
  36. package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +1 -1
  37. package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +1 -1
  38. package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +1 -1
  39. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
  40. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +38 -62
  41. package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +1 -1
  42. package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
  43. package/artifacts/contracts/instance/IInstance.sol/IInstance.json +712 -49
  44. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
  45. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +146 -59
  46. package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
  47. package/artifacts/contracts/instance/Instance.sol/Instance.json +560 -272
  48. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +1 -1
  49. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +103 -184
  50. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
  51. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +61 -97
  52. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
  53. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +412 -245
  54. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
  55. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +175 -101
  56. package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +1 -1
  57. package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +8 -32
  58. package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.dbg.json +4 -0
  59. package/artifacts/contracts/{shared/RegisterableUpgradable.sol/RegisterableUpgradable.json → instance/base/ComponentService.sol/ComponentService.json} +321 -9
  60. package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
  61. package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +1 -1
  62. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
  63. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +2 -2
  64. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +1 -1
  65. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +2 -2
  66. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
  67. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +24 -13
  68. package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
  69. package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
  70. package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
  71. package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
  72. package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +1 -1
  73. package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +1 -1
  74. package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.dbg.json +4 -0
  75. package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.json +1117 -0
  76. package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +1 -1
  77. package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +495 -100
  78. package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
  79. package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +172 -26
  80. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +1 -1
  81. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +578 -62
  82. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
  83. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +208 -22
  84. package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.dbg.json +4 -0
  85. package/artifacts/contracts/instance/{base/ComponentServiceBase.sol/ComponentServiceBase.json → service/IApplicationService.sol/IApplicationService.json} +221 -104
  86. package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +1 -1
  87. package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.json +181 -52
  88. package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +1 -1
  89. package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.json +229 -19
  90. package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +1 -1
  91. package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.json +152 -32
  92. package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +1 -1
  93. package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +32 -19
  94. package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +1 -1
  95. package/artifacts/contracts/instance/service/IProductService.sol/IProductService.json +32 -19
  96. package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +1 -1
  97. package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +481 -87
  98. package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
  99. package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +203 -25
  100. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +1 -1
  101. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +301 -62
  102. package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
  103. package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +169 -23
  104. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +1 -1
  105. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +301 -62
  106. package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +1 -1
  107. package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +169 -15
  108. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
  109. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +2 -2
  110. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
  111. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +225 -133
  112. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
  113. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +185 -77
  114. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
  115. package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
  116. package/artifacts/contracts/registry/Registry.sol/Registry.json +238 -235
  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 +243 -129
  121. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
  122. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +181 -97
  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 +1 -1
  126. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +150 -29
  127. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +1 -1
  128. package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
  129. package/artifacts/contracts/shared/ERC165.sol/ERC165.json +41 -3
  130. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
  131. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +37 -0
  132. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +4 -0
  133. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +129 -0
  134. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
  135. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +18 -5
  136. package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +4 -0
  137. package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.json +69 -0
  138. package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
  139. package/artifacts/contracts/shared/IService.sol/IService.json +32 -19
  140. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
  141. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +2 -2
  142. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
  143. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +156 -11
  144. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +4 -0
  145. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +269 -0
  146. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
  147. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +156 -6
  148. package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
  149. package/artifacts/contracts/shared/Registerable.sol/Registerable.json +152 -11
  150. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +4 -0
  151. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +105 -0
  152. package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
  153. package/artifacts/contracts/shared/Service.sol/Service.json +178 -19
  154. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
  155. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
  156. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +2 -2
  157. package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
  158. package/artifacts/contracts/shared/Versionable.sol/Versionable.json +2 -2
  159. package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +1 -1
  160. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +1 -1
  161. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +152 -11
  162. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +1 -1
  163. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +2 -2
  164. package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +1 -1
  165. package/artifacts/contracts/test/TestService.sol/TestService.json +196 -37
  166. package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +1 -1
  167. package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +1 -1
  168. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +1 -1
  169. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +8 -8
  170. package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +1 -1
  171. package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +1 -1
  172. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
  173. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +1 -1
  174. package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
  175. package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.json +2 -2
  176. package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +1 -1
  177. package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +1 -1
  178. package/artifacts/contracts/types/Key32.sol/Key32Lib.json +2 -2
  179. package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
  180. package/artifacts/contracts/types/NftId.sol/NftIdLib.json +2 -2
  181. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
  182. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.json +2 -2
  183. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +1 -1
  184. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
  185. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +2 -2
  186. package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +1 -1
  187. package/artifacts/contracts/types/Referral.sol/ReferralLib.json +2 -2
  188. package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +1 -1
  189. package/artifacts/contracts/types/RiskId.sol/RiskIdLib.json +2 -2
  190. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +1 -1
  191. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +2 -2
  192. package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +1 -1
  193. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +1 -1
  194. package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +1 -1
  195. package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +1 -1
  196. package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +1 -1
  197. package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +1 -1
  198. package/contracts/components/Component.sol +236 -0
  199. package/contracts/components/Distribution.sol +209 -64
  200. package/contracts/components/IComponent.sol +50 -0
  201. package/contracts/components/IDistributionComponent.sol +59 -3
  202. package/contracts/components/IPoolComponent.sol +50 -29
  203. package/contracts/components/IProductComponent.sol +7 -3
  204. package/contracts/components/Pool.sol +135 -152
  205. package/contracts/components/Product.sol +103 -117
  206. package/contracts/instance/BundleManager.sol +7 -11
  207. package/contracts/instance/IInstance.sol +35 -9
  208. package/contracts/instance/IInstanceService.sol +23 -6
  209. package/contracts/instance/Instance.sol +67 -62
  210. package/contracts/instance/InstanceAccessManager.sol +31 -39
  211. package/contracts/instance/InstanceReader.sol +3 -25
  212. package/contracts/instance/InstanceService.sol +210 -79
  213. package/contracts/instance/InstanceServiceManager.sol +5 -8
  214. package/contracts/instance/ObjectManager.sol +7 -24
  215. package/contracts/instance/base/ComponentService.sol +134 -0
  216. package/contracts/instance/module/IAccess.sol +4 -5
  217. package/contracts/instance/module/ISetup.sol +5 -4
  218. package/contracts/instance/service/ApplicationService.sol +268 -0
  219. package/contracts/instance/service/BundleService.sol +52 -14
  220. package/contracts/instance/service/BundleServiceManager.sol +5 -8
  221. package/contracts/instance/service/DistributionService.sol +222 -49
  222. package/contracts/instance/service/DistributionServiceManager.sol +6 -9
  223. package/contracts/instance/service/IApplicationService.sol +82 -0
  224. package/contracts/instance/service/IBundleService.sol +12 -3
  225. package/contracts/instance/service/IDistributionService.sol +53 -0
  226. package/contracts/instance/service/IPolicyService.sol +17 -16
  227. package/contracts/instance/service/PolicyService.sol +148 -132
  228. package/contracts/instance/service/PoolService.sol +27 -42
  229. package/contracts/instance/service/PoolServiceManager.sol +5 -8
  230. package/contracts/instance/service/ProductService.sol +100 -40
  231. package/contracts/registry/ChainNft.sol +1 -1
  232. package/contracts/registry/IRegistry.sol +37 -19
  233. package/contracts/registry/IRegistryService.sol +30 -13
  234. package/contracts/registry/Registry.sol +233 -217
  235. package/contracts/registry/RegistryAccessManager.sol +216 -0
  236. package/contracts/registry/RegistryService.sol +81 -162
  237. package/contracts/registry/RegistryServiceManager.sol +18 -36
  238. package/contracts/registry/ReleaseManager.sol +331 -0
  239. package/contracts/registry/TokenRegistry.sol +11 -9
  240. package/contracts/shared/ERC165.sol +12 -11
  241. package/contracts/shared/INftOwnable.sol +12 -6
  242. package/contracts/shared/IPolicyHolder.sol +26 -0
  243. package/contracts/shared/IRegisterable.sol +4 -6
  244. package/contracts/shared/IRegistryLinked.sol +15 -0
  245. package/contracts/shared/IService.sol +2 -1
  246. package/contracts/shared/IVersionable.sol +2 -2
  247. package/contracts/shared/NftOwnable.sol +113 -57
  248. package/contracts/shared/PolicyHolder.sol +81 -0
  249. package/contracts/shared/ProxyManager.sol +6 -5
  250. package/contracts/shared/Registerable.sol +15 -24
  251. package/contracts/shared/RegistryLinked.sol +64 -0
  252. package/contracts/shared/Service.sol +18 -13
  253. package/contracts/shared/Versionable.sol +3 -2
  254. package/contracts/test/TestRegisterable.sol +1 -1
  255. package/contracts/test/TestService.sol +4 -3
  256. package/contracts/types/DistributorType.sol +2 -2
  257. package/contracts/types/ObjectType.sol +6 -2
  258. package/contracts/types/RoleId.sol +4 -7
  259. package/package.json +3 -3
  260. package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +0 -4
  261. package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +0 -4
  262. package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.json +0 -384
  263. package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +0 -4
  264. package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +0 -1206
  265. package/artifacts/contracts/instance/IInstanceBase.sol/IInstanceBase.dbg.json +0 -4
  266. package/artifacts/contracts/instance/IInstanceBase.sol/IInstanceBase.json +0 -448
  267. package/artifacts/contracts/instance/InstanceBase.sol/InstanceBase.dbg.json +0 -4
  268. package/artifacts/contracts/instance/InstanceBase.sol/InstanceBase.json +0 -763
  269. package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +0 -4
  270. package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +0 -4
  271. package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.json +0 -113
  272. package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +0 -4
  273. package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +0 -827
  274. package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +0 -4
  275. package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.json +0 -466
  276. package/artifacts/contracts/shared/RegisterableUpgradable.sol/RegisterableUpgradable.dbg.json +0 -4
  277. package/contracts/components/BaseComponent.sol +0 -145
  278. package/contracts/components/IBaseComponent.sol +0 -32
  279. package/contracts/instance/AccessManagerUpgradeableInitializeable.sol +0 -23
  280. package/contracts/instance/IInstanceBase.sol +0 -26
  281. package/contracts/instance/InstanceBase.sol +0 -41
  282. package/contracts/instance/base/ComponentServiceBase.sol +0 -72
  283. package/contracts/instance/base/IInstanceBase.sol +0 -23
  284. package/contracts/instance/service/ComponentOwnerService.sol +0 -317
  285. package/contracts/instance/service/IComponentOwnerService.sol +0 -20
  286. package/contracts/shared/RegisterableUpgradable.sol +0 -16
@@ -4,19 +4,23 @@ pragma solidity ^0.8.20;
4
4
  import {Clones} from "@openzeppelin/contracts/proxy/Clones.sol";
5
5
 
6
6
  import {Instance} from "./Instance.sol";
7
+ import {IInstance} from "./IInstance.sol";
7
8
  import {InstanceAccessManager} from "./InstanceAccessManager.sol";
8
9
  import {IInstanceService} from "./IInstanceService.sol";
9
10
  import {InstanceReader} from "./InstanceReader.sol";
10
11
  import {BundleManager} from "./BundleManager.sol";
11
12
  import {IRegistry} from "../registry/IRegistry.sol";
12
- import {RegistryService} from "../registry/RegistryService.sol";
13
+ import {IRegistryService} from "../registry/IRegistryService.sol";
13
14
  import {ChainNft} from "../registry/ChainNft.sol";
14
15
  import {Service} from "../../contracts/shared/Service.sol";
15
16
  import {IService} from "../shared/IService.sol";
16
17
  import {NftId} from "../../contracts/types/NftId.sol";
17
18
  import {RoleId} from "../types/RoleId.sol";
18
- import {VersionLib} from "../types/Version.sol";
19
- import {ADMIN_ROLE, INSTANCE_OWNER_ROLE, INSTANCE_SERVICE_ROLE, DISTRIBUTION_SERVICE_ROLE, POOL_SERVICE_ROLE, PRODUCT_SERVICE_ROLE, POLICY_SERVICE_ROLE, BUNDLE_SERVICE_ROLE} from "../types/RoleId.sol";
19
+ import {ADMIN_ROLE, DISTRIBUTION_OWNER_ROLE, POOL_OWNER_ROLE, PRODUCT_OWNER_ROLE, INSTANCE_SERVICE_ROLE, DISTRIBUTION_SERVICE_ROLE, POOL_SERVICE_ROLE, PRODUCT_SERVICE_ROLE, POLICY_SERVICE_ROLE, BUNDLE_SERVICE_ROLE} from "../types/RoleId.sol";
20
+ import {ObjectType, INSTANCE, BUNDLE, POLICY, PRODUCT, DISTRIBUTION, REGISTRY, POOL} from "../types/ObjectType.sol";
21
+ import {IDistributionComponent} from "../components/IDistributionComponent.sol";
22
+ import {IPoolComponent} from "../components/IPoolComponent.sol";
23
+ import {IProductComponent} from "../components/IProductComponent.sol";
20
24
 
21
25
  contract InstanceService is Service, IInstanceService {
22
26
 
@@ -27,11 +31,10 @@ contract InstanceService is Service, IInstanceService {
27
31
 
28
32
  // TODO update to real hash when instance is stable
29
33
  bytes32 public constant INSTANCE_CREATION_CODE_HASH = bytes32(0);
30
- string public constant NAME = "InstanceService";
31
34
 
32
35
  modifier onlyInstanceOwner(NftId instanceNftId) {
33
36
  IRegistry registry = getRegistry();
34
- ChainNft chainNft = registry.getChainNft();
37
+ ChainNft chainNft = ChainNft(registry.getChainNftAddress());
35
38
 
36
39
  if( msg.sender != chainNft.ownerOf(instanceNftId.toInt())) {
37
40
  revert ErrorInstanceServiceNotInstanceOwner(msg.sender, instanceNftId);
@@ -39,6 +42,14 @@ contract InstanceService is Service, IInstanceService {
39
42
  _;
40
43
  }
41
44
 
45
+ modifier onlyRegisteredService() {
46
+ address caller = msg.sender;
47
+ if (! getRegistry().isRegisteredService(caller)) {
48
+ revert ErrorInstanceServiceRequestUnauhorized(caller);
49
+ }
50
+ _;
51
+ }
52
+
42
53
  function createInstanceClone()
43
54
  external
44
55
  returns (
@@ -53,26 +64,24 @@ contract InstanceService is Service, IInstanceService {
53
64
  IRegistry registry = getRegistry();
54
65
  address registryAddress = address(registry);
55
66
  NftId registryNftId = registry.getNftId(registryAddress);
56
- address registryServiceAddress = registry.getServiceAddress("RegistryService", VersionLib.toVersion(3, 0, 0).toMajorPart());
57
- RegistryService registryService = RegistryService(registryServiceAddress);
67
+ address registryServiceAddress = registry.getServiceAddress(REGISTRY(), getMajorVersion());
68
+ IRegistryService registryService = IRegistryService(registryServiceAddress);
58
69
 
59
70
  // initially set the authority of the access managar to this (being the instance service).
60
71
  // This will allow the instance service to bootstrap the authorizations of the instance
61
72
  // and then transfer the ownership of the access manager to the instance owner once everything is setup
62
73
  clonedAccessManager = InstanceAccessManager(Clones.clone(_masterInstanceAccessManager));
63
- clonedAccessManager.__InstanceAccessManager_initialize(address(this));
74
+ clonedAccessManager.initialize(address(this));
64
75
 
65
76
  clonedInstance = Instance(Clones.clone(_masterInstance));
66
77
  clonedInstance.initialize(address(clonedAccessManager), registryAddress, registryNftId, msg.sender);
67
- ( IRegistry.ObjectInfo memory info, ) = registryService.registerInstance(clonedInstance);
68
- clonedInstanceNftId = info.nftId;
69
78
 
70
79
  clonedInstanceReader = InstanceReader(Clones.clone(address(_masterInstanceReader)));
71
- clonedInstanceReader.initialize(registryAddress, clonedInstanceNftId);
80
+ clonedInstanceReader.initialize(registryAddress, address(clonedInstance));
72
81
  clonedInstance.setInstanceReader(clonedInstanceReader);
73
82
 
74
83
  clonedBundleManager = BundleManager(Clones.clone(_masterInstanceBundleManager));
75
- clonedBundleManager.initialize(address(clonedAccessManager), registryAddress, clonedInstanceNftId);
84
+ clonedBundleManager.initialize(address(clonedAccessManager), registryAddress, address(clonedInstance));
76
85
  clonedInstance.setBundleManager(clonedBundleManager);
77
86
 
78
87
  // TODO amend setters with instance specific , policy manager ...
@@ -81,14 +90,19 @@ contract InstanceService is Service, IInstanceService {
81
90
 
82
91
  // to complete setup switch instance ownership to the instance owner
83
92
  // TODO: use a role less powerful than admin, maybe INSTANCE_ADMIN (does not exist yet)
84
- clonedAccessManager.grantRole(INSTANCE_OWNER_ROLE(), instanceOwner);
85
93
  clonedAccessManager.grantRole(ADMIN_ROLE(), instanceOwner);
86
94
  clonedAccessManager.revokeRole(ADMIN_ROLE(), address(this));
87
95
 
96
+ IRegistry.ObjectInfo memory info = registryService.registerInstance(clonedInstance, instanceOwner);
97
+ clonedInstanceNftId = info.nftId;
98
+ // clonedInstance.linkToRegisteredNftId();
99
+
88
100
  emit LogInstanceCloned(address(clonedAccessManager), address(clonedInstance), address(clonedInstanceReader), clonedInstanceNftId);
89
101
  }
90
102
 
91
103
  function _grantInitialAuthorizations(InstanceAccessManager clonedAccessManager, Instance clonedInstance, BundleManager clonedBundleManager) internal {
104
+ _createGifRoles(clonedAccessManager);
105
+ _createGifTargets(clonedAccessManager, clonedInstance, clonedBundleManager);
92
106
  _grantDistributionServiceAuthorizations(clonedAccessManager, clonedInstance);
93
107
  _grantPoolServiceAuthorizations(clonedAccessManager, clonedInstance);
94
108
  _grantProductServiceAuthorizations(clonedAccessManager, clonedInstance);
@@ -97,36 +111,64 @@ contract InstanceService is Service, IInstanceService {
97
111
  _grantInstanceServiceAuthorizations(clonedAccessManager, clonedInstance);
98
112
  }
99
113
 
114
+ function _createGifRoles(InstanceAccessManager clonedAccessManager) internal {
115
+ clonedAccessManager.createGifRole(DISTRIBUTION_OWNER_ROLE(), "DistributionOwnerRole");
116
+ clonedAccessManager.createGifRole(POOL_OWNER_ROLE(), "PoolOwnerRole");
117
+ clonedAccessManager.createGifRole(PRODUCT_OWNER_ROLE(), "ProductOwnerRole");
118
+
119
+ clonedAccessManager.createGifRole(DISTRIBUTION_SERVICE_ROLE(), "DistributionServiceRole");
120
+ clonedAccessManager.createGifRole(POOL_SERVICE_ROLE(), "PoolServiceRole");
121
+ clonedAccessManager.createGifRole(PRODUCT_SERVICE_ROLE(), "ProductServiceRole");
122
+ clonedAccessManager.createGifRole(POLICY_SERVICE_ROLE(), "PolicyServiceRole");
123
+ clonedAccessManager.createGifRole(BUNDLE_SERVICE_ROLE(), "BundleServiceRole");
124
+ clonedAccessManager.createGifRole(INSTANCE_SERVICE_ROLE(), "InstanceServiceRole");
125
+ }
126
+
127
+ function _createGifTargets(InstanceAccessManager clonedAccessManager, Instance clonedInstance, BundleManager clonedBundleManager) internal {
128
+ clonedAccessManager.createGifTarget(address(clonedAccessManager), "InstanceAccessManager");
129
+ clonedAccessManager.createGifTarget(address(clonedInstance), "Instance");
130
+ clonedAccessManager.createGifTarget(address(clonedBundleManager), "BundleManager");
131
+ }
132
+
100
133
  function _grantDistributionServiceAuthorizations(InstanceAccessManager clonedAccessManager, Instance clonedInstance) internal {
101
134
  // configure authorization for distribution service on instance
102
135
  IRegistry registry = getRegistry();
103
- address distributionServiceAddress = _registry.getServiceAddress("DistributionService", VersionLib.toVersion(3, 0, 0).toMajorPart());
104
- clonedAccessManager.grantRole(DISTRIBUTION_SERVICE_ROLE(), address(distributionServiceAddress));
105
- bytes4[] memory instanceDistributionServiceSelectors = new bytes4[](2);
136
+ address distributionServiceAddress = registry.getServiceAddress(DISTRIBUTION(), getMajorVersion());
137
+ clonedAccessManager.grantRole(DISTRIBUTION_SERVICE_ROLE(), distributionServiceAddress);
138
+ bytes4[] memory instanceDistributionServiceSelectors = new bytes4[](11);
106
139
  instanceDistributionServiceSelectors[0] = clonedInstance.createDistributionSetup.selector;
107
140
  instanceDistributionServiceSelectors[1] = clonedInstance.updateDistributionSetup.selector;
141
+ instanceDistributionServiceSelectors[2] = clonedInstance.createDistributorType.selector;
142
+ instanceDistributionServiceSelectors[3] = clonedInstance.updateDistributorType.selector;
143
+ instanceDistributionServiceSelectors[4] = clonedInstance.updateDistributorTypeState.selector;
144
+ instanceDistributionServiceSelectors[5] = clonedInstance.createDistributor.selector;
145
+ instanceDistributionServiceSelectors[6] = clonedInstance.updateDistributor.selector;
146
+ instanceDistributionServiceSelectors[7] = clonedInstance.updateDistributorState.selector;
147
+ instanceDistributionServiceSelectors[8] = clonedInstance.createReferral.selector;
148
+ instanceDistributionServiceSelectors[9] = clonedInstance.updateReferral.selector;
149
+ instanceDistributionServiceSelectors[10] = clonedInstance.updateReferralState.selector;
108
150
  clonedAccessManager.setTargetFunctionRole(
109
- address(clonedInstance),
151
+ "Instance",
110
152
  instanceDistributionServiceSelectors,
111
- DISTRIBUTION_SERVICE_ROLE().toInt());
153
+ DISTRIBUTION_SERVICE_ROLE());
112
154
  }
113
155
 
114
156
  function _grantPoolServiceAuthorizations(InstanceAccessManager clonedAccessManager, Instance clonedInstance) internal {
115
157
  // configure authorization for pool service on instance
116
- address poolServiceAddress = _registry.getServiceAddress("PoolService", VersionLib.toVersion(3, 0, 0).toMajorPart());
158
+ address poolServiceAddress = getRegistry().getServiceAddress(POOL(), getMajorVersion());
117
159
  clonedAccessManager.grantRole(POOL_SERVICE_ROLE(), address(poolServiceAddress));
118
160
  bytes4[] memory instancePoolServiceSelectors = new bytes4[](4);
119
161
  instancePoolServiceSelectors[0] = clonedInstance.createPoolSetup.selector;
120
162
  instancePoolServiceSelectors[1] = clonedInstance.updatePoolSetup.selector;
121
163
  clonedAccessManager.setTargetFunctionRole(
122
- address(clonedInstance),
164
+ "Instance",
123
165
  instancePoolServiceSelectors,
124
- POOL_SERVICE_ROLE().toInt());
166
+ POOL_SERVICE_ROLE());
125
167
  }
126
168
 
127
169
  function _grantProductServiceAuthorizations(InstanceAccessManager clonedAccessManager, Instance clonedInstance) internal {
128
170
  // configure authorization for product service on instance
129
- address productServiceAddress = _registry.getServiceAddress("ProductService", VersionLib.toVersion(3, 0, 0).toMajorPart());
171
+ address productServiceAddress = getRegistry().getServiceAddress(PRODUCT(), getMajorVersion());
130
172
  clonedAccessManager.grantRole(PRODUCT_SERVICE_ROLE(), address(productServiceAddress));
131
173
  bytes4[] memory instanceProductServiceSelectors = new bytes4[](5);
132
174
  instanceProductServiceSelectors[0] = clonedInstance.createProductSetup.selector;
@@ -135,36 +177,36 @@ contract InstanceService is Service, IInstanceService {
135
177
  instanceProductServiceSelectors[3] = clonedInstance.updateRisk.selector;
136
178
  instanceProductServiceSelectors[4] = clonedInstance.updateRiskState.selector;
137
179
  clonedAccessManager.setTargetFunctionRole(
138
- address(clonedInstance),
180
+ "Instance",
139
181
  instanceProductServiceSelectors,
140
- PRODUCT_SERVICE_ROLE().toInt());
182
+ PRODUCT_SERVICE_ROLE());
141
183
  }
142
184
 
143
185
  function _grantPolicyServiceAuthorizations(InstanceAccessManager clonedAccessManager, Instance clonedInstance) internal {
144
186
  // configure authorization for policy service on instance
145
- address policyServiceAddress = _registry.getServiceAddress("PolicyService", VersionLib.toVersion(3, 0, 0).toMajorPart());
187
+ address policyServiceAddress = getRegistry().getServiceAddress(POLICY(), getMajorVersion());
146
188
  clonedAccessManager.grantRole(POLICY_SERVICE_ROLE(), address(policyServiceAddress));
147
189
  bytes4[] memory instancePolicyServiceSelectors = new bytes4[](3);
148
190
  instancePolicyServiceSelectors[0] = clonedInstance.createPolicy.selector;
149
191
  instancePolicyServiceSelectors[1] = clonedInstance.updatePolicy.selector;
150
192
  instancePolicyServiceSelectors[2] = clonedInstance.updatePolicyState.selector;
151
193
  clonedAccessManager.setTargetFunctionRole(
152
- address(clonedInstance),
194
+ "Instance",
153
195
  instancePolicyServiceSelectors,
154
- POLICY_SERVICE_ROLE().toInt());
196
+ POLICY_SERVICE_ROLE());
155
197
  }
156
198
 
157
199
  function _grantBundleServiceAuthorizations(InstanceAccessManager clonedAccessManager, Instance clonedInstance, BundleManager clonedBundleManager) internal {
158
200
  // configure authorization for bundle service on instance
159
- address bundleServiceAddress = _registry.getServiceAddress("BundleService", VersionLib.toVersion(3, 0, 0).toMajorPart());
201
+ address bundleServiceAddress = getRegistry().getServiceAddress(BUNDLE(), getMajorVersion());
160
202
  clonedAccessManager.grantRole(BUNDLE_SERVICE_ROLE(), address(bundleServiceAddress));
161
203
  bytes4[] memory instanceBundleServiceSelectors = new bytes4[](2);
162
204
  instanceBundleServiceSelectors[0] = clonedInstance.createBundle.selector;
163
205
  instanceBundleServiceSelectors[1] = clonedInstance.updateBundle.selector;
164
206
  clonedAccessManager.setTargetFunctionRole(
165
- address(clonedInstance),
207
+ "Instance",
166
208
  instanceBundleServiceSelectors,
167
- BUNDLE_SERVICE_ROLE().toInt());
209
+ BUNDLE_SERVICE_ROLE());
168
210
 
169
211
  // configure authorization for bundle service on bundle manager
170
212
  bytes4[] memory bundleManagerBundleServiceSelectors = new bytes4[](5);
@@ -174,58 +216,82 @@ contract InstanceService is Service, IInstanceService {
174
216
  bundleManagerBundleServiceSelectors[3] = clonedBundleManager.lock.selector;
175
217
  bundleManagerBundleServiceSelectors[4] = clonedBundleManager.unlock.selector;
176
218
  clonedAccessManager.setTargetFunctionRole(
177
- address(clonedBundleManager),
219
+ "BundleManager",
178
220
  bundleManagerBundleServiceSelectors,
179
- BUNDLE_SERVICE_ROLE().toInt());
221
+ BUNDLE_SERVICE_ROLE());
180
222
  }
181
223
 
182
224
  function _grantInstanceServiceAuthorizations(InstanceAccessManager clonedAccessManager, Instance clonedInstance) internal {
183
225
  // configure authorization for instance service on instance
184
- address instanceServiceAddress = _registry.getServiceAddress("InstanceService", VersionLib.toVersion(3, 0, 0).toMajorPart());
226
+ address instanceServiceAddress = getRegistry().getServiceAddress(INSTANCE(), getMajorVersion());
185
227
  clonedAccessManager.grantRole(INSTANCE_SERVICE_ROLE(), instanceServiceAddress);
186
228
  bytes4[] memory instanceInstanceServiceSelectors = new bytes4[](1);
187
229
  instanceInstanceServiceSelectors[0] = clonedInstance.setInstanceReader.selector;
188
230
  clonedAccessManager.setTargetFunctionRole(
189
- address(clonedInstance),
231
+ "Instance",
190
232
  instanceInstanceServiceSelectors,
191
- INSTANCE_SERVICE_ROLE().toInt());
192
- }
193
-
194
- function setMasterInstance(address accessManagerAddress, address instanceAddress, address instanceReaderAddress, address bundleManagerAddress) external onlyOwner {
195
- require(_masterInstanceAccessManager == address(0), "ERROR:CRD-001:ACCESS_MANAGER_MASTER_ALREADY_SET");
196
- require(_masterInstance == address(0), "ERROR:CRD-002:INSTANCE_MASTER_ALREADY_SET");
197
- require(_masterInstanceBundleManager == address(0), "ERROR:CRD-004:BUNDLE_MANAGER_MASTER_ALREADY_SET");
233
+ INSTANCE_SERVICE_ROLE());
198
234
 
199
- require (accessManagerAddress != address(0), "ERROR:CRD-005:ACCESS_MANAGER_ZERO");
200
- require (instanceAddress != address(0), "ERROR:CRD-006:INSTANCE_ZERO");
201
- require (instanceReaderAddress != address(0), "ERROR:CRD-007:INSTANCE_READER_ZERO");
202
- require (bundleManagerAddress != address(0), "ERROR:CRD-008:BUNDLE_MANAGER_ZERO");
203
-
204
- Instance instance = Instance(instanceAddress);
205
- InstanceReader instanceReader = InstanceReader(instanceReaderAddress);
206
- BundleManager bundleManager = BundleManager(bundleManagerAddress);
235
+ bytes4[] memory instanceAccessManagerInstanceServiceSelectors = new bytes4[](1);
236
+ instanceAccessManagerInstanceServiceSelectors[0] = clonedAccessManager.createGifTarget.selector;
237
+ clonedAccessManager.setTargetFunctionRole(
238
+ "InstanceAccessManager",
239
+ instanceAccessManagerInstanceServiceSelectors,
240
+ INSTANCE_SERVICE_ROLE());
241
+ }
207
242
 
208
- require(instance.authority() == accessManagerAddress, "ERROR:CRD-009:INSTANCE_AUTHORITY_MISMATCH");
209
- require(instanceReader.getInstanceNftId() == instance.getNftId(), "ERROR:CRD-010:INSTANCE_READER_INSTANCE_MISMATCH");
210
- require(bundleManager.getInstanceNftId() == instance.getNftId(), "ERROR:CRD-011:BUNDLE_MANAGER_INSTANCE_MISMATCH");
243
+ function setAndRegisterMasterInstance(address instanceAddress)
244
+ external
245
+ onlyOwner
246
+ returns(NftId masterInstanceNftId)
247
+ {
248
+ if(_masterInstance != address(0)) { revert ErrorInstanceServiceMasterInstanceAlreadySet(); }
249
+ if(_masterInstanceAccessManager != address(0)) { revert ErrorInstanceServiceMasterInstanceAccessManagerAlreadySet(); }
250
+ if(_masterInstanceBundleManager != address(0)) { revert ErrorInstanceServiceMasterBundleManagerAlreadySet(); }
251
+
252
+ if(instanceAddress == address(0)) { revert ErrorInstanceServiceInstanceAddressZero(); }
253
+
254
+ IInstance instance = IInstance(instanceAddress);
255
+ InstanceAccessManager accessManager = InstanceAccessManager(instance.authority());
256
+ address accessManagerAddress = address(accessManager);
257
+ InstanceReader instanceReader = instance.getInstanceReader();
258
+ address instanceReaderAddress = address(instanceReader);
259
+ BundleManager bundleManager = instance.getBundleManager();
260
+ address bundleManagerAddress = address(bundleManager);
261
+
262
+ if(accessManagerAddress == address(0)) { revert ErrorInstanceServiceAccessManagerZero(); }
263
+ if(instanceReaderAddress == address(0)) { revert ErrorInstanceServiceInstanceReaderZero(); }
264
+ if(bundleManagerAddress == address(0)) { revert ErrorInstanceServiceBundleManagerZero(); }
265
+
266
+ if(instance.authority() != accessManagerAddress) { revert ErrorInstanceServiceInstanceAuthorityMismatch(); }
267
+ if(instanceReader.getInstance() != instance) { revert ErrorInstanceServiceInstanceReaderInstanceMismatch2(); }
268
+ if(bundleManager.getInstance() != instance) { revert ErrorInstanceServiceBundleMangerInstanceMismatch(); }
211
269
 
212
270
  _masterInstanceAccessManager = accessManagerAddress;
213
271
  _masterInstance = instanceAddress;
214
272
  _masterInstanceReader = instanceReaderAddress;
215
273
  _masterInstanceBundleManager = bundleManagerAddress;
274
+
275
+ IRegistryService registryService = IRegistryService(getRegistry().getServiceAddress(REGISTRY(), getMajorVersion()));
276
+ IInstance masterInstance = IInstance(_masterInstance);
277
+ IRegistry.ObjectInfo memory info = registryService.registerInstance(masterInstance, getOwner());
278
+ masterInstanceNftId = info.nftId;
279
+
280
+ // masterInstance.linkToRegisteredNftId();
216
281
  }
217
282
 
218
283
  function setMasterInstanceReader(address instanceReaderAddress) external onlyOwner {
219
- require(_masterInstanceReader != address(0), "ERROR:CRD-003:INSTANCE_READER_MASTER_NOT_SET");
220
- require (instanceReaderAddress != address(0), "ERROR:CRD-012:INSTANCE_READER_ZERO");
221
- require(instanceReaderAddress != _masterInstanceReader, "ERROR:CRD-014:INSTANCE_READER_MASTER_SAME_AS_NEW");
284
+ if(_masterInstanceReader == address(0)) { revert ErrorInstanceServiceMasterInstanceReaderNotSet(); }
285
+ if(instanceReaderAddress == address(0)) { revert ErrorInstanceServiceInstanceReaderAddressZero(); }
286
+ if(instanceReaderAddress == _masterInstanceReader) { revert ErrorInstanceServiceInstanceReaderSameAsMasterInstanceReader(); }
222
287
 
223
288
  InstanceReader instanceReader = InstanceReader(instanceReaderAddress);
224
- require(instanceReader.getInstanceNftId() == Instance(_masterInstance).getNftId(), "ERROR:CRD-015:INSTANCE_READER_INSTANCE_MISMATCH");
289
+ if(instanceReader.getInstance() != IInstance(_masterInstance)) { revert ErrorInstanceServiceInstanceReaderInstanceMismatch(); }
225
290
 
226
291
  _masterInstanceReader = instanceReaderAddress;
227
292
  }
228
293
 
294
+ // TODO access restriction
229
295
  function upgradeInstanceReader(NftId instanceNftId) external {
230
296
  IRegistry registry = getRegistry();
231
297
  IRegistry.ObjectInfo memory instanceInfo = registry.getObjectInfo(instanceNftId);
@@ -237,7 +303,7 @@ contract InstanceService is Service, IInstanceService {
237
303
  }
238
304
 
239
305
  InstanceReader upgradedInstanceReaderClone = InstanceReader(Clones.clone(address(_masterInstanceReader)));
240
- upgradedInstanceReaderClone.initialize(address(registry), instanceNftId);
306
+ upgradedInstanceReaderClone.initialize(address(registry), address(instance));
241
307
  instance.setInstanceReader(upgradedInstanceReaderClone);
242
308
  }
243
309
 
@@ -258,15 +324,11 @@ contract InstanceService is Service, IInstanceService {
258
324
  }
259
325
 
260
326
  // From IService
261
- function getName() public pure override(IService, Service) returns(string memory) {
262
- return NAME;
327
+ function getDomain() public pure override(Service, IService) returns(ObjectType) {
328
+ return INSTANCE();
263
329
  }
264
330
 
265
331
  /// @dev top level initializer
266
- // 1) registry is non upgradeable -> don't need a proxy and uses constructor !
267
- // 2) deploy registry service first -> from its initialization func it is easier to deploy registry then vice versa
268
- // 3) deploy registry -> pass registry service address as constructor argument
269
- // registry is getting instantiated and locked to registry service address forever
270
332
  function _initialize(
271
333
  address owner,
272
334
  bytes memory data
@@ -275,37 +337,106 @@ contract InstanceService is Service, IInstanceService {
275
337
  initializer
276
338
  virtual override
277
339
  {
278
- address initialOwner = address(0);
279
- address registryAddress = address(0);
340
+ address initialOwner;
341
+ address registryAddress;
280
342
  (registryAddress, initialOwner) = abi.decode(data, (address, address));
281
343
  // TODO while InstanceService is not deployed in InstanceServiceManager constructor
282
344
  // owner is InstanceServiceManager deployer
283
- _initializeService(registryAddress, owner);
284
-
285
- _registerInterface(type(IService).interfaceId);
286
- _registerInterface(type(IInstanceService).interfaceId);
345
+ initializeService(registryAddress, owner);
346
+ registerInterface(type(IInstanceService).interfaceId);
287
347
  }
288
348
 
289
- function createRole(RoleId role, string memory name, NftId instanceNftId) external override onlyInstanceOwner(instanceNftId) {
349
+ function hasRole(address account, RoleId role, address instanceAddress) public view returns (bool) {
350
+ Instance instance = Instance(instanceAddress);
351
+ InstanceAccessManager accessManager = InstanceAccessManager(instance.authority());
352
+ return accessManager.hasRole(role, account);
353
+ }
354
+
355
+ function createGifTarget(NftId instanceNftId, address targetAddress, string memory targetName) external onlyRegisteredService {
290
356
  IRegistry registry = getRegistry();
291
357
  IRegistry.ObjectInfo memory instanceInfo = registry.getObjectInfo(instanceNftId);
292
358
  Instance instance = Instance(instanceInfo.objectAddress);
293
- InstanceAccessManager accessManager = instance.getInstanceAccessManager();
294
- accessManager.createRole(role, name);
359
+ InstanceAccessManager accessManager = InstanceAccessManager(instance.authority());
360
+ accessManager.createGifTarget(targetAddress, targetName);
295
361
  }
296
362
 
297
- function grantRole(RoleId role, address member, NftId instanceNftId) external override onlyInstanceOwner(instanceNftId) {
363
+ function grantDistributionDefaultPermissions(NftId instanceNftId, address distributionAddress, string memory distributionName) external onlyRegisteredService {
298
364
  IRegistry registry = getRegistry();
365
+ IRegistry.ObjectInfo memory distributionInfo = registry.getObjectInfo(distributionAddress);
366
+
367
+ if (distributionInfo.objectType != DISTRIBUTION()) {
368
+ revert ErrorInstanceServiceInvalidComponentType(distributionAddress, DISTRIBUTION(), distributionInfo.objectType);
369
+ }
370
+
299
371
  IRegistry.ObjectInfo memory instanceInfo = registry.getObjectInfo(instanceNftId);
300
372
  Instance instance = Instance(instanceInfo.objectAddress);
301
- InstanceAccessManager accessManager = instance.getInstanceAccessManager();
302
- accessManager.grantRole(role, member);
373
+ InstanceAccessManager instanceAccessManager = InstanceAccessManager(instance.authority());
374
+
375
+ bytes4[] memory fctSelectors = new bytes4[](1);
376
+ fctSelectors[0] = IDistributionComponent.setFees.selector;
377
+ instanceAccessManager.setTargetFunctionRole(distributionName, fctSelectors, DISTRIBUTION_OWNER_ROLE());
378
+
379
+ bytes4[] memory fctSelectors2 = new bytes4[](2);
380
+ fctSelectors2[0] = IDistributionComponent.processSale.selector;
381
+ fctSelectors2[1] = IDistributionComponent.processRenewal.selector;
382
+ instanceAccessManager.setTargetFunctionRole(distributionName, fctSelectors2, PRODUCT_SERVICE_ROLE());
303
383
  }
304
384
 
305
- function hasRole(address account, RoleId role, address instanceAddress) public view returns (bool) {
306
- Instance instance = Instance(instanceAddress);
307
- InstanceAccessManager accessManager = instance.getInstanceAccessManager();
308
- return accessManager.hasRole(role, account);
385
+ function grantPoolDefaultPermissions(NftId instanceNftId, address poolAddress, string memory poolName) external onlyRegisteredService {
386
+ IRegistry registry = getRegistry();
387
+ IRegistry.ObjectInfo memory poolInfo = registry.getObjectInfo(poolAddress);
388
+
389
+ if (poolInfo.objectType != POOL()) {
390
+ revert ErrorInstanceServiceInvalidComponentType(poolAddress, POOL(), poolInfo.objectType);
391
+ }
392
+
393
+ IRegistry.ObjectInfo memory instanceInfo = registry.getObjectInfo(instanceNftId);
394
+ Instance instance = Instance(instanceInfo.objectAddress);
395
+ InstanceAccessManager instanceAccessManager = InstanceAccessManager(instance.authority());
396
+
397
+ bytes4[] memory fctSelectors = new bytes4[](1);
398
+ fctSelectors[0] = IPoolComponent.setFees.selector;
399
+ instanceAccessManager.setTargetFunctionRole(poolName, fctSelectors, POOL_OWNER_ROLE());
400
+
401
+ bytes4[] memory fctSelectors2 = new bytes4[](1);
402
+ fctSelectors2[0] = IPoolComponent.verifyApplication.selector;
403
+ instanceAccessManager.setTargetFunctionRole(poolName, fctSelectors2, POLICY_SERVICE_ROLE());
404
+ }
405
+
406
+ function grantProductDefaultPermissions(NftId instanceNftId, address productAddress, string memory productName) external onlyRegisteredService {
407
+ IRegistry registry = getRegistry();
408
+ IRegistry.ObjectInfo memory productInfo = registry.getObjectInfo(productAddress);
409
+
410
+ if (productInfo.objectType != PRODUCT()) {
411
+ revert ErrorInstanceServiceInvalidComponentType(productAddress, PRODUCT(), productInfo.objectType);
412
+ }
413
+
414
+ IRegistry.ObjectInfo memory instanceInfo = registry.getObjectInfo(instanceNftId);
415
+ Instance instance = Instance(instanceInfo.objectAddress);
416
+ InstanceAccessManager instanceAccessManager = InstanceAccessManager(instance.authority());
417
+
418
+ bytes4[] memory fctSelectors = new bytes4[](1);
419
+ fctSelectors[0] = IProductComponent.setFees.selector;
420
+ instanceAccessManager.setTargetFunctionRole(productName, fctSelectors, PRODUCT_OWNER_ROLE());
309
421
  }
422
+
423
+ function setTargetLocked(string memory targetName, bool locked) external {
424
+ address componentAddress = msg.sender;
425
+ IRegistry registry = getRegistry();
426
+ IRegistry.ObjectInfo memory componentInfo = registry.getObjectInfo(componentAddress);
427
+ if (componentInfo.nftId.eqz()) {
428
+ revert ErrorInstanceServiceComponentNotRegistered(componentAddress);
429
+ }
430
+
431
+ // TODO validate component type
432
+
433
+
434
+ address instanceAddress = registry.getObjectInfo(componentInfo.parentNftId).objectAddress;
435
+ IInstance instance = IInstance(instanceAddress);
436
+
437
+ InstanceAccessManager accessManager = InstanceAccessManager(instance.authority());
438
+ accessManager.setTargetClosed(targetName, locked);
439
+ }
440
+
310
441
  }
311
442
 
@@ -7,7 +7,7 @@ import {ProxyManager} from "../shared/ProxyManager.sol";
7
7
  import {InstanceService} from "./InstanceService.sol";
8
8
  import {Registry} from "../registry/Registry.sol";
9
9
  import {RegistryService} from "../registry/RegistryService.sol";
10
- import {VersionLib} from "../types/Version.sol";
10
+ import {REGISTRY} from "../types/ObjectType.sol";
11
11
 
12
12
  contract InstanceServiceManager is ProxyManager {
13
13
 
@@ -28,10 +28,10 @@ contract InstanceServiceManager is ProxyManager {
28
28
 
29
29
  _instanceService = InstanceService(address(versionable));
30
30
 
31
- Registry registry = Registry(registryAddress);
32
- address registryServiceAddress = registry.getServiceAddress("RegistryService", VersionLib.toVersion(3, 0, 0).toMajorPart());
33
- RegistryService registryService = RegistryService(registryServiceAddress);
34
- // TODO this must have a role or own nft to register service
31
+ // TODO `this` must have a role or own nft to register service
32
+ //Registry registry = Registry(registryAddress);
33
+ //address registryServiceAddress = registry.getServiceAddress(REGISTRY(), _instanceService.getMajorVersion());
34
+ //RegistryService registryService = RegistryService(registryServiceAddress);
35
35
  //registryService.registerService(_instanceService);
36
36
  // RegistryService registryService = _instanceService.getRegistryService();
37
37
 
@@ -40,9 +40,6 @@ contract InstanceServiceManager is ProxyManager {
40
40
  //_linkToNftOwnable(
41
41
  // address(registryAddress),
42
42
  // address(_instanceService));
43
-
44
- // implies that after this constructor call only upgrade functionality is available
45
- _isDeployed = true;
46
43
  }
47
44
 
48
45
  //--- view functions ----------------------------------------------------//
@@ -14,49 +14,32 @@ contract ObjectManager is
14
14
  Cloneable
15
15
  {
16
16
 
17
- event LogObjectManagerInitialized(NftId instanceNftId, address instanceReader);
17
+ event LogObjectManagerInitialized(address instance);
18
18
 
19
19
  error ErrorObjectManagerNftIdInvalid(NftId instanceNftId);
20
20
  error ErrorObjectManagerAlreadyAdded(NftId componentNftId, NftId objectNftId);
21
21
 
22
22
  mapping(NftId compnentNftId => LibNftIdSet.Set objects) internal _activeObjects;
23
23
  mapping(NftId compnentNftId => LibNftIdSet.Set objects) internal _allObjects;
24
- NftId internal _instanceNftId;
25
- InstanceReader internal _instanceReader;
26
-
27
- constructor() Cloneable() {
28
- _instanceReader = InstanceReader(address(0));
29
- }
24
+ IInstance internal _instance; // store instance address -> more flexible, instance may not be registered during ObjectManager initialization
30
25
 
31
26
  /// @dev call to initialize MUST be made in the same transaction as cloning of the contract
32
27
  function initialize(
33
28
  address authority,
34
29
  address registry,
35
- NftId instanceNftId
30
+ address instance
36
31
  )
37
32
  external
38
33
  {
39
34
  initialize(authority, registry);
40
35
 
41
- // check/handle instance nft id/instance reader
42
- IRegistry.ObjectInfo memory instanceInfo = _registry.getObjectInfo(instanceNftId);
43
- if (instanceInfo.objectType != INSTANCE()) {
44
- revert ErrorObjectManagerNftIdInvalid(instanceNftId);
45
- }
46
-
47
- IInstance instance = IInstance(instanceInfo.objectAddress);
48
- _instanceReader = instance.getInstanceReader();
49
- _instanceNftId = instanceNftId;
36
+ _instance = IInstance(instance);
50
37
 
51
- emit LogObjectManagerInitialized(instanceNftId, address(_instanceReader));
52
- }
53
-
54
- function getInstanceReader() external view returns (InstanceReader) {
55
- return _instanceReader;
38
+ emit LogObjectManagerInitialized(instance);
56
39
  }
57
40
 
58
- function getInstanceNftId() external view returns (NftId) {
59
- return _instanceNftId;
41
+ function getInstance() external view returns (IInstance) {
42
+ return _instance;
60
43
  }
61
44
 
62
45
  function _add(NftId componentNftId, NftId objectNftId) internal {