@etherisc/gif-next 0.0.2-83889c4-030 → 0.0.2-839c4b8-393

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 (604) hide show
  1. package/README.md +137 -9
  2. package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.dbg.json +4 -0
  3. package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.json +1075 -0
  4. package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.dbg.json +4 -0
  5. package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.json +790 -0
  6. package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.dbg.json +4 -0
  7. package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.json +843 -0
  8. package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +4 -0
  9. package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +1664 -0
  10. package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.dbg.json +4 -0
  11. package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.json +1289 -0
  12. package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.dbg.json +4 -0
  13. package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.json +1403 -0
  14. package/artifacts/contracts/authorization/Authorization.sol/Authorization.dbg.json +4 -0
  15. package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +790 -0
  16. package/artifacts/contracts/authorization/IAccess.sol/IAccess.dbg.json +4 -0
  17. package/artifacts/contracts/authorization/IAccess.sol/IAccess.json +10 -0
  18. package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.dbg.json +4 -0
  19. package/artifacts/contracts/{shared/IAccessManagerExtended.sol/IAccessManagerExtended.json → authorization/IAccessAdmin.sol/IAccessAdmin.json} +605 -795
  20. package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +4 -0
  21. package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +455 -0
  22. package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +4 -0
  23. package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.json +397 -0
  24. package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +4 -0
  25. package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +646 -0
  26. package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +4 -0
  27. package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +1234 -0
  28. package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +4 -0
  29. package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +805 -0
  30. package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
  31. package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +139 -616
  32. package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
  33. package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +763 -303
  34. package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
  35. package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +235 -123
  36. package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
  37. package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +145 -282
  38. package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
  39. package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +547 -77
  40. package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.dbg.json +4 -0
  41. package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.json +22 -0
  42. package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.dbg.json +4 -0
  43. package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.json +1474 -0
  44. package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +4 -0
  45. package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +805 -0
  46. package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +4 -0
  47. package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +2043 -0
  48. package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +4 -0
  49. package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +805 -0
  50. package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.dbg.json +4 -0
  51. package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.json +376 -0
  52. package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.dbg.json +4 -0
  53. package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.json +1429 -0
  54. package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.dbg.json +4 -0
  55. package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.json +805 -0
  56. package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +4 -0
  57. package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +1161 -0
  58. package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +4 -0
  59. package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +1637 -0
  60. package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.dbg.json +4 -0
  61. package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.json +805 -0
  62. package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +4 -0
  63. package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +2575 -0
  64. package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.dbg.json +4 -0
  65. package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.json +805 -0
  66. package/artifacts/contracts/instance/BaseStore.sol/BaseStore.dbg.json +4 -0
  67. package/artifacts/contracts/{shared/IKeyValueStore.sol/IKeyValueStore.json → instance/BaseStore.sol/BaseStore.json} +59 -195
  68. package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +4 -0
  69. package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +851 -0
  70. package/artifacts/contracts/instance/IBaseStore.sol/IBaseStore.dbg.json +4 -0
  71. package/artifacts/contracts/instance/IBaseStore.sol/IBaseStore.json +304 -0
  72. package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
  73. package/artifacts/contracts/instance/IInstance.sol/IInstance.json +594 -101
  74. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
  75. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +510 -68
  76. package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
  77. package/artifacts/contracts/instance/Instance.sol/Instance.json +600 -235
  78. package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
  79. package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +1889 -313
  80. package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +4 -0
  81. package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +837 -0
  82. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
  83. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +1663 -845
  84. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
  85. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +498 -213
  86. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
  87. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +141 -103
  88. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
  89. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +1500 -2103
  90. package/artifacts/contracts/instance/ProductStore.sol/ProductStore.dbg.json +4 -0
  91. package/artifacts/contracts/instance/ProductStore.sol/ProductStore.json +3427 -0
  92. package/artifacts/contracts/instance/RiskSet.sol/RiskSet.dbg.json +4 -0
  93. package/artifacts/contracts/instance/RiskSet.sol/RiskSet.json +866 -0
  94. package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +1 -1
  95. package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +8 -8
  96. package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +1 -1
  97. package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.json +0 -53
  98. package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +1 -1
  99. package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +2 -2
  100. package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.dbg.json +4 -0
  101. package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.json +223 -0
  102. package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.dbg.json +4 -0
  103. package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.json +192 -0
  104. package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.dbg.json +4 -0
  105. package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.json +168 -0
  106. package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
  107. package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +1 -1
  108. package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
  109. package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
  110. package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
  111. package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +1 -1
  112. package/artifacts/contracts/mock/Dip.sol/Dip.json +2 -2
  113. package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.dbg.json +4 -0
  114. package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.json +947 -0
  115. package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +4 -0
  116. package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +810 -0
  117. package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +1 -1
  118. package/artifacts/contracts/oracle/IOracle.sol/IOracle.json +43 -1
  119. package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +1 -1
  120. package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +142 -139
  121. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +1 -1
  122. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +110 -10
  123. package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +1 -1
  124. package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +140 -423
  125. package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +1 -1
  126. package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +222 -177
  127. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +1 -1
  128. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +184 -92
  129. package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +4 -0
  130. package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +1232 -0
  131. package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +4 -0
  132. package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +805 -0
  133. package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
  134. package/artifacts/contracts/pool/BundleService.sol/BundleService.json +576 -243
  135. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
  136. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +223 -103
  137. package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
  138. package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +395 -52
  139. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
  140. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +147 -406
  141. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
  142. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +756 -372
  143. package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
  144. package/artifacts/contracts/pool/Pool.sol/Pool.json +144 -694
  145. package/artifacts/contracts/pool/PoolLib.sol/PoolLib.dbg.json +4 -0
  146. package/artifacts/contracts/pool/PoolLib.sol/PoolLib.json +522 -0
  147. package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
  148. package/artifacts/contracts/pool/PoolService.sol/PoolService.json +934 -533
  149. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
  150. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +230 -102
  151. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
  152. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +372 -170
  153. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
  154. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +166 -98
  155. package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +4 -0
  156. package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +1149 -0
  157. package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +4 -0
  158. package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +805 -0
  159. package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
  160. package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +489 -231
  161. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
  162. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +195 -119
  163. package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
  164. package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +313 -8
  165. package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
  166. package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +362 -17
  167. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
  168. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +429 -100
  169. package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
  170. package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +195 -79
  171. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
  172. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +282 -271
  173. package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +4 -0
  174. package/artifacts/contracts/{shared/ComponentVerifyingService.sol/ComponentVerifyingService.json → product/IRiskService.sol/IRiskService.json} +289 -150
  175. package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
  176. package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +567 -309
  177. package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.dbg.json +4 -0
  178. package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.json +783 -0
  179. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
  180. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +203 -103
  181. package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
  182. package/artifacts/contracts/product/PricingService.sol/PricingService.json +258 -309
  183. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
  184. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +165 -129
  185. package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
  186. package/artifacts/contracts/product/Product.sol/Product.json +316 -606
  187. package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +4 -0
  188. package/artifacts/contracts/product/RiskService.sol/RiskService.json +873 -0
  189. package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +4 -0
  190. package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +774 -0
  191. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
  192. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +59 -16
  193. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
  194. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +384 -69
  195. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
  196. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +109 -147
  197. package/artifacts/contracts/registry/IRelease.sol/IRelease.dbg.json +4 -0
  198. package/artifacts/contracts/registry/IRelease.sol/IRelease.json +24 -0
  199. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
  200. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +5 -18
  201. package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
  202. package/artifacts/contracts/registry/Registry.sol/Registry.json +617 -133
  203. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
  204. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +1908 -155
  205. package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.dbg.json +4 -0
  206. package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.json +1074 -0
  207. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
  208. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +159 -276
  209. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
  210. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +148 -84
  211. package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.dbg.json +4 -0
  212. package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.json +2152 -0
  213. package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +4 -0
  214. package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +205 -0
  215. package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +4 -0
  216. package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +1389 -0
  217. package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +4 -0
  218. package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +683 -0
  219. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
  220. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +120 -60
  221. package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
  222. package/artifacts/contracts/shared/Component.sol/Component.json +86 -287
  223. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
  224. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +620 -559
  225. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
  226. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +197 -127
  227. package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +4 -0
  228. package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +632 -0
  229. package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.dbg.json +4 -0
  230. package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.json +24 -0
  231. package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.dbg.json +4 -0
  232. package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.json +30 -0
  233. package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.dbg.json +4 -0
  234. package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.json +40 -0
  235. package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
  236. package/artifacts/contracts/shared/IComponent.sol/IComponent.json +92 -103
  237. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
  238. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +545 -237
  239. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
  240. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +131 -139
  241. package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +1 -1
  242. package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.json +34 -3
  243. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
  244. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +35 -0
  245. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
  246. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +15 -47
  247. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
  248. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +167 -0
  249. package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
  250. package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
  251. package/artifacts/contracts/shared/IService.sol/IService.json +96 -1
  252. package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.dbg.json +4 -0
  253. package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.json +53 -0
  254. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +1 -1
  255. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +125 -376
  256. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
  257. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +42 -62
  258. package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.dbg.json +4 -0
  259. package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.json +306 -0
  260. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
  261. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +41 -57
  262. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
  263. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +19 -141
  264. package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
  265. package/artifacts/contracts/shared/Registerable.sol/Registerable.json +141 -97
  266. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
  267. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -15
  268. package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
  269. package/artifacts/contracts/shared/Service.sol/Service.json +92 -104
  270. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
  271. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +585 -12
  272. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.dbg.json +4 -0
  273. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.json +484 -0
  274. package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +4 -0
  275. package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +172 -0
  276. package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
  277. package/artifacts/contracts/staking/IStaking.sol/IStaking.json +1513 -204
  278. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
  279. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +261 -107
  280. package/artifacts/contracts/staking/ITargetLimitHandler.sol/ITargetLimitHandler.dbg.json +4 -0
  281. package/artifacts/contracts/staking/ITargetLimitHandler.sol/ITargetLimitHandler.json +50 -0
  282. package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
  283. package/artifacts/contracts/staking/Staking.sol/Staking.json +1653 -523
  284. package/artifacts/contracts/staking/StakingLib.sol/StakingLib.dbg.json +4 -0
  285. package/artifacts/contracts/staking/StakingLib.sol/StakingLib.json +470 -0
  286. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
  287. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +186 -116
  288. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
  289. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +295 -183
  290. package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
  291. package/artifacts/contracts/staking/StakingService.sol/StakingService.json +315 -295
  292. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
  293. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +144 -104
  294. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
  295. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +1725 -817
  296. package/artifacts/contracts/staking/TargetHandler.sol/TargetHandler.dbg.json +4 -0
  297. package/artifacts/contracts/staking/TargetHandler.sol/TargetHandler.json +309 -0
  298. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
  299. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +184 -76
  300. package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +1 -1
  301. package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.json +2 -2
  302. package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +1 -1
  303. package/artifacts/contracts/type/Amount.sol/AmountLib.json +63 -10
  304. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
  305. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +45 -19
  306. package/artifacts/contracts/type/ChainId.sol/ChainIdLib.dbg.json +4 -0
  307. package/artifacts/contracts/type/ChainId.sol/ChainIdLib.json +193 -0
  308. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +1 -1
  309. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +28 -4
  310. package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
  311. package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +4 -4
  312. package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +1 -1
  313. package/artifacts/contracts/type/Fee.sol/FeeLib.json +98 -37
  314. package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +1 -1
  315. package/artifacts/contracts/type/Key32.sol/Key32Lib.json +2 -2
  316. package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.dbg.json +4 -0
  317. package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.json +33 -0
  318. package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
  319. package/artifacts/contracts/type/NftId.sol/NftIdLib.json +23 -4
  320. package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
  321. package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +2 -2
  322. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
  323. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +140 -4
  324. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +1 -1
  325. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +19 -19
  326. package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +1 -1
  327. package/artifacts/contracts/type/Referral.sol/ReferralLib.json +4 -4
  328. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +1 -1
  329. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +4 -4
  330. package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +1 -1
  331. package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +125 -7
  332. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
  333. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +121 -23
  334. package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
  335. package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +93 -2
  336. package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +4 -0
  337. package/artifacts/contracts/type/Selector.sol/SelectorLib.json +148 -0
  338. package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +4 -0
  339. package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +10 -0
  340. package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
  341. package/artifacts/contracts/type/StateId.sol/StateIdLib.json +15 -2
  342. package/artifacts/contracts/type/String.sol/StrLib.dbg.json +4 -0
  343. package/artifacts/contracts/type/String.sol/StrLib.json +180 -0
  344. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
  345. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +24 -5
  346. package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
  347. package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +126 -33
  348. package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +1 -1
  349. package/artifacts/contracts/type/Version.sol/VersionLib.json +2 -21
  350. package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +1 -1
  351. package/artifacts/contracts/type/Version.sol/VersionPartLib.json +120 -2
  352. package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.dbg.json +4 -0
  353. package/artifacts/contracts/{shared → upgradeability}/IVersionable.sol/IVersionable.json +11 -1
  354. package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.dbg.json +4 -0
  355. package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +656 -0
  356. package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +4 -0
  357. package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +142 -0
  358. package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +4 -0
  359. package/artifacts/contracts/{shared → upgradeability}/Versionable.sol/Versionable.json +11 -1
  360. package/contracts/accounting/AccountingService.sol +274 -0
  361. package/contracts/accounting/AccountingServiceManager.sol +38 -0
  362. package/contracts/accounting/IAccountingService.sol +47 -0
  363. package/contracts/authorization/AccessAdmin.sol +780 -0
  364. package/contracts/authorization/AccessAdminLib.sol +396 -0
  365. package/contracts/authorization/AccessManagerCloneable.sol +158 -0
  366. package/contracts/authorization/Authorization.sol +169 -0
  367. package/contracts/authorization/IAccess.sol +67 -0
  368. package/contracts/authorization/IAccessAdmin.sol +144 -0
  369. package/contracts/authorization/IAuthorization.sol +26 -0
  370. package/contracts/authorization/IServiceAuthorization.sol +78 -0
  371. package/contracts/authorization/ServiceAuthorization.sol +320 -0
  372. package/contracts/distribution/BasicDistribution.sol +140 -0
  373. package/contracts/distribution/BasicDistributionAuthorization.sol +67 -0
  374. package/contracts/distribution/Distribution.sol +125 -141
  375. package/contracts/distribution/DistributionService.sol +287 -137
  376. package/contracts/distribution/DistributionServiceManager.sol +8 -11
  377. package/contracts/distribution/IDistributionComponent.sol +21 -42
  378. package/contracts/distribution/IDistributionService.sol +60 -26
  379. package/contracts/examples/fire/DamageLevel.sol +59 -0
  380. package/contracts/examples/fire/FirePool.sol +86 -0
  381. package/contracts/examples/fire/FirePoolAuthorization.sol +35 -0
  382. package/contracts/examples/fire/FireProduct.sol +433 -0
  383. package/contracts/examples/fire/FireProductAuthorization.sol +45 -0
  384. package/contracts/examples/fire/FireUSD.sol +26 -0
  385. package/contracts/examples/unpermissioned/SimpleDistribution.sol +81 -0
  386. package/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol +28 -0
  387. package/contracts/examples/unpermissioned/SimpleOracle.sol +133 -0
  388. package/contracts/examples/unpermissioned/SimplePool.sol +102 -0
  389. package/contracts/examples/unpermissioned/SimplePoolAuthorization.sol +28 -0
  390. package/contracts/examples/unpermissioned/SimpleProduct.sol +437 -0
  391. package/contracts/examples/unpermissioned/SimpleProductAuthorization.sol +28 -0
  392. package/contracts/instance/BaseStore.sol +93 -0
  393. package/contracts/instance/BundleSet.sol +130 -0
  394. package/contracts/instance/IBaseStore.sol +37 -0
  395. package/contracts/instance/IInstance.sol +121 -47
  396. package/contracts/instance/IInstanceService.sol +80 -42
  397. package/contracts/instance/Instance.sol +251 -136
  398. package/contracts/instance/InstanceAdmin.sol +297 -249
  399. package/contracts/instance/InstanceAuthorizationV3.sol +275 -0
  400. package/contracts/instance/InstanceReader.sol +478 -256
  401. package/contracts/instance/InstanceService.sol +389 -237
  402. package/contracts/instance/InstanceServiceManager.sol +8 -13
  403. package/contracts/instance/InstanceStore.sol +163 -121
  404. package/contracts/instance/ProductStore.sol +290 -0
  405. package/contracts/instance/RiskSet.sol +126 -0
  406. package/contracts/instance/TargetNames.sol +10 -0
  407. package/contracts/instance/base/BalanceStore.sol +15 -12
  408. package/contracts/instance/base/Cloneable.sol +2 -25
  409. package/contracts/instance/base/ObjectCounter.sol +1 -2
  410. package/contracts/instance/base/ObjectLifecycle.sol +109 -0
  411. package/contracts/instance/base/ObjectSet.sol +77 -0
  412. package/contracts/instance/base/ObjectSetHelperLib.sol +30 -0
  413. package/contracts/instance/module/IBundle.sol +6 -5
  414. package/contracts/instance/module/IComponents.sol +29 -21
  415. package/contracts/instance/module/IDistribution.sol +21 -9
  416. package/contracts/instance/module/IPolicy.sol +50 -29
  417. package/contracts/instance/module/IRisk.sol +5 -0
  418. package/contracts/mock/Dip.sol +1 -1
  419. package/contracts/oracle/BasicOracle.sol +44 -0
  420. package/contracts/oracle/BasicOracleAuthorization.sol +53 -0
  421. package/contracts/oracle/IOracle.sol +25 -4
  422. package/contracts/oracle/IOracleComponent.sol +2 -1
  423. package/contracts/oracle/IOracleService.sol +2 -1
  424. package/contracts/oracle/Oracle.sol +60 -53
  425. package/contracts/oracle/OracleService.sol +120 -87
  426. package/contracts/oracle/OracleServiceManager.sol +8 -11
  427. package/contracts/pool/BasicPool.sol +161 -0
  428. package/contracts/pool/BasicPoolAuthorization.sol +81 -0
  429. package/contracts/pool/BundleService.sol +225 -135
  430. package/contracts/pool/BundleServiceManager.sol +8 -11
  431. package/contracts/pool/IBundleService.sol +43 -33
  432. package/contracts/pool/IPoolComponent.sol +20 -70
  433. package/contracts/pool/IPoolService.sol +97 -77
  434. package/contracts/pool/Pool.sol +196 -164
  435. package/contracts/pool/PoolLib.sol +341 -0
  436. package/contracts/pool/PoolService.sol +424 -263
  437. package/contracts/pool/PoolServiceManager.sol +6 -9
  438. package/contracts/product/ApplicationService.sol +159 -86
  439. package/contracts/product/ApplicationServiceManager.sol +6 -6
  440. package/contracts/product/BasicProduct.sol +48 -0
  441. package/contracts/product/BasicProductAuthorization.sol +63 -0
  442. package/contracts/product/ClaimService.sol +396 -212
  443. package/contracts/product/ClaimServiceManager.sol +6 -6
  444. package/contracts/product/IApplicationService.sol +29 -3
  445. package/contracts/product/IClaimService.sol +48 -11
  446. package/contracts/product/IPolicyService.sol +61 -37
  447. package/contracts/product/IPricingService.sol +11 -10
  448. package/contracts/product/IProductComponent.sol +29 -9
  449. package/contracts/product/IRiskService.sol +48 -0
  450. package/contracts/product/PolicyService.sol +450 -280
  451. package/contracts/product/PolicyServiceLib.sol +139 -0
  452. package/contracts/product/PolicyServiceManager.sol +6 -9
  453. package/contracts/product/PricingService.sol +93 -88
  454. package/contracts/product/PricingServiceManager.sol +6 -9
  455. package/contracts/product/Product.sol +261 -147
  456. package/contracts/product/RiskService.sol +189 -0
  457. package/contracts/product/RiskServiceManager.sol +39 -0
  458. package/contracts/registry/ChainNft.sol +72 -40
  459. package/contracts/registry/IRegistry.sol +84 -36
  460. package/contracts/registry/IRegistryService.sol +3 -10
  461. package/contracts/registry/IRelease.sol +29 -0
  462. package/contracts/registry/ITransferInterceptor.sol +1 -2
  463. package/contracts/registry/Registry.sol +378 -218
  464. package/contracts/registry/RegistryAdmin.sol +125 -171
  465. package/contracts/registry/RegistryAuthorization.sol +336 -0
  466. package/contracts/registry/RegistryService.sol +47 -72
  467. package/contracts/registry/RegistryServiceManager.sol +5 -10
  468. package/contracts/registry/ReleaseAdmin.sol +195 -0
  469. package/contracts/registry/ReleaseLifecycle.sol +32 -0
  470. package/contracts/registry/ReleaseRegistry.sol +525 -0
  471. package/contracts/registry/ServiceAuthorizationV3.sol +342 -0
  472. package/contracts/registry/TokenRegistry.sol +61 -59
  473. package/contracts/shared/Component.sol +71 -142
  474. package/contracts/shared/ComponentService.sol +462 -389
  475. package/contracts/shared/ComponentServiceManager.sol +10 -7
  476. package/contracts/shared/ContractLib.sol +312 -0
  477. package/contracts/shared/IComponent.sol +6 -18
  478. package/contracts/shared/IComponentService.sol +50 -41
  479. package/contracts/shared/IInstanceLinkedComponent.sol +10 -26
  480. package/contracts/shared/ILifecycle.sol +3 -2
  481. package/contracts/shared/INftOwnable.sol +4 -0
  482. package/contracts/shared/IPolicyHolder.sol +12 -22
  483. package/contracts/shared/IRegisterable.sol +22 -1
  484. package/contracts/shared/IService.sol +10 -5
  485. package/contracts/shared/{ERC165.sol → InitializableERC165.sol} +11 -3
  486. package/contracts/shared/InstanceLinkedComponent.sol +96 -48
  487. package/contracts/shared/Lifecycle.sol +30 -72
  488. package/contracts/shared/{NftIdSetManager.sol → NftIdSet.sol} +1 -1
  489. package/contracts/shared/NftOwnable.sol +33 -11
  490. package/contracts/shared/PolicyHolder.sol +20 -59
  491. package/contracts/shared/Registerable.sol +52 -21
  492. package/contracts/shared/RegistryLinked.sol +9 -14
  493. package/contracts/shared/Service.sol +31 -41
  494. package/contracts/shared/TokenHandler.sol +310 -26
  495. package/contracts/shared/TokenHandlerDeployerLib.sol +20 -0
  496. package/contracts/staking/IStaking.sol +272 -73
  497. package/contracts/staking/IStakingService.sol +54 -76
  498. package/contracts/staking/ITargetLimitHandler.sol +17 -0
  499. package/contracts/staking/Staking.sol +540 -294
  500. package/contracts/staking/{StakeManagerLib.sol → StakingLib.sol} +72 -56
  501. package/contracts/staking/StakingManager.sol +14 -15
  502. package/contracts/staking/StakingReader.sol +72 -88
  503. package/contracts/staking/StakingService.sol +90 -175
  504. package/contracts/staking/StakingServiceManager.sol +9 -8
  505. package/contracts/staking/StakingStore.sol +1131 -335
  506. package/contracts/staking/TargetHandler.sol +132 -0
  507. package/contracts/staking/TargetManagerLib.sol +73 -46
  508. package/contracts/type/Amount.sol +31 -5
  509. package/contracts/type/Blocknumber.sol +22 -16
  510. package/contracts/type/ChainId.sol +101 -0
  511. package/contracts/type/ClaimId.sol +6 -1
  512. package/contracts/type/Fee.sol +8 -8
  513. package/contracts/type/Key32.sol +2 -2
  514. package/contracts/type/Key32Set.sol +62 -0
  515. package/contracts/type/NftId.sol +7 -0
  516. package/contracts/type/ObjectType.sol +200 -61
  517. package/contracts/type/PayoutId.sol +10 -10
  518. package/contracts/type/Referral.sol +1 -0
  519. package/contracts/type/RiskId.sol +38 -6
  520. package/contracts/type/RoleId.sol +121 -87
  521. package/contracts/type/Seconds.sol +40 -1
  522. package/contracts/type/Selector.sol +107 -0
  523. package/contracts/type/StateId.sol +15 -1
  524. package/contracts/type/String.sol +65 -0
  525. package/contracts/type/Timestamp.sol +14 -7
  526. package/contracts/type/UFixed.sol +62 -125
  527. package/contracts/type/Version.sol +57 -6
  528. package/contracts/{shared → upgradeability}/IVersionable.sol +3 -0
  529. package/contracts/{shared → upgradeability}/ProxyManager.sol +96 -49
  530. package/contracts/upgradeability/UpgradableProxyWithAdmin.sol +24 -0
  531. package/contracts/{shared → upgradeability}/Versionable.sol +8 -5
  532. package/package.json +10 -7
  533. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +0 -4
  534. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +0 -778
  535. package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +0 -4
  536. package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +0 -228
  537. package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +0 -4
  538. package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +0 -256
  539. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +0 -4
  540. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +0 -129
  541. package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +0 -4
  542. package/artifacts/contracts/product/IProductService.sol/IProductService.json +0 -387
  543. package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +0 -4
  544. package/artifacts/contracts/product/ProductService.sol/ProductService.json +0 -679
  545. package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
  546. package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +0 -694
  547. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +0 -4
  548. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +0 -1292
  549. package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.dbg.json +0 -4
  550. package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.json +0 -137
  551. package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.dbg.json +0 -4
  552. package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.json +0 -1193
  553. package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.dbg.json +0 -4
  554. package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.json +0 -1715
  555. package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.dbg.json +0 -4
  556. package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.json +0 -1728
  557. package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.dbg.json +0 -4
  558. package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.json +0 -1806
  559. package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.dbg.json +0 -4
  560. package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.json +0 -1824
  561. package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +0 -4
  562. package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +0 -4
  563. package/artifacts/contracts/shared/ERC165.sol/ERC165.json +0 -73
  564. package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.dbg.json +0 -4
  565. package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.dbg.json +0 -4
  566. package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.json +0 -1600
  567. package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +0 -4
  568. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +0 -4
  569. package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.dbg.json +0 -4
  570. package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.json +0 -39
  571. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +0 -4
  572. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +0 -571
  573. package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.dbg.json +0 -4
  574. package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.json +0 -306
  575. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +0 -4
  576. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +0 -617
  577. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +0 -4
  578. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +0 -129
  579. package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +0 -4
  580. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +0 -4
  581. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +0 -444
  582. package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +0 -4
  583. package/artifacts/contracts/type/UFixed.sol/MathLib.json +0 -10
  584. package/contracts/instance/BundleManager.sol +0 -126
  585. package/contracts/instance/InstanceAuthorizationsLib.sol +0 -377
  586. package/contracts/instance/base/ObjectManager.sol +0 -82
  587. package/contracts/instance/module/IAccess.sol +0 -46
  588. package/contracts/product/IProductService.sol +0 -33
  589. package/contracts/product/ProductService.sol +0 -124
  590. package/contracts/product/ProductServiceManager.sol +0 -42
  591. package/contracts/registry/ReleaseManager.sol +0 -600
  592. package/contracts/registry/ServiceAuthorizationsLib.sol +0 -173
  593. package/contracts/shared/AccessManagerCustom.sol +0 -736
  594. package/contracts/shared/AccessManagerExtended.sol +0 -470
  595. package/contracts/shared/AccessManagerExtendedInitializeable.sol +0 -13
  596. package/contracts/shared/AccessManagerExtendedWithDisable.sol +0 -137
  597. package/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol +0 -14
  598. package/contracts/shared/ComponentVerifyingService.sol +0 -117
  599. package/contracts/shared/IAccessManagerExtended.sol +0 -74
  600. package/contracts/shared/IAccessManagerExtendedWithDisable.sol +0 -18
  601. package/contracts/shared/IKeyValueStore.sol +0 -53
  602. package/contracts/shared/InitializableCustom.sol +0 -177
  603. package/contracts/shared/KeyValueStore.sol +0 -127
  604. package/contracts/shared/UpgradableProxyWithAdmin.sol +0 -16
@@ -1,47 +1,47 @@
1
1
  // SPDX-License-Identifier: Apache-2.0
2
2
  pragma solidity ^0.8.20;
3
3
 
4
- import {Amount, AmountLib} from "../type/Amount.sol";
5
- import {ComponentVerifyingService} from "../shared/ComponentVerifyingService.sol";
6
- import {Fee, FeeLib} from "../type/Fee.sol";
7
- import {IInstanceLinkedComponent} from "./IInstanceLinkedComponent.sol";
8
- import {IRegistry} from "../registry/IRegistry.sol";
9
- import {IRegistryService} from "../registry/IRegistryService.sol";
10
- import {IInstance} from "../instance/IInstance.sol";
11
- import {IAccess} from "../instance/module/IAccess.sol";
12
- import {NftId} from "../type/NftId.sol";
13
- import {ObjectType, REGISTRY, COMPONENT, DISTRIBUTION, INSTANCE, ORACLE, POOL, PRODUCT} from "../type/ObjectType.sol";
14
- import {RoleId, DISTRIBUTION_OWNER_ROLE, ORACLE_OWNER_ROLE, POOL_OWNER_ROLE, PRODUCT_OWNER_ROLE, POLICY_SERVICE_ROLE, PRODUCT_SERVICE_ROLE} from "../type/RoleId.sol";
15
- import {KEEP_STATE} from "../type/StateId.sol";
4
+ import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
5
+
6
+ import {IAccountingService} from "../accounting/IAccountingService.sol";
16
7
  import {IComponents} from "../instance/module/IComponents.sol";
17
8
  import {IComponentService} from "./IComponentService.sol";
18
- import {IDistributionComponent} from "../distribution/IDistributionComponent.sol";
19
- import {IInstanceService} from "../instance/IInstanceService.sol";
20
- import {IPoolComponent} from "../pool/IPoolComponent.sol";
21
- import {IProductComponent} from "../product/IProductComponent.sol";
9
+ import {IInstance} from "../instance/IInstance.sol";
10
+ import {IInstanceLinkedComponent} from "./IInstanceLinkedComponent.sol";
11
+ import {InstanceAdmin} from "../instance/InstanceAdmin.sol";
22
12
  import {InstanceReader} from "../instance/InstanceReader.sol";
23
13
  import {InstanceStore} from "../instance/InstanceStore.sol";
24
- import {TokenHandler} from "./TokenHandler.sol";
14
+ import {IPoolComponent} from "../pool/IPoolComponent.sol";
15
+ import {IProductComponent} from "../product/IProductComponent.sol";
16
+ import {IRegistry} from "../registry/IRegistry.sol";
17
+ import {IRegistryService} from "../registry/IRegistryService.sol";
18
+ import {IStaking} from "../staking/IStaking.sol";
19
+ import {IStakingService} from "../staking/IStakingService.sol";
20
+
21
+ import {AccessManagerCloneable} from "../authorization/AccessManagerCloneable.sol";
22
+ import {Amount, AmountLib} from "../type/Amount.sol";
23
+ import {ChainIdLib} from "../type/ChainId.sol";
24
+ import {ContractLib} from "../shared/ContractLib.sol";
25
+ import {Fee, FeeLib} from "../type/Fee.sol";
26
+ import {KEEP_STATE} from "../type/StateId.sol";
27
+ import {NftId, NftIdLib} from "../type/NftId.sol";
28
+ import {ObjectType, ACCOUNTING, REGISTRY, COMPONENT, DISTRIBUTION, INSTANCE, ORACLE, POOL, PRODUCT, STAKING} from "../type/ObjectType.sol";
29
+ import {ProductStore} from "../instance/ProductStore.sol";
30
+ import {Service} from "../shared/Service.sol";
31
+ import {TokenHandler} from "../shared/TokenHandler.sol";
32
+ import {TokenHandlerDeployerLib} from "../shared/TokenHandlerDeployerLib.sol";
33
+
25
34
 
26
35
  contract ComponentService is
27
- ComponentVerifyingService,
36
+ Service,
28
37
  IComponentService
29
38
  {
30
-
31
- error ErrorComponentServiceAlreadyRegistered(address component);
32
- error ErrorComponentServiceNotComponent(address component);
33
- error ErrorComponentServiceInvalidType(address component, ObjectType requiredType, ObjectType componentType);
34
- error ErrorComponentServiceSenderNotOwner(address component, address initialOwner, address sender);
35
- error ErrorComponentServiceExpectedRoleMissing(NftId instanceNftId, RoleId requiredRole, address sender);
36
- error ErrorComponentServiceComponentLocked(address component);
37
- error ErrorComponentServiceSenderNotService(address sender);
38
- error ErrorComponentServiceComponentTypeInvalid(address component, ObjectType expectedType, ObjectType foundType);
39
-
40
39
  bool private constant INCREASE = true;
41
40
  bool private constant DECREASE = false;
42
41
 
42
+ IAccountingService private _accountingService;
43
43
  IRegistryService private _registryService;
44
- IInstanceService private _instanceService;
44
+ IStaking private _staking;
45
45
 
46
46
  function _initialize(
47
47
  address owner,
@@ -51,171 +51,296 @@ contract ComponentService is
51
51
  virtual override
52
52
  initializer()
53
53
  {
54
- // TODO check this, might no longer be the way, refactor if necessary
55
- address registryAddress;
56
- address initialOwner;
57
- (registryAddress, initialOwner) = abi.decode(data, (address, address));
54
+ (
55
+ address authority,
56
+ address registry
57
+ ) = abi.decode(data, (address, address));
58
58
 
59
- initializeService(registryAddress, address(0), owner);
59
+ __Service_init(authority, registry, owner);
60
60
 
61
+ _accountingService = IAccountingService(_getServiceAddress(ACCOUNTING()));
61
62
  _registryService = IRegistryService(_getServiceAddress(REGISTRY()));
62
- _instanceService = IInstanceService(_getServiceAddress(INSTANCE()));
63
+ _staking = IStakingService(_getServiceAddress(STAKING())).getStaking();
63
64
 
64
- registerInterface(type(IComponentService).interfaceId);
65
+ _registerInterface(type(IComponentService).interfaceId);
65
66
  }
66
67
 
68
+ //-------- component ----------------------------------------------------//
69
+
70
+ /// @inheritdoc IComponentService
71
+ function registerComponent(address componentAddress)
72
+ external
73
+ virtual
74
+ restricted()
75
+ returns (NftId componentNftId)
76
+ {
77
+ // checks
78
+ // check sender is registered product
79
+ IRegistry registry = getRegistry();
80
+ if (!registry.isObjectType(msg.sender, PRODUCT())) {
81
+ revert ErrorComponentServiceCallerNotProduct(msg.sender);
82
+ }
67
83
 
68
- function getDomain() public pure virtual override returns(ObjectType) {
69
- return COMPONENT();
84
+ // check provided address is product contract
85
+ if (!_isInstanceLinkedComponent(componentAddress)) {
86
+ revert ErrorComponentServiceNotComponent(componentAddress);
87
+ }
88
+
89
+ NftId productNftId = registry.getNftIdForAddress(msg.sender);
90
+ IInstance instance = IInstance(
91
+ registry.getObjectAddress(
92
+ registry.getParentNftId(productNftId)));
93
+
94
+ componentNftId = _verifyAndRegister(
95
+ instance,
96
+ componentAddress,
97
+ productNftId, // product is parent of component to be registered
98
+ address(0)); // token will be inhereited from product
70
99
  }
71
100
 
72
- //-------- component ----------------------------------------------------//
73
101
 
74
- function setWallet(address newWallet) external virtual {
75
- (NftId componentNftId,, IInstance instance) = _getAndVerifyActiveComponent(COMPONENT());
76
- IComponents.ComponentInfo memory info = instance.getInstanceReader().getComponentInfo(componentNftId);
77
- address currentWallet = info.wallet;
102
+ /// @inheritdoc IComponentService
103
+ function approveTokenHandler(
104
+ IERC20Metadata token,
105
+ Amount amount
106
+ )
107
+ external
108
+ virtual
109
+ restricted()
110
+ {
111
+ // checks
112
+ (NftId componentNftId, IInstance instance) = _getAndVerifyComponent(COMPONENT(), true);
113
+ TokenHandler tokenHandler = instance.getInstanceReader().getTokenHandler(
114
+ componentNftId);
78
115
 
79
- if (newWallet == address(0)) {
80
- revert ErrorComponentServiceNewWalletAddressZero();
81
- }
116
+ // effects
117
+ tokenHandler.approve(token, amount);
118
+ }
82
119
 
83
- if (currentWallet == address(0)) {
84
- revert ErrorComponentServiceWalletAddressZero();
85
- }
86
120
 
87
- if (newWallet == currentWallet) {
88
- revert ErrorComponentServiceWalletAddressIsSameAsCurrent();
89
- }
121
+ /// @inheritdoc IComponentService
122
+ function setWallet(address newWallet)
123
+ external
124
+ virtual
125
+ restricted()
126
+ {
127
+ // checks
128
+ (NftId componentNftId, IInstance instance) = _getAndVerifyComponent(COMPONENT(), true);
129
+ TokenHandler tokenHandler = instance.getInstanceReader().getTokenHandler(
130
+ componentNftId);
131
+
132
+ // effects
133
+ tokenHandler.setWallet(newWallet);
134
+ }
90
135
 
91
- info.wallet = newWallet;
92
- instance.getInstanceStore().updateComponent(componentNftId, info, KEEP_STATE());
93
- emit LogComponentServiceWalletAddressChanged(componentNftId, currentWallet, newWallet);
136
+ /// @inheritdoc IComponentService
137
+ function setLocked(bool locked)
138
+ external
139
+ virtual
140
+ restricted()
141
+ {
142
+ (, IInstance instance) = _getAndVerifyComponent(COMPONENT(), false);
143
+
144
+ address component = msg.sender;
145
+ instance.getInstanceAdmin().setComponentLocked(
146
+ component,
147
+ locked);
148
+ emit LogComponentServiceComponentLocked(component, locked);
94
149
  }
95
150
 
96
- // TODO implement
97
- function lock() external virtual {}
98
151
 
99
- // TODO implement
100
- function unlock() external virtual {}
152
+ /// @inheritdoc IComponentService
153
+ function withdrawFees(Amount amount)
154
+ external
155
+ virtual
156
+ restricted()
157
+ returns (Amount withdrawnAmount)
158
+ {
159
+ // checks
160
+ (NftId componentNftId, IInstance instance) = _getAndVerifyComponent(COMPONENT(), true);
161
+ InstanceReader instanceReader = instance.getInstanceReader();
162
+
163
+ // determine withdrawn amount
164
+ Amount maxAvailableAmount = instanceReader.getFeeAmount(componentNftId);
165
+ withdrawnAmount = amount;
166
+
167
+ // max amount -> withraw all available fees
168
+ if (amount == AmountLib.max()) {
169
+ withdrawnAmount = maxAvailableAmount;
170
+ }
171
+
172
+ // check modified withdrawn amount
173
+ if (withdrawnAmount.eqz()) {
174
+ revert ErrorComponentServiceWithdrawAmountIsZero();
175
+ } else if (withdrawnAmount > maxAvailableAmount) {
176
+ revert ErrorComponentServiceWithdrawAmountExceedsLimit(withdrawnAmount, maxAvailableAmount);
177
+ }
178
+
179
+ // effects
180
+ // decrease fee counters by withdrawnAmount
181
+ _accountingService.decreaseComponentFees(
182
+ instance.getInstanceStore(),
183
+ componentNftId,
184
+ withdrawnAmount);
185
+
186
+ // transfer amount to component owner
187
+ address componentOwner = getRegistry().ownerOf(componentNftId);
188
+ TokenHandler tokenHandler = instanceReader.getTokenHandler(componentNftId);
189
+ emit LogComponentServiceComponentFeesWithdrawn(
190
+ componentNftId,
191
+ componentOwner,
192
+ address(tokenHandler.TOKEN()),
193
+ withdrawnAmount);
194
+
195
+ // interactions
196
+ // transfer amount to component owner
197
+ tokenHandler.pushFeeToken(
198
+ componentOwner,
199
+ withdrawnAmount);
200
+ }
101
201
 
102
202
 
103
203
  //-------- product ------------------------------------------------------//
104
204
 
105
- function registerProduct()
205
+ /// @inheritdoc IComponentService
206
+ function registerProduct(address productAddress, address token)
106
207
  external
107
208
  virtual
209
+ restricted()
210
+ nonReentrant()
211
+ returns (NftId productNftId)
108
212
  {
109
- address contractAddress = msg.sender;
110
- RoleId[] memory roles = new RoleId[](1);
111
- bytes4[][] memory selectors = new bytes4[][](1);
213
+ // checks
214
+ // check sender is registered instance
215
+ IRegistry registry = getRegistry();
216
+ if (!registry.isObjectType(msg.sender, INSTANCE())) {
217
+ revert ErrorComponentServiceCallerNotInstance(msg.sender);
218
+ }
112
219
 
113
- // authorizaion for distribution owner
114
- roles[0] = PRODUCT_OWNER_ROLE();
115
- selectors[0] = _createSelectors(IProductComponent.setFees.selector);
220
+ // check provided address is product contract
221
+ if (!_isProduct(productAddress)) {
222
+ revert ErrorComponentServiceNotProduct(productAddress);
223
+ }
116
224
 
117
- // register/create component setup
118
- (
119
- InstanceReader instanceReader,
120
- InstanceStore instanceStore,
121
- NftId productNftId
122
- ) = _register(
123
- contractAddress,
124
- PRODUCT(),
125
- PRODUCT_OWNER_ROLE(),
126
- roles,
127
- selectors);
128
-
129
- // create product info
130
- IComponents.ProductInfo memory productInfo = IProductComponent(contractAddress).getInitialProductInfo();
131
- instanceStore.createProduct(productNftId, productInfo);
132
-
133
- // link distribution and pool to product
134
- _linkToProduct(instanceReader, instanceStore, productInfo.distributionNftId, productNftId);
135
- _linkToProduct(instanceReader, instanceStore, productInfo.poolNftId, productNftId);
225
+ IInstance instance = IInstance(msg.sender);
226
+ NftId instanceNftId = registry.getNftIdForAddress(msg.sender);
227
+ productNftId = _verifyAndRegister(
228
+ instance,
229
+ productAddress,
230
+ instanceNftId, // instance is parent of product to be registered
231
+ token);
232
+
233
+ // add product specific token for product to staking
234
+ _staking.addTargetToken(
235
+ instanceNftId,
236
+ token);
237
+ }
238
+
239
+
240
+ function _isProduct(address target) internal view virtual returns (bool) {
241
+ if (!_isInstanceLinkedComponent(target)) {
242
+ return false;
243
+ }
244
+
245
+ return IInstanceLinkedComponent(target).getInitialInfo().objectType == PRODUCT();
136
246
  }
137
247
 
138
248
 
249
+ function _isInstanceLinkedComponent(address target) internal view virtual returns (bool) {
250
+ if (!ContractLib.isContract(target)) {
251
+ return false;
252
+ }
253
+
254
+ return ContractLib.supportsInterface(target, type(IInstanceLinkedComponent).interfaceId);
255
+ }
256
+
257
+
258
+ /// @inheritdoc IComponentService
139
259
  function setProductFees(
140
260
  Fee memory productFee, // product fee on net premium
141
261
  Fee memory processingFee // product fee on payout amounts
142
262
  )
143
263
  external
144
264
  virtual
265
+ restricted()
266
+ nonReentrant()
145
267
  {
146
- (NftId productNftId,, IInstance instance) = _getAndVerifyActiveComponent(PRODUCT());
147
- IComponents.ProductInfo memory productInfo = instance.getInstanceReader().getProductInfo(productNftId);
268
+ (NftId productNftId, IInstance instance) = _getAndVerifyComponent(PRODUCT(), true);
269
+ IComponents.FeeInfo memory feeInfo = instance.getInstanceReader().getFeeInfo(productNftId);
148
270
  bool feesChanged = false;
149
271
 
150
272
  // update product fee if required
151
- if(!FeeLib.eq(productInfo.productFee, productFee)) {
152
- _logUpdateFee(productNftId, "ProductFee", productInfo.productFee, productFee);
153
- productInfo.productFee = productFee;
273
+ if(!FeeLib.eq(feeInfo.productFee, productFee)) {
274
+ _logUpdateFee(productNftId, "ProductFee", feeInfo.productFee, productFee);
275
+ feeInfo.productFee = productFee;
154
276
  feesChanged = true;
155
277
  }
156
278
 
157
279
  // update processing fee if required
158
- if(!FeeLib.eq(productInfo.processingFee, processingFee)) {
159
- _logUpdateFee(productNftId, "ProcessingFee", productInfo.processingFee, processingFee);
160
- productInfo.processingFee = processingFee;
280
+ if(!FeeLib.eq(feeInfo.processingFee, processingFee)) {
281
+ _logUpdateFee(productNftId, "ProcessingFee", feeInfo.processingFee, processingFee);
282
+ feeInfo.processingFee = processingFee;
161
283
  feesChanged = true;
162
284
  }
163
285
 
164
286
  if(feesChanged) {
165
- instance.getInstanceStore().updateProduct(productNftId, productInfo, KEEP_STATE());
287
+ instance.getProductStore().updateFee(productNftId, feeInfo);
166
288
  emit LogComponentServiceProductFeesUpdated(productNftId);
167
289
  }
168
290
  }
169
291
 
170
- function increaseProductFees(
171
- InstanceStore instanceStore,
172
- NftId productNftId,
173
- Amount feeAmount
174
- )
175
- external
176
- virtual
177
- // TODO re-enable once role granting is stable and fixed
178
- // restricted()
292
+
293
+ function _createProduct(
294
+ ProductStore productStore,
295
+ NftId productNftId,
296
+ address productAddress
297
+ )
298
+ internal
299
+ virtual
179
300
  {
180
- _changeTargetBalance(INCREASE, instanceStore, productNftId, AmountLib.zero(), feeAmount);
181
- }
301
+ // create product in instance instanceStore
302
+ IProductComponent product = IProductComponent(productAddress);
303
+ IComponents.ProductInfo memory initialProductInfo = product.getInitialProductInfo();
304
+ // force initialization of linked components with empty values to
305
+ // ensure no components are linked upon initialization of the product
306
+ initialProductInfo.poolNftId = NftIdLib.zero();
307
+ initialProductInfo.distributionNftId = NftIdLib.zero();
308
+ initialProductInfo.oracleNftId = new NftId[](initialProductInfo.expectedNumberOfOracles);
182
309
 
310
+ // create info
311
+ productStore.createProduct(
312
+ productNftId,
313
+ initialProductInfo);
183
314
 
184
- function decreaseProductFees(InstanceStore instanceStore, NftId productNftId, Amount feeAmount)
185
- external
186
- virtual
187
- // TODO re-enable once role granting is stable and fixed
188
- // restricted()
189
- {
190
- _changeTargetBalance(DECREASE, instanceStore, productNftId, AmountLib.zero(), feeAmount);
315
+ productStore.createFee(
316
+ productNftId,
317
+ product.getInitialFeeInfo());
191
318
  }
192
319
 
193
320
  //-------- distribution -------------------------------------------------//
194
321
 
195
322
  /// @dev registers the sending component as a distribution component
196
- function registerDistribution()
197
- external
323
+ function _createDistribution(
324
+ ProductStore productStore,
325
+ NftId productNftId,
326
+ NftId distributionNftId,
327
+ IComponents.ProductInfo memory productInfo
328
+ )
329
+ internal
198
330
  virtual
331
+ nonReentrant()
199
332
  {
200
- address contractAddress = msg.sender;
201
- RoleId[] memory roles = new RoleId[](2);
202
- bytes4[][] memory selectors = new bytes4[][](2);
203
-
204
- // authorizaion for distribution owner
205
- roles[0] = DISTRIBUTION_OWNER_ROLE();
206
- selectors[0] = _createSelectors(IDistributionComponent.setFees.selector);
207
-
208
- // authorizaion for product service
209
- roles[1] = PRODUCT_SERVICE_ROLE();
210
- selectors[1] = _createSelectors(IDistributionComponent.processRenewal.selector);
211
-
212
- // register/create component info
213
- _register(
214
- contractAddress,
215
- DISTRIBUTION(),
216
- DISTRIBUTION_OWNER_ROLE(),
217
- roles,
218
- selectors);
333
+ // check product is still expecting a distribution registration
334
+ if (!productInfo.hasDistribution) {
335
+ revert ErrorProductServiceNoDistributionExpected(productNftId);
336
+ }
337
+ if (productInfo.distributionNftId.gtz()) {
338
+ revert ErrorProductServiceDistributionAlreadyRegistered(productNftId, productInfo.distributionNftId);
339
+ }
340
+
341
+ // set distribution in product info
342
+ productInfo.distributionNftId = distributionNftId;
343
+ productStore.updateProduct(productNftId, productInfo, KEEP_STATE());
219
344
  }
220
345
 
221
346
 
@@ -225,118 +350,86 @@ contract ComponentService is
225
350
  )
226
351
  external
227
352
  virtual
353
+ restricted()
228
354
  {
229
- (NftId distributionNftId,, IInstance instance) = _getAndVerifyActiveComponent(DISTRIBUTION());
230
- (NftId productNftId, IComponents.ProductInfo memory productInfo) = _getLinkedProductInfo(
355
+ (NftId distributionNftId, IInstance instance) = _getAndVerifyComponent(DISTRIBUTION(), true);
356
+ (NftId productNftId, IComponents.FeeInfo memory feeInfo) = _getLinkedFeeInfo(
231
357
  instance.getInstanceReader(), distributionNftId);
232
358
  bool feesChanged = false;
233
359
 
234
360
  // update distributino fee if required
235
- if(!FeeLib.eq(productInfo.distributionFee, distributionFee)) {
236
- _logUpdateFee(productNftId, "DistributionFee", productInfo.distributionFee, distributionFee);
237
- productInfo.distributionFee = distributionFee;
361
+ if(!FeeLib.eq(feeInfo.distributionFee, distributionFee)) {
362
+ _logUpdateFee(productNftId, "DistributionFee", feeInfo.distributionFee, distributionFee);
363
+ feeInfo.distributionFee = distributionFee;
238
364
  feesChanged = true;
239
365
  }
240
366
 
241
367
  // update min distribution owner fee if required
242
- if(!FeeLib.eq(productInfo.minDistributionOwnerFee, minDistributionOwnerFee)) {
243
- _logUpdateFee(productNftId, "MinDistributionOwnerFee", productInfo.minDistributionOwnerFee, minDistributionOwnerFee);
244
- productInfo.minDistributionOwnerFee = minDistributionOwnerFee;
368
+ if(!FeeLib.eq(feeInfo.minDistributionOwnerFee, minDistributionOwnerFee)) {
369
+ _logUpdateFee(productNftId, "MinDistributionOwnerFee", feeInfo.minDistributionOwnerFee, minDistributionOwnerFee);
370
+ feeInfo.minDistributionOwnerFee = minDistributionOwnerFee;
245
371
  feesChanged = true;
246
372
  }
247
373
 
248
374
  if(feesChanged) {
249
- instance.getInstanceStore().updateProduct(productNftId, productInfo, KEEP_STATE());
375
+ instance.getProductStore().updateFee(productNftId, feeInfo);
250
376
  emit LogComponentServiceDistributionFeesUpdated(distributionNftId);
251
377
  }
252
378
  }
253
379
 
254
- function increaseDistributionBalance(
255
- InstanceStore instanceStore,
256
- NftId distributionNftId,
257
- Amount amount,
258
- Amount feeAmount
259
- )
260
- external
261
- virtual
262
- // TODO re-enable once role granting is stable and fixed
263
- // restricted()
264
- {
265
- _changeTargetBalance(INCREASE, instanceStore, distributionNftId, amount, feeAmount);
266
- }
267
-
268
-
269
- function decreaseDistributionBalance(
270
- InstanceStore instanceStore,
271
- NftId distributionNftId,
272
- Amount amount,
273
- Amount feeAmount
274
- )
275
- external
276
- virtual
277
- // TODO re-enable once role granting is stable and fixed
278
- // restricted()
279
- {
280
- _changeTargetBalance(DECREASE, instanceStore, distributionNftId, amount, feeAmount);
281
- }
282
-
283
380
  //-------- oracle -------------------------------------------------------//
284
381
 
285
- function registerOracle()
286
- external
382
+ function _createOracle(
383
+ ProductStore productStore,
384
+ NftId productNftId,
385
+ NftId oracleNftId,
386
+ IComponents.ProductInfo memory productInfo
387
+ )
388
+ internal
287
389
  virtual
288
390
  {
289
- address contractAddress = msg.sender;
290
- RoleId[] memory roles = new RoleId[](0);
291
- bytes4[][] memory selectors = new bytes4[][](0);
391
+ // check product is still expecting an oracle registration
392
+ if (productInfo.expectedNumberOfOracles == 0) {
393
+ revert ErrorProductServiceNoOraclesExpected(productNftId);
394
+ }
395
+ if (productInfo.numberOfOracles == productInfo.expectedNumberOfOracles) {
396
+ revert ErrorProductServiceOraclesAlreadyRegistered(productNftId, productInfo.expectedNumberOfOracles);
397
+ }
292
398
 
293
- // register/create component setup
294
- (
295
- , // instance reader
296
- InstanceStore instanceStore,
297
- NftId componentNftId
298
- ) = _register(
299
- contractAddress,
300
- ORACLE(),
301
- ORACLE_OWNER_ROLE(),
302
- roles,
303
- selectors);
399
+ // update/add oracle to product info
400
+ productInfo.oracleNftId[productInfo.numberOfOracles] = oracleNftId;
401
+ productInfo.numberOfOracles++;
402
+ productStore.updateProduct(productNftId, productInfo, KEEP_STATE());
304
403
  }
305
404
 
306
405
  //-------- pool ---------------------------------------------------------//
307
406
 
308
- function registerPool()
309
- external
407
+ function _createPool(
408
+ InstanceStore instanceStore,
409
+ ProductStore productStore,
410
+ NftId productNftId,
411
+ NftId poolNftId,
412
+ address componentAddress,
413
+ IComponents.ProductInfo memory productInfo
414
+ )
415
+ internal
310
416
  virtual
311
417
  {
312
- address contractAddress = msg.sender;
313
- RoleId[] memory roles = new RoleId[](2);
314
- bytes4[][] memory selectors = new bytes4[][](2);
315
-
316
- // authorizaion for pool owner
317
- roles[0] = POOL_OWNER_ROLE();
318
- selectors[0] = _createSelectors(IPoolComponent.setFees.selector);
319
-
320
- // authorizaion for product service
321
- roles[1] = POLICY_SERVICE_ROLE();
322
- selectors[1] = _createSelectors(IPoolComponent.verifyApplication.selector);
323
-
324
- // register/create component setup
325
- (
326
- , // instance reader
327
- InstanceStore instanceStore,
328
- NftId componentNftId
329
- ) = _register(
330
- contractAddress,
331
- POOL(),
332
- POOL_OWNER_ROLE(),
333
- roles,
334
- selectors);
418
+ // check product is still expecting a pool registration
419
+ //IComponents.ProductInfo memory productInfo = instanceReader.getProductInfo(productNftId);
420
+ if (productInfo.poolNftId.gtz()) {
421
+ revert ErrorProductServicePoolAlreadyRegistered(productNftId, productInfo.poolNftId);
422
+ }
335
423
 
336
424
  // create info
425
+ IPoolComponent pool = IPoolComponent(componentAddress);
337
426
  instanceStore.createPool(
338
- componentNftId,
339
- IPoolComponent(contractAddress).getInitialPoolInfo());
427
+ poolNftId,
428
+ pool.getInitialPoolInfo());
429
+
430
+ // update pool in product info
431
+ productInfo.poolNftId = poolNftId;
432
+ productStore.updateProduct(productNftId, productInfo, KEEP_STATE());
340
433
  }
341
434
 
342
435
 
@@ -347,189 +440,146 @@ contract ComponentService is
347
440
  )
348
441
  external
349
442
  virtual
443
+ restricted()
350
444
  {
351
- (NftId poolNftId,, IInstance instance) = _getAndVerifyActiveComponent(POOL());
352
- (NftId productNftId, IComponents.ProductInfo memory productInfo) = _getLinkedProductInfo(
445
+ (NftId poolNftId, IInstance instance) = _getAndVerifyComponent(POOL(), true);
446
+
447
+ (NftId productNftId, IComponents.FeeInfo memory feeInfo) = _getLinkedFeeInfo(
353
448
  instance.getInstanceReader(), poolNftId);
354
449
  bool feesChanged = false;
355
450
 
356
451
  // update pool fee if required
357
- if(!FeeLib.eq(productInfo.poolFee, poolFee)) {
358
- _logUpdateFee(productNftId, "PoolFee", productInfo.poolFee, poolFee);
359
- productInfo.poolFee = poolFee;
452
+ if(!FeeLib.eq(feeInfo.poolFee, poolFee)) {
453
+ _logUpdateFee(productNftId, "PoolFee", feeInfo.poolFee, poolFee);
454
+ feeInfo.poolFee = poolFee;
360
455
  feesChanged = true;
361
456
  }
362
457
 
363
458
  // update staking fee if required
364
- if(!FeeLib.eq(productInfo.stakingFee, stakingFee)) {
365
- _logUpdateFee(productNftId, "StakingFee", productInfo.stakingFee, stakingFee);
366
- productInfo.stakingFee = stakingFee;
459
+ if(!FeeLib.eq(feeInfo.stakingFee, stakingFee)) {
460
+ _logUpdateFee(productNftId, "StakingFee", feeInfo.stakingFee, stakingFee);
461
+ feeInfo.stakingFee = stakingFee;
367
462
  feesChanged = true;
368
463
  }
369
464
 
370
465
  // update performance fee if required
371
- if(!FeeLib.eq(productInfo.performanceFee, performanceFee)) {
372
- _logUpdateFee(productNftId, "PerformanceFee", productInfo.performanceFee, performanceFee);
373
- productInfo.performanceFee = performanceFee;
466
+ if(!FeeLib.eq(feeInfo.performanceFee, performanceFee)) {
467
+ _logUpdateFee(productNftId, "PerformanceFee", feeInfo.performanceFee, performanceFee);
468
+ feeInfo.performanceFee = performanceFee;
374
469
  feesChanged = true;
375
470
  }
376
471
 
377
472
  if(feesChanged) {
378
- instance.getInstanceStore().updateProduct(productNftId, productInfo, KEEP_STATE());
473
+ instance.getProductStore().updateFee(productNftId, feeInfo);
379
474
  emit LogComponentServicePoolFeesUpdated(poolNftId);
380
475
  }
381
476
  }
382
477
 
383
- function increasePoolBalance(
384
- InstanceStore instanceStore,
385
- NftId poolNftId,
386
- Amount amount,
387
- Amount feeAmount
388
- )
389
- public
390
- virtual
391
- // TODO re-enable once role granting is stable and fixed
392
- // restricted()
393
- {
394
- _changeTargetBalance(INCREASE, instanceStore, poolNftId, amount, feeAmount);
395
- }
396
-
397
- function decreasePoolBalance(
398
- InstanceStore instanceStore,
399
- NftId poolNftId,
400
- Amount amount,
401
- Amount feeAmount
402
- )
403
- public
404
- virtual
405
- // TODO re-enable once role granting is stable and fixed
406
- // restricted()
407
- {
408
- _changeTargetBalance(DECREASE, instanceStore, poolNftId, amount, feeAmount);
409
- }
410
478
 
411
- //-------- bundle -------------------------------------------------------//
412
-
413
- function increaseBundleBalance(
414
- InstanceStore instanceStore,
415
- NftId bundleNftId,
416
- Amount amount,
417
- Amount feeAmount
418
- )
419
- external
420
- virtual
421
- // TODO re-enable once role granting is stable and fixed
422
- // restricted()
423
- {
424
- _changeTargetBalance(INCREASE, instanceStore, bundleNftId, amount, feeAmount);
425
- }
426
-
427
- function decreaseBundleBalance(
428
- InstanceStore instanceStore,
429
- NftId bundleNftId,
430
- Amount amount,
431
- Amount feeAmount
479
+ /// @dev Registers the component represented by the provided address.
480
+ /// The caller must ensure componentAddress is IInstanceLinkedComponent.
481
+ function _verifyAndRegister(
482
+ IInstance instance,
483
+ address componentAddress,
484
+ NftId parentNftId,
485
+ address token
432
486
  )
433
- external
487
+ internal
434
488
  virtual
435
- // TODO re-enable once role granting is stable and fixed
436
- // restricted()
489
+ returns (NftId componentNftId)
437
490
  {
438
- _changeTargetBalance(DECREASE, instanceStore, bundleNftId, amount, feeAmount);
439
- }
440
-
491
+ (
492
+ IInstanceLinkedComponent component,
493
+ IRegistry.ObjectInfo memory objectInfo // initial component info
494
+ ) = _getAndVerifyRegisterableComponent(
495
+ componentAddress,
496
+ parentNftId);
441
497
 
442
- //-------- internal functions ------------------------------------------//
498
+ InstanceStore instanceStore = instance.getInstanceStore();
499
+ ObjectType componentType = objectInfo.objectType;
443
500
 
444
- function _changeTargetBalance(
445
- bool increase,
446
- InstanceStore instanceStore,
447
- NftId targetNftId,
448
- Amount amount,
449
- Amount feeAmount
450
- )
451
- internal
452
- virtual
453
- {
454
- Amount totalAmount = amount + feeAmount;
501
+ if(componentType == PRODUCT()) {
502
+ // register product with registry
503
+ componentNftId = _registryService.registerProduct(
504
+ component,
505
+ objectInfo.initialOwner).nftId;
455
506
 
456
- if(increase) {
457
- if(totalAmount.gtz()) { instanceStore.increaseBalance(targetNftId, totalAmount); }
458
- if(feeAmount.gtz()) { instanceStore.increaseFees(targetNftId, feeAmount); }
507
+ // create product info in instance store
508
+ _createProduct(instance.getProductStore(), componentNftId, componentAddress);
459
509
  } else {
460
- if(totalAmount.gtz()) { instanceStore.decreaseBalance(targetNftId, totalAmount); }
461
- if(feeAmount.gtz()) { instanceStore.decreaseFees(targetNftId, feeAmount); }
510
+ // register non product component with registry
511
+ componentNftId = _registryService.registerProductLinkedComponent(
512
+ component,
513
+ objectInfo.objectType,
514
+ objectInfo.initialOwner).nftId;
515
+
516
+ InstanceReader instanceReader = instance.getInstanceReader();
517
+
518
+ // create non product component info in instance store
519
+ NftId productNftId = parentNftId;
520
+ IComponents.ProductInfo memory productInfo = instanceReader.getProductInfo(productNftId);
521
+ if(componentType == POOL()) {
522
+ _createPool(instanceStore, instance.getProductStore(), productNftId, componentNftId, componentAddress, productInfo);
523
+ } else if(componentType == DISTRIBUTION()) {
524
+ _createDistribution(instance.getProductStore(), productNftId, componentNftId, productInfo);
525
+ } else if(componentType == ORACLE()) {
526
+ _createOracle(instance.getProductStore(), productNftId, componentNftId, productInfo);
527
+ } else {
528
+ revert ErrorComponentServiceComponentTypeNotSupported(componentAddress, componentType);
529
+ }
530
+
531
+ // get product's token
532
+ token = address(instanceReader.getTokenHandler(productNftId).TOKEN());
462
533
  }
463
- }
464
534
 
465
- /// @dev registers the component represented by the provided address
466
- function _register(
467
- address componentAddress, // address of component to register
468
- ObjectType requiredType, // required type for component for registration
469
- RoleId requiredRole, // role required for comonent owner for registration
470
- RoleId[] memory roles, // roles with write access to component
471
- bytes4[][] memory selectors // authorized functions per role with write access
472
- )
473
- internal
474
- virtual
475
- returns (
476
- InstanceReader instanceReader,
477
- InstanceStore instanceStore,
478
- NftId componentNftId
479
- )
480
- {
481
- (
482
- IInstance instance,
483
- IInstanceLinkedComponent component,
484
- address owner
485
- ) = _getAndVerifyRegisterableComponent(
486
- componentAddress,
487
- requiredType,
488
- requiredRole);
535
+ _checkToken(instance, token);
489
536
 
490
- // register component with registry
491
- componentNftId = _registryService.registerComponent(
492
- component,
493
- requiredType,
494
- owner).nftId;
537
+ InstanceAdmin instanceAdmin = instance.getInstanceAdmin();
538
+
539
+ // deploy and wire token handler
540
+ IComponents.ComponentInfo memory componentInfo = component.getInitialComponentInfo();
541
+ componentInfo.tokenHandler = TokenHandlerDeployerLib.deployTokenHandler(
542
+ address(getRegistry()),
543
+ address(component), // initially, component is its own wallet
544
+ token,
545
+ instanceAdmin.authority());
546
+
547
+ // register component with instance
548
+ instanceStore.createComponent(
549
+ componentNftId,
550
+ componentInfo);
495
551
 
552
+ // link component contract to nft id
496
553
  component.linkToRegisteredNftId();
497
554
 
498
- // save amended component info with instance
499
- instanceReader = instance.getInstanceReader();
500
- instanceStore = instance.getInstanceStore();
501
-
502
- IComponents.ComponentInfo memory componentInfo = component.getComponentInfo();
503
- componentInfo.tokenHandler = new TokenHandler(address(componentInfo.token));
504
- instanceStore.createComponent(component.getNftId(), componentInfo);
555
+ // authorize
556
+ instanceAdmin.initializeComponentAuthorization(componentAddress, componentType);
505
557
 
506
- // configure instance authorization
507
- _instanceService.createComponentTarget(
508
- instance.getNftId(),
509
- componentAddress,
510
- component.getName(),
511
- selectors,
512
- roles);
558
+ emit LogComponentServiceRegistered(
559
+ instance.getNftId(),
560
+ componentNftId,
561
+ componentType,
562
+ address(component),
563
+ token,
564
+ objectInfo.initialOwner);
513
565
  }
514
566
 
515
567
 
516
- /// @dev link the component info corresponding to the componentNftId to the provided productNftId
517
- function _linkToProduct(
518
- InstanceReader instanceReader,
519
- InstanceStore instanceStore,
520
- NftId componentNftId,
521
- NftId productNftId
522
- )
568
+ function _checkToken(IInstance instance, address token)
523
569
  internal
570
+ view
524
571
  {
525
- // only link components that are registered
526
- if(componentNftId.eqz()) {
527
- return;
572
+ if (! instance.isTokenRegistryDisabled()) {
573
+ // check if provided token is whitelisted and active
574
+ if (!ContractLib.isActiveToken(
575
+ getRegistry().getTokenRegistryAddress(),
576
+ ChainIdLib.current(),
577
+ token,
578
+ AccessManagerCloneable(authority()).getRelease())
579
+ ) {
580
+ revert ErrorComponentServiceTokenInvalid(token);
581
+ }
528
582
  }
529
-
530
- IComponents.ComponentInfo memory componentInfo = instanceReader.getComponentInfo(componentNftId);
531
- componentInfo.productNftId = productNftId;
532
- instanceStore.updateComponent(componentNftId, componentInfo, KEEP_STATE());
533
583
  }
534
584
 
535
585
 
@@ -548,13 +598,7 @@ contract ComponentService is
548
598
  }
549
599
 
550
600
 
551
- function _createSelectors(bytes4 selector) internal pure returns (bytes4[] memory selectors) {
552
- selectors = new bytes4[](1);
553
- selectors[0] = selector;
554
- }
555
-
556
-
557
- function _getLinkedProductInfo(
601
+ function _getLinkedFeeInfo(
558
602
  InstanceReader instanceReader,
559
603
  NftId componentNftId
560
604
  )
@@ -562,57 +606,86 @@ contract ComponentService is
562
606
  view
563
607
  returns(
564
608
  NftId productNftId,
565
- IComponents.ProductInfo memory info
609
+ IComponents.FeeInfo memory info
566
610
  )
567
611
  {
568
- productNftId = instanceReader.getComponentInfo(componentNftId).productNftId;
569
- info = instanceReader.getProductInfo(productNftId);
612
+ productNftId = getRegistry().getParentNftId(componentNftId);
613
+ info = instanceReader.getFeeInfo(productNftId);
570
614
  }
571
615
 
572
616
 
573
- /// @dev based on the provided component address required type and role returns the component and related instance contract
574
- /// the function reverts iff:
617
+ /// @dev Based on the provided component address required type the component
618
+ /// and related instance contract this function reverts iff:
619
+ /// - the component parent does not match with the required parent
620
+ /// - the component release does not match with the service release
575
621
  /// - the component has already been registered
576
- /// - the component contract does not support IInstanceLinkedComponent
577
- /// - the component type does not match with the required type
578
- /// - the initial component owner misses the required role (with the instance access manager)
579
622
  function _getAndVerifyRegisterableComponent(
580
623
  address componentAddress,
581
- ObjectType requiredType,
582
- RoleId requiredRole
624
+ NftId requiredParent
583
625
  )
584
626
  internal
585
627
  view
586
628
  returns (
587
- IInstance instance,
588
629
  IInstanceLinkedComponent component,
589
- address owner
630
+ IRegistry.ObjectInfo memory info
590
631
  )
591
632
  {
592
- // check this is a component
593
633
  component = IInstanceLinkedComponent(componentAddress);
594
- if(!component.supportsInterface(type(IInstanceLinkedComponent).interfaceId)) {
595
- revert ErrorComponentServiceNotComponent(componentAddress);
634
+ info = component.getInitialInfo();
635
+
636
+ // check component parent
637
+ if(info.parentNftId != requiredParent) {
638
+ revert ErrorComponentServiceComponentParentInvalid(componentAddress, requiredParent, info.parentNftId);
596
639
  }
597
640
 
598
- // check component is of required type
599
- IRegistry.ObjectInfo memory info = component.getInitialInfo();
600
- if(info.objectType != requiredType) {
601
- revert ErrorComponentServiceInvalidType(componentAddress, requiredType, info.objectType);
641
+ // check component release (must match with service release)
642
+ if(component.getRelease() != getRelease()) {
643
+ revert ErrorComponentServiceComponentReleaseMismatch(componentAddress, getRelease(), component.getRelease());
602
644
  }
603
645
 
604
646
  // check component has not already been registered
605
- if (getRegistry().getNftId(componentAddress).gtz()) {
606
- revert ErrorComponentServiceAlreadyRegistered(componentAddress);
647
+ if (getRegistry().getNftIdForAddress(componentAddress).gtz()) {
648
+ revert ErrorComponentServiceComponentAlreadyRegistered(componentAddress);
607
649
  }
650
+ }
651
+
652
+
653
+ function _setLocked(InstanceAdmin instanceAdmin, address componentAddress, bool locked) internal {
654
+ instanceAdmin.setTargetLocked(componentAddress, locked);
655
+ }
608
656
 
609
- // check instance has assigned required role to inital owner
610
- instance = _getInstance(info.parentNftId);
611
- owner = info.initialOwner;
612
657
 
613
- (bool hasRole,) = instance.getInstanceAccessManager().hasRole(requiredRole.toInt(), owner);
614
- if(!hasRole) {
615
- revert ErrorComponentServiceExpectedRoleMissing(info.parentNftId, requiredRole, owner);
658
+ function _getAndVerifyComponent(ObjectType expectedType, bool isActive)
659
+ internal
660
+ view
661
+ returns (
662
+ NftId componentNftId,
663
+ IInstance instance
664
+ )
665
+ {
666
+ IRegistry.ObjectInfo memory info;
667
+ address instanceAddress;
668
+
669
+ if (expectedType != COMPONENT()) {
670
+ (info, instanceAddress) = ContractLib.getAndVerifyComponent(
671
+ getRegistry(),
672
+ msg.sender, // caller
673
+ expectedType,
674
+ isActive);
675
+ } else {
676
+ (info, instanceAddress) = ContractLib.getAndVerifyAnyComponent(
677
+ getRegistry(),
678
+ msg.sender,
679
+ isActive);
616
680
  }
681
+
682
+ // get component nft id and instance
683
+ componentNftId = info.nftId;
684
+ instance = IInstance(instanceAddress);
685
+ }
686
+
687
+
688
+ function _getDomain() internal pure virtual override returns(ObjectType) {
689
+ return COMPONENT();
617
690
  }
618
691
  }