@etherisc/gif-next 0.0.2-c16a73d-613 → 0.0.2-c2496d8-605

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