@etherisc/gif-next 0.0.2-8bdd2eb-413 → 0.0.2-8c6c3ef-628

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