@etherisc/gif-next 0.0.2-a6ce659-551 → 0.0.2-a6d7b34-014

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