@etherisc/gif-next 0.0.2-b3a9c97-695 → 0.0.2-b3b68b6-318

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