@etherisc/gif-next 0.0.2-750c7cb-311 → 0.0.2-7560591-936

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 (530) hide show
  1. package/README.md +85 -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 +496 -255
  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 +277 -20
  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 +395 -203
  21. package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +1 -1
  22. package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +143 -19
  23. package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +1 -1
  24. package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.json +19 -0
  25. package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +1 -1
  26. package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +68 -5
  27. package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +1 -1
  28. package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +158 -467
  29. package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +1 -1
  30. package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +265 -31
  31. package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
  32. package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +89 -355
  33. package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
  34. package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +382 -359
  35. package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
  36. package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +143 -129
  37. package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
  38. package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +84 -198
  39. package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
  40. package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +252 -126
  41. package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.dbg.json +4 -0
  42. package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.json +22 -0
  43. package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.dbg.json +4 -0
  44. package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.json +1445 -0
  45. package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +4 -0
  46. package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +644 -0
  47. package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +4 -0
  48. package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +2002 -0
  49. package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +4 -0
  50. package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +644 -0
  51. package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.dbg.json +4 -0
  52. package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.json +376 -0
  53. package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.dbg.json +4 -0
  54. package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.json +1388 -0
  55. package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.dbg.json +4 -0
  56. package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.json +644 -0
  57. package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +4 -0
  58. package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +1152 -0
  59. package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +4 -0
  60. package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +1612 -0
  61. package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.dbg.json +4 -0
  62. package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.json +644 -0
  63. package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +4 -0
  64. package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +2389 -0
  65. package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.dbg.json +4 -0
  66. package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.json +644 -0
  67. package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +1 -1
  68. package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +193 -45
  69. package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
  70. package/artifacts/contracts/instance/IInstance.sol/IInstance.json +236 -39
  71. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
  72. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +144 -93
  73. package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
  74. package/artifacts/contracts/instance/Instance.sol/Instance.json +256 -123
  75. package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
  76. package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +737 -327
  77. package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +1 -1
  78. package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +209 -94
  79. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
  80. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +1074 -309
  81. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
  82. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +172 -278
  83. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
  84. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +106 -106
  85. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
  86. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +897 -638
  87. package/artifacts/contracts/instance/RiskSet.sol/RiskSet.dbg.json +4 -0
  88. package/artifacts/contracts/instance/RiskSet.sol/RiskSet.json +853 -0
  89. package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +1 -1
  90. package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +2 -2
  91. package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +1 -1
  92. package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +1 -1
  93. package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +2 -2
  94. package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.dbg.json +1 -1
  95. package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.json +46 -5
  96. package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.dbg.json +1 -1
  97. package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.json +16 -5
  98. package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.dbg.json +4 -0
  99. package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.json +168 -0
  100. package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
  101. package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +1 -1
  102. package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
  103. package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
  104. package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
  105. package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +1 -1
  106. package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.dbg.json +1 -1
  107. package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.json +116 -333
  108. package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +1 -1
  109. package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +247 -33
  110. package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +1 -1
  111. package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +1 -1
  112. package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +91 -140
  113. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +1 -1
  114. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +69 -11
  115. package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +1 -1
  116. package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +92 -293
  117. package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +1 -1
  118. package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +153 -190
  119. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +1 -1
  120. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +132 -98
  121. package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +1 -1
  122. package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +132 -333
  123. package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +1 -1
  124. package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +265 -31
  125. package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
  126. package/artifacts/contracts/pool/BundleService.sol/BundleService.json +164 -424
  127. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
  128. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +116 -146
  129. package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
  130. package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +90 -148
  131. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
  132. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +122 -182
  133. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
  134. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +317 -300
  135. package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
  136. package/artifacts/contracts/pool/Pool.sol/Pool.json +120 -332
  137. package/artifacts/contracts/pool/PoolLib.sol/PoolLib.dbg.json +4 -0
  138. package/artifacts/contracts/pool/PoolLib.sol/PoolLib.json +456 -0
  139. package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
  140. package/artifacts/contracts/pool/PoolService.sol/PoolService.json +444 -570
  141. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
  142. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +134 -124
  143. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
  144. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +194 -178
  145. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
  146. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +110 -100
  147. package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +1 -1
  148. package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +254 -394
  149. package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +1 -1
  150. package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +265 -31
  151. package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
  152. package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +403 -246
  153. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
  154. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +147 -125
  155. package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
  156. package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +136 -9
  157. package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
  158. package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +293 -17
  159. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
  160. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +248 -83
  161. package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
  162. package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +157 -83
  163. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
  164. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +245 -233
  165. package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +4 -0
  166. package/artifacts/contracts/product/{IProductService.sol/IProductService.json → IRiskService.sol/IRiskService.json} +88 -8
  167. package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
  168. package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +316 -318
  169. package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.dbg.json +4 -0
  170. package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.json +293 -0
  171. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
  172. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +130 -116
  173. package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
  174. package/artifacts/contracts/product/PricingService.sol/PricingService.json +230 -336
  175. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
  176. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +119 -141
  177. package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
  178. package/artifacts/contracts/product/Product.sol/Product.json +246 -386
  179. package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +4 -0
  180. package/artifacts/contracts/product/RiskService.sol/RiskService.json +688 -0
  181. package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +4 -0
  182. package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +736 -0
  183. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
  184. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +59 -16
  185. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
  186. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +342 -42
  187. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
  188. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +144 -41
  189. package/artifacts/contracts/registry/IRelease.sol/IRelease.dbg.json +4 -0
  190. package/artifacts/contracts/registry/IRelease.sol/IRelease.json +24 -0
  191. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
  192. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +5 -18
  193. package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
  194. package/artifacts/contracts/registry/Registry.sol/Registry.json +548 -103
  195. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
  196. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +640 -368
  197. package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.dbg.json +4 -0
  198. package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.json +878 -0
  199. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
  200. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +109 -292
  201. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
  202. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +104 -90
  203. package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.dbg.json +4 -0
  204. package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.json +1954 -0
  205. package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +1 -1
  206. package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +47 -6
  207. package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +1 -1
  208. package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +431 -253
  209. package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +1 -1
  210. package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +66 -8
  211. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
  212. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +15 -15
  213. package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
  214. package/artifacts/contracts/shared/Component.sol/Component.json +80 -252
  215. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
  216. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +526 -682
  217. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
  218. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +142 -146
  219. package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +1 -1
  220. package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +57 -111
  221. package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +4 -0
  222. package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +597 -0
  223. package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.dbg.json +4 -0
  224. package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.json +24 -0
  225. package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.dbg.json +4 -0
  226. package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.json +30 -0
  227. package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.dbg.json +4 -0
  228. package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.json +40 -0
  229. package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
  230. package/artifacts/contracts/shared/IComponent.sol/IComponent.json +80 -100
  231. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
  232. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +463 -300
  233. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
  234. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +91 -140
  235. package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
  236. package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.json +36 -0
  237. package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +1 -1
  238. package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.json +36 -0
  239. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
  240. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +16 -0
  241. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
  242. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +15 -47
  243. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
  244. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +148 -0
  245. package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
  246. package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
  247. package/artifacts/contracts/shared/IService.sol/IService.json +55 -2
  248. package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.dbg.json +1 -1
  249. package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.json +2 -22
  250. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +1 -1
  251. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +91 -292
  252. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
  253. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +42 -1
  254. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
  255. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +42 -1
  256. package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.dbg.json +1 -1
  257. package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.json +2 -2
  258. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
  259. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +22 -57
  260. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
  261. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +19 -141
  262. package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
  263. package/artifacts/contracts/shared/Registerable.sol/Registerable.json +122 -97
  264. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
  265. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -15
  266. package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
  267. package/artifacts/contracts/shared/Service.sol/Service.json +57 -111
  268. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
  269. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +544 -18
  270. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.dbg.json +4 -0
  271. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.json +484 -0
  272. package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +4 -0
  273. package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +172 -0
  274. package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
  275. package/artifacts/contracts/staking/IStaking.sol/IStaking.json +196 -143
  276. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
  277. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +152 -20
  278. package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
  279. package/artifacts/contracts/staking/Staking.sol/Staking.json +287 -390
  280. package/artifacts/contracts/staking/StakingLib.sol/StakingLib.dbg.json +4 -0
  281. package/artifacts/contracts/staking/StakingLib.sol/StakingLib.json +469 -0
  282. package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.dbg.json +1 -1
  283. package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.json +46 -5
  284. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
  285. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +132 -113
  286. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
  287. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +41 -73
  288. package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
  289. package/artifacts/contracts/staking/StakingService.sol/StakingService.json +205 -168
  290. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
  291. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +113 -95
  292. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
  293. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +205 -150
  294. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
  295. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +90 -49
  296. package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +1 -1
  297. package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +1 -1
  298. package/artifacts/contracts/type/Amount.sol/AmountLib.json +35 -11
  299. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
  300. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +1 -1
  301. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +28 -4
  302. package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
  303. package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +2 -2
  304. package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +1 -1
  305. package/artifacts/contracts/type/Fee.sol/FeeLib.json +94 -38
  306. package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +1 -1
  307. package/artifacts/contracts/type/Key32.sol/Key32Lib.json +2 -2
  308. package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.dbg.json +4 -0
  309. package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.json +33 -0
  310. package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
  311. package/artifacts/contracts/type/NftId.sol/NftIdLib.json +23 -4
  312. package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
  313. package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +2 -2
  314. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
  315. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +33 -31
  316. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +1 -1
  317. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +19 -19
  318. package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +1 -1
  319. package/artifacts/contracts/type/Referral.sol/ReferralLib.json +2 -2
  320. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +1 -1
  321. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +2 -2
  322. package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +1 -1
  323. package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +125 -7
  324. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
  325. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +79 -15
  326. package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
  327. package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +26 -2
  328. package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +1 -1
  329. package/artifacts/contracts/type/Selector.sol/SelectorLib.json +21 -2
  330. package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +1 -1
  331. package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +2 -2
  332. package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
  333. package/artifacts/contracts/type/StateId.sol/StateIdLib.json +15 -2
  334. package/artifacts/contracts/type/String.sol/StrLib.dbg.json +1 -1
  335. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
  336. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +2 -2
  337. package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
  338. package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +73 -36
  339. package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +1 -1
  340. package/artifacts/contracts/type/Version.sol/VersionLib.json +2 -21
  341. package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +1 -1
  342. package/artifacts/contracts/type/Version.sol/VersionPartLib.json +101 -2
  343. package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.dbg.json +1 -1
  344. package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.dbg.json +1 -1
  345. package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +81 -80
  346. package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
  347. package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +15 -2
  348. package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +1 -1
  349. package/contracts/accounting/AccountingService.sol +262 -0
  350. package/contracts/accounting/AccountingServiceManager.sol +38 -0
  351. package/contracts/accounting/IAccountingService.sol +45 -0
  352. package/contracts/authorization/AccessAdmin.sol +338 -225
  353. package/contracts/authorization/AccessAdminLib.sol +183 -0
  354. package/contracts/authorization/AccessManagerCloneable.sol +146 -4
  355. package/contracts/authorization/Authorization.sol +350 -203
  356. package/contracts/authorization/IAccess.sol +13 -4
  357. package/contracts/authorization/IAccessAdmin.sol +69 -35
  358. package/contracts/authorization/IAuthorization.sol +33 -7
  359. package/contracts/authorization/IServiceAuthorization.sol +3 -1
  360. package/contracts/authorization/ServiceAuthorization.sol +26 -10
  361. package/contracts/distribution/BasicDistribution.sol +20 -17
  362. package/contracts/distribution/BasicDistributionAuthorization.sol +22 -9
  363. package/contracts/distribution/Distribution.sol +37 -88
  364. package/contracts/distribution/DistributionService.sol +167 -118
  365. package/contracts/distribution/DistributionServiceManager.sol +6 -6
  366. package/contracts/distribution/IDistributionComponent.sol +1 -10
  367. package/contracts/distribution/IDistributionService.sol +31 -25
  368. package/contracts/examples/fire/DamageLevel.sol +59 -0
  369. package/contracts/examples/fire/FirePool.sol +86 -0
  370. package/contracts/examples/fire/FirePoolAuthorization.sol +35 -0
  371. package/contracts/examples/fire/FireProduct.sol +433 -0
  372. package/contracts/examples/fire/FireProductAuthorization.sol +45 -0
  373. package/contracts/examples/fire/FireUSD.sol +26 -0
  374. package/contracts/examples/unpermissioned/SimpleDistribution.sol +81 -0
  375. package/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol +28 -0
  376. package/contracts/examples/unpermissioned/SimpleOracle.sol +133 -0
  377. package/contracts/examples/unpermissioned/SimplePool.sol +102 -0
  378. package/contracts/examples/unpermissioned/SimplePoolAuthorization.sol +28 -0
  379. package/contracts/examples/unpermissioned/SimpleProduct.sol +373 -0
  380. package/contracts/examples/unpermissioned/SimpleProductAuthorization.sol +28 -0
  381. package/contracts/instance/BundleSet.sol +42 -38
  382. package/contracts/instance/IInstance.sol +64 -44
  383. package/contracts/instance/IInstanceService.sol +27 -31
  384. package/contracts/instance/Instance.sol +120 -70
  385. package/contracts/instance/InstanceAdmin.sol +287 -103
  386. package/contracts/instance/InstanceAuthorizationV3.sol +92 -61
  387. package/contracts/instance/InstanceReader.sol +281 -39
  388. package/contracts/instance/InstanceService.sol +207 -191
  389. package/contracts/instance/InstanceServiceManager.sol +6 -7
  390. package/contracts/instance/InstanceStore.sol +23 -2
  391. package/contracts/instance/RiskSet.sol +118 -0
  392. package/contracts/instance/base/ObjectCounter.sol +1 -2
  393. package/contracts/instance/base/ObjectLifecycle.sol +10 -1
  394. package/contracts/instance/base/ObjectSet.sol +31 -33
  395. package/contracts/instance/base/ObjectSetHelperLib.sol +30 -0
  396. package/contracts/instance/module/IBundle.sol +6 -5
  397. package/contracts/instance/module/IComponents.sol +29 -13
  398. package/contracts/instance/module/IDistribution.sol +21 -8
  399. package/contracts/instance/module/IPolicy.sol +49 -28
  400. package/contracts/instance/module/IRisk.sol +5 -0
  401. package/contracts/oracle/BasicOracle.sol +1 -4
  402. package/contracts/oracle/BasicOracleAuthorization.sol +3 -12
  403. package/contracts/oracle/IOracle.sol +9 -4
  404. package/contracts/oracle/IOracleService.sol +2 -1
  405. package/contracts/oracle/Oracle.sol +7 -19
  406. package/contracts/oracle/OracleService.sol +113 -81
  407. package/contracts/oracle/OracleServiceManager.sol +6 -6
  408. package/contracts/pool/BasicPool.sol +32 -25
  409. package/contracts/pool/BasicPoolAuthorization.sol +27 -9
  410. package/contracts/pool/BundleService.sol +93 -148
  411. package/contracts/pool/BundleServiceManager.sol +6 -6
  412. package/contracts/pool/IBundleService.sol +16 -36
  413. package/contracts/pool/IPoolComponent.sol +19 -15
  414. package/contracts/pool/IPoolService.sol +86 -70
  415. package/contracts/pool/Pool.sol +139 -124
  416. package/contracts/pool/PoolLib.sol +216 -0
  417. package/contracts/pool/PoolService.sol +497 -301
  418. package/contracts/pool/PoolServiceManager.sol +4 -4
  419. package/contracts/product/ApplicationService.sol +87 -43
  420. package/contracts/product/ApplicationServiceManager.sol +4 -4
  421. package/contracts/product/BasicProduct.sol +10 -13
  422. package/contracts/product/BasicProductAuthorization.sol +24 -11
  423. package/contracts/product/ClaimService.sol +364 -156
  424. package/contracts/product/ClaimServiceManager.sol +4 -4
  425. package/contracts/product/IApplicationService.sol +9 -2
  426. package/contracts/product/IClaimService.sol +43 -8
  427. package/contracts/product/IPolicyService.sol +44 -34
  428. package/contracts/product/IPricingService.sol +11 -10
  429. package/contracts/product/IProductComponent.sol +27 -5
  430. package/contracts/product/{IProductService.sol → IRiskService.sol} +8 -8
  431. package/contracts/product/PolicyService.sol +408 -300
  432. package/contracts/product/PolicyServiceLib.sol +65 -0
  433. package/contracts/product/PolicyServiceManager.sol +4 -4
  434. package/contracts/product/PricingService.sol +69 -60
  435. package/contracts/product/PricingServiceManager.sol +4 -4
  436. package/contracts/product/Product.sol +153 -97
  437. package/contracts/product/RiskService.sol +154 -0
  438. package/contracts/product/RiskServiceManager.sol +39 -0
  439. package/contracts/registry/ChainNft.sol +72 -40
  440. package/contracts/registry/IRegistry.sol +64 -28
  441. package/contracts/registry/IRegistryService.sol +5 -12
  442. package/contracts/registry/IRelease.sol +29 -0
  443. package/contracts/registry/ITransferInterceptor.sol +1 -2
  444. package/contracts/registry/Registry.sol +357 -203
  445. package/contracts/registry/RegistryAdmin.sol +162 -269
  446. package/contracts/registry/RegistryAuthorization.sol +267 -0
  447. package/contracts/registry/RegistryService.sol +37 -48
  448. package/contracts/registry/RegistryServiceManager.sol +3 -3
  449. package/contracts/registry/ReleaseAdmin.sol +253 -0
  450. package/contracts/registry/ReleaseLifecycle.sol +8 -3
  451. package/contracts/registry/ReleaseRegistry.sol +272 -240
  452. package/contracts/registry/ServiceAuthorizationV3.sol +183 -52
  453. package/contracts/registry/TokenRegistry.sol +10 -9
  454. package/contracts/shared/Component.sol +66 -137
  455. package/contracts/shared/ComponentService.sol +436 -378
  456. package/contracts/shared/ComponentServiceManager.sol +8 -5
  457. package/contracts/shared/ComponentVerifyingService.sol +28 -17
  458. package/contracts/shared/ContractLib.sol +281 -0
  459. package/contracts/shared/IComponent.sol +5 -18
  460. package/contracts/shared/IComponentService.sol +44 -40
  461. package/contracts/shared/IInstanceLinkedComponent.sol +2 -28
  462. package/contracts/shared/ILifecycle.sol +3 -1
  463. package/contracts/shared/INftOwnable.sol +2 -0
  464. package/contracts/shared/IPolicyHolder.sol +12 -22
  465. package/contracts/shared/IRegisterable.sol +23 -1
  466. package/contracts/shared/IService.sol +3 -5
  467. package/contracts/shared/InitializableERC165.sol +10 -2
  468. package/contracts/shared/InstanceLinkedComponent.sol +73 -50
  469. package/contracts/shared/KeyValueStore.sol +1 -1
  470. package/contracts/shared/Lifecycle.sol +15 -4
  471. package/contracts/shared/NftOwnable.sol +29 -9
  472. package/contracts/shared/PolicyHolder.sol +15 -52
  473. package/contracts/shared/Registerable.sol +52 -21
  474. package/contracts/shared/RegistryLinked.sol +9 -14
  475. package/contracts/shared/Service.sol +15 -32
  476. package/contracts/shared/TokenHandler.sol +309 -29
  477. package/contracts/shared/TokenHandlerDeployerLib.sol +20 -0
  478. package/contracts/staking/IStaking.sol +25 -13
  479. package/contracts/staking/IStakingService.sol +16 -4
  480. package/contracts/staking/Staking.sol +103 -73
  481. package/contracts/staking/{StakeManagerLib.sol → StakingLib.sol} +95 -45
  482. package/contracts/staking/StakingManager.sol +8 -6
  483. package/contracts/staking/StakingReader.sol +18 -21
  484. package/contracts/staking/StakingService.sol +82 -25
  485. package/contracts/staking/StakingServiceManager.sol +6 -5
  486. package/contracts/staking/StakingStore.sol +2 -1
  487. package/contracts/staking/TargetManagerLib.sol +7 -3
  488. package/contracts/type/Amount.sol +15 -0
  489. package/contracts/type/ClaimId.sol +6 -1
  490. package/contracts/type/Fee.sol +8 -8
  491. package/contracts/type/Key32.sol +2 -2
  492. package/contracts/type/Key32Set.sol +62 -0
  493. package/contracts/type/NftId.sol +7 -0
  494. package/contracts/type/ObjectType.sol +57 -34
  495. package/contracts/type/PayoutId.sol +10 -10
  496. package/contracts/type/RiskId.sol +38 -6
  497. package/contracts/type/RoleId.sol +23 -15
  498. package/contracts/type/Seconds.sol +8 -0
  499. package/contracts/type/Selector.sol +5 -0
  500. package/contracts/type/StateId.sol +15 -1
  501. package/contracts/type/Timestamp.sol +0 -5
  502. package/contracts/type/UFixed.sol +37 -126
  503. package/contracts/type/Version.sol +54 -5
  504. package/contracts/upgradeability/ProxyManager.sol +79 -43
  505. package/contracts/upgradeability/UpgradableProxyWithAdmin.sol +7 -1
  506. package/contracts/upgradeability/Versionable.sol +2 -2
  507. package/package.json +5 -4
  508. package/artifacts/contracts/authorization/IModuleAuthorization.sol/IModuleAuthorization.dbg.json +0 -4
  509. package/artifacts/contracts/authorization/IModuleAuthorization.sol/IModuleAuthorization.json +0 -290
  510. package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.dbg.json +0 -4
  511. package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.json +0 -390
  512. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +0 -4
  513. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +0 -129
  514. package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +0 -4
  515. package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +0 -4
  516. package/artifacts/contracts/product/ProductService.sol/ProductService.json +0 -708
  517. package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
  518. package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +0 -702
  519. package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.dbg.json +0 -4
  520. package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.json +0 -39
  521. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +0 -4
  522. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +0 -470
  523. package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +0 -4
  524. package/artifacts/contracts/type/UFixed.sol/MathLib.json +0 -16
  525. package/contracts/authorization/IModuleAuthorization.sol +0 -21
  526. package/contracts/authorization/ModuleAuthorization.sol +0 -78
  527. package/contracts/instance/module/IAccess.sol +0 -46
  528. package/contracts/product/ProductService.sol +0 -99
  529. package/contracts/product/ProductServiceManager.sol +0 -39
  530. package/contracts/shared/InitializableCustom.sol +0 -177
@@ -1,45 +1,44 @@
1
1
  // SPDX-License-Identifier: Apache-2.0
2
2
  pragma solidity ^0.8.20;
3
3
 
4
- import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
5
-
4
+ import {IAccountingService} from "../accounting/IAccountingService.sol";
6
5
  import {IBundle} from "../instance/module/IBundle.sol";
7
6
  import {IBundleService} from "./IBundleService.sol";
8
7
  import {IComponents} from "../instance/module/IComponents.sol";
9
8
  import {IComponentService} from "../shared/IComponentService.sol";
10
9
  import {IInstance} from "../instance/IInstance.sol";
11
- import {IInstanceService} from "../instance/IInstanceService.sol";
12
10
  import {IPolicy} from "../instance/module/IPolicy.sol";
11
+ import {IPolicyHolder} from "../shared/IPolicyHolder.sol";
12
+ import {IPoolComponent} from "../pool/IPoolComponent.sol";
13
13
  import {IPoolService} from "./IPoolService.sol";
14
+ import {IProductComponent} from "../product/IProductComponent.sol";
14
15
  import {IRegistry} from "../registry/IRegistry.sol";
15
- import {IRegistryService} from "../registry/IRegistryService.sol";
16
16
  import {IStaking} from "../staking/IStaking.sol";
17
17
 
18
18
  import {Amount, AmountLib} from "../type/Amount.sol";
19
- import {Fee, FeeLib} from "../type/Fee.sol";
20
- import {NftId} from "../type/NftId.sol";
21
- import {ObjectType, POOL, BUNDLE, COMPONENT, INSTANCE, REGISTRY} from "../type/ObjectType.sol";
22
- import {RoleId, PUBLIC_ROLE} from "../type/RoleId.sol";
23
- import {Fee, FeeLib} from "../type/Fee.sol";
19
+ import {ClaimId} from "../type/ClaimId.sol";
20
+ import {ContractLib} from "../shared/ContractLib.sol";
21
+ import {InstanceReader} from "../instance/InstanceReader.sol";
22
+ import {InstanceStore} from "../instance/InstanceStore.sol";
24
23
  import {KEEP_STATE} from "../type/StateId.sol";
25
- import {Seconds} from "../type/Seconds.sol";
24
+ import {NftId} from "../type/NftId.sol";
25
+ import {ObjectType, ACCOUNTING, POOL, BUNDLE, PRODUCT, POLICY, COMPONENT} from "../type/ObjectType.sol";
26
+ import {PayoutId} from "../type/PayoutId.sol";
27
+ import {PoolLib} from "./PoolLib.sol";
28
+ import {Service} from "../shared/Service.sol";
26
29
  import {TokenHandler} from "../shared/TokenHandler.sol";
27
30
  import {UFixed} from "../type/UFixed.sol";
28
- import {ComponentVerifyingService} from "../shared/ComponentVerifyingService.sol";
29
- import {InstanceReader} from "../instance/InstanceReader.sol";
30
- import {InstanceStore} from "../instance/InstanceStore.sol";
31
31
 
32
32
  string constant POOL_SERVICE_NAME = "PoolService";
33
33
 
34
+
34
35
  contract PoolService is
35
- ComponentVerifyingService,
36
+ Service,
36
37
  IPoolService
37
38
  {
39
+ IAccountingService private _accountingService;
38
40
  IBundleService internal _bundleService;
39
41
  IComponentService internal _componentService;
40
- IInstanceService private _instanceService;
41
- IRegistryService private _registryService;
42
-
43
42
  IStaking private _staking;
44
43
 
45
44
  function _initialize(
@@ -47,33 +46,31 @@ contract PoolService is
47
46
  bytes memory data
48
47
  )
49
48
  internal
50
- initializer
51
49
  virtual override
50
+ initializer()
52
51
  {
53
52
  (
54
- address registryAddress,,
55
- //address managerAddress
56
- address authority
57
- ) = abi.decode(data, (address, address, address));
53
+ address authority,
54
+ address registry
55
+ ) = abi.decode(data, (address, address));
58
56
 
59
- initializeService(registryAddress, authority, owner);
57
+ __Service_init(authority, registry, owner);
60
58
 
61
- _registryService = IRegistryService(_getServiceAddress(REGISTRY()));
59
+ _accountingService = IAccountingService(_getServiceAddress(ACCOUNTING()));
62
60
  _bundleService = IBundleService(_getServiceAddress(BUNDLE()));
63
- _instanceService = IInstanceService(_getServiceAddress(INSTANCE()));
64
61
  _componentService = IComponentService(_getServiceAddress(COMPONENT()));
65
-
66
62
  _staking = IStaking(getRegistry().getStakingAddress());
67
63
 
68
- registerInterface(type(IPoolService).interfaceId);
64
+ _registerInterface(type(IPoolService).interfaceId);
69
65
  }
70
66
 
67
+
71
68
  /// @inheritdoc IPoolService
72
69
  function setMaxBalanceAmount(Amount maxBalanceAmount)
73
70
  external
74
71
  virtual
75
72
  {
76
- (NftId poolNftId,, IInstance instance) = _getAndVerifyActiveComponent(POOL());
73
+ (NftId poolNftId, IInstance instance) = _getAndVerifyActivePool();
77
74
  InstanceReader instanceReader = instance.getInstanceReader();
78
75
  IComponents.PoolInfo memory poolInfo = instanceReader.getPoolInfo(poolNftId);
79
76
 
@@ -84,105 +81,21 @@ contract PoolService is
84
81
  emit LogPoolServiceMaxBalanceAmountUpdated(poolNftId, previousMaxBalanceAmount, maxBalanceAmount);
85
82
  }
86
83
 
87
- function setBundleOwnerRole(RoleId bundleOwnerRole)
88
- external
89
- virtual
90
- {
91
- (NftId poolNftId,, IInstance instance) = _getAndVerifyActiveComponent(POOL());
92
- InstanceReader instanceReader = instance.getInstanceReader();
93
-
94
- IComponents.ComponentInfo memory componentInfo = instanceReader.getComponentInfo(poolNftId);
95
- IComponents.PoolInfo memory poolInfo = abi.decode(componentInfo.data, (IComponents.PoolInfo));
96
-
97
- // bundle owner role may only be set once per pool
98
- if(poolInfo.bundleOwnerRole != PUBLIC_ROLE()) {
99
- revert ErrorPoolServiceBundleOwnerRoleAlreadySet(poolNftId);
100
- }
101
-
102
- poolInfo.bundleOwnerRole = bundleOwnerRole;
103
- instance.getInstanceStore().updatePool(poolNftId, poolInfo, KEEP_STATE());
104
-
105
- emit LogPoolServiceBundleOwnerRoleSet(poolNftId, bundleOwnerRole);
106
- }
107
-
108
- /// @inheritdoc IPoolService
109
- function createBundle(
110
- address bundleOwner, // initial bundle owner
111
- Fee memory fee, // fees deducted from premium that go to bundle owner
112
- Amount stakingAmount, // staking amount - staking fees result in initial bundle capital
113
- Seconds lifetime, // initial duration for which new policies are covered
114
- bytes calldata filter // optional use case specific criteria that define if a policy may be covered by this bundle
115
- )
116
- external
117
- virtual
118
- returns(NftId bundleNftId, Amount netStakedAmount)
119
- {
120
- (NftId poolNftId,, IInstance instance) = _getAndVerifyActiveComponent(POOL());
121
-
122
- {
123
- InstanceReader instanceReader = instance.getInstanceReader();
124
- IComponents.PoolInfo memory poolInfo = instanceReader.getPoolInfo(poolNftId);
125
- Amount currentPoolBalance = instanceReader.getBalanceAmount(poolNftId);
126
- if (currentPoolBalance + stakingAmount > poolInfo.maxBalanceAmount) {
127
- revert ErrorPoolServiceMaxBalanceAmountExceeded(poolNftId, poolInfo.maxBalanceAmount, currentPoolBalance, stakingAmount);
128
- }
129
- }
130
-
131
-
132
- Amount stakingFeeAmount;
133
- (stakingFeeAmount, netStakedAmount) = FeeLib.calculateFee(
134
- _getStakingFee(instance.getInstanceReader(), poolNftId),
135
- stakingAmount);
136
-
137
-
138
- bundleNftId = _bundleService.create(
139
- instance,
140
- poolNftId,
141
- bundleOwner,
142
- fee,
143
- netStakedAmount,
144
- lifetime,
145
- filter);
146
-
147
- // pool book keeping
148
- _componentService.increasePoolBalance(
149
- instance.getInstanceStore(),
150
- poolNftId,
151
- netStakedAmount,
152
- stakingFeeAmount);
153
-
154
- // pool bookkeeping and collect tokens from bundle owner
155
- _collectStakingAmount(
156
- instance.getInstanceReader(),
157
- poolNftId,
158
- bundleOwner,
159
- stakingAmount);
160
-
161
- emit LogPoolServiceBundleCreated(instance.getNftId(), poolNftId, bundleNftId);
162
- }
163
-
164
- function _getStakingFee(InstanceReader instanceReader, NftId poolNftId)
165
- internal
166
- virtual
167
- view
168
- returns (Fee memory stakingFee)
169
- {
170
- NftId productNftId = instanceReader.getComponentInfo(poolNftId).productNftId;
171
- return instanceReader.getProductInfo(productNftId).stakingFee;
172
- }
173
84
 
174
85
  function closeBundle(NftId bundleNftId)
175
86
  external
176
87
  virtual
177
88
  {
178
- (NftId poolNftId,, IInstance instance) = _getAndVerifyActiveComponent(POOL());
89
+ _checkNftType(bundleNftId, BUNDLE());
90
+
91
+ (NftId poolNftId, IInstance instance) = _getAndVerifyActivePool();
179
92
 
180
93
  // TODO get performance fee for pool (#477)
181
94
 
182
95
  // releasing collateral in bundle
183
96
  (Amount unstakedAmount, Amount feeAmount) = _bundleService.close(instance, bundleNftId);
184
97
 
185
- _componentService.decreasePoolBalance(
98
+ _accountingService.decreasePoolBalance(
186
99
  instance.getInstanceStore(),
187
100
  poolNftId,
188
101
  unstakedAmount + feeAmount,
@@ -192,42 +105,88 @@ contract PoolService is
192
105
 
193
106
  if ((unstakedAmount + feeAmount).gtz()){
194
107
  IComponents.ComponentInfo memory poolComponentInfo = instance.getInstanceReader().getComponentInfo(poolNftId);
195
- TokenHandler tokenHandler = poolComponentInfo.tokenHandler;
196
- IERC20Metadata token = IERC20Metadata(poolComponentInfo.token);
197
-
198
- // TODO: centralize token handling (issue #471)
199
-
200
- // check allowance
201
- uint256 tokenAllowance = token.allowance(poolComponentInfo.wallet, address(tokenHandler));
202
- if (tokenAllowance < (unstakedAmount.toInt() + feeAmount.toInt())) {
203
- revert ErrorPoolServiceWalletAllowanceTooSmall(
204
- poolComponentInfo.wallet,
205
- address(tokenHandler),
206
- tokenAllowance,
207
- unstakedAmount.toInt() + feeAmount.toInt());
208
- }
108
+ poolComponentInfo.tokenHandler.pushToken(
109
+ getRegistry().ownerOf(bundleNftId),
110
+ unstakedAmount + feeAmount);
111
+ }
112
+ }
209
113
 
210
- // transfer amount to bundle owner
211
- address bundleOwner = getRegistry().ownerOf(bundleNftId);
212
- tokenHandler.transfer(poolComponentInfo.wallet, bundleOwner, unstakedAmount + feeAmount);
114
+
115
+ /// @inheritdoc IPoolService
116
+ function processFundedClaim(
117
+ NftId policyNftId,
118
+ ClaimId claimId,
119
+ Amount availableAmount
120
+ )
121
+ external
122
+ virtual
123
+ {
124
+ _checkNftType(policyNftId, POLICY());
125
+
126
+ (NftId poolNftId, IInstance instance) = _getAndVerifyActivePool();
127
+ InstanceReader instanceReader = instance.getInstanceReader();
128
+ NftId productNftId = getRegistry().getParentNftId(poolNftId);
129
+
130
+ // check policy matches with calling pool
131
+ IPolicy.PolicyInfo memory policyInfo = instanceReader.getPolicyInfo(policyNftId);
132
+ if(policyInfo.productNftId != productNftId) {
133
+ revert ErrorPoolServicePolicyPoolMismatch(
134
+ policyNftId,
135
+ policyInfo.productNftId,
136
+ productNftId);
137
+ }
138
+
139
+ emit LogPoolServiceProcessFundedClaim(policyNftId, claimId, availableAmount);
140
+
141
+ // callback to product component if applicable
142
+ if (instanceReader.getProductInfo(productNftId).isProcessingFundedClaims) {
143
+ address productAddress = getRegistry().getObjectAddress(productNftId);
144
+ IProductComponent(productAddress).processFundedClaim(policyNftId, claimId, availableAmount);
213
145
  }
214
146
  }
215
147
 
148
+
149
+ // function _checkAndGetPoolInfo(NftId bundleNftId)
150
+ // internal
151
+ // view
152
+ // returns (
153
+ // InstanceReader instanceReader,
154
+ // InstanceStore instanceStore,
155
+ // NftId instanceNftId,
156
+ // NftId poolNftId,
157
+ // IComponents.PoolInfo memory poolInfo
158
+ // )
159
+ // {
160
+ // _checkNftType(bundleNftId, BUNDLE());
161
+
162
+ // (NftId poolNftId, IInstance instance) = _getAndVerifyActivePool();
163
+ // instanceReader = instance.getInstanceReader();
164
+ // instanceStore = instance.getInstanceStore();
165
+ // instanceNftId = instance.getNftId();
166
+ // poolInfo = instanceReader.getPoolInfo(poolNftId);
167
+
168
+ // if (getRegistry().getParentNftId(bundleNftId) != poolNftId) {
169
+ // revert ErrorPoolServiceBundlePoolMismatch(bundleNftId, poolNftId);
170
+ // }
171
+ // }
172
+
173
+
216
174
  /// @inheritdoc IPoolService
217
175
  function stake(NftId bundleNftId, Amount amount)
218
176
  external
219
177
  virtual
220
178
  // TODO: restricted() (once #462 is done)
221
- returns(Amount netAmount)
179
+ returns(
180
+ Amount netAmount
181
+ )
222
182
  {
223
- (NftId poolNftId,, IInstance instance) = _getAndVerifyActiveComponent(POOL());
224
- InstanceReader instanceReader = instance.getInstanceReader();
225
- IBundle.BundleInfo memory bundleInfo = instanceReader.getBundleInfo(bundleNftId);
226
- IComponents.PoolInfo memory poolInfo = instanceReader.getPoolInfo(poolNftId);
227
-
228
- if (bundleInfo.poolNftId != poolNftId) {
229
- revert ErrorPoolServiceBundlePoolMismatch(bundleNftId, poolNftId);
230
- }
183
+ (
184
+ InstanceReader instanceReader,
185
+ InstanceStore instanceStore,
186
+ NftId instanceNftId,
187
+ NftId poolNftId,
188
+ IComponents.PoolInfo memory poolInfo
189
+ ) = PoolLib.checkAndGetPoolInfo(getRegistry(), msg.sender, bundleNftId);
231
190
 
232
191
  {
233
192
  Amount currentPoolBalance = instanceReader.getBalanceAmount(poolNftId);
@@ -241,29 +200,37 @@ contract PoolService is
241
200
  (
242
201
  feeAmount,
243
202
  netAmount
244
- ) = FeeLib.calculateFee(
245
- _getStakingFee(instanceReader, poolNftId),
203
+ ) = PoolLib.calculateStakingAmounts(
204
+ getRegistry(),
205
+ instanceReader,
206
+ poolNftId,
246
207
  amount);
247
208
 
248
- // do all the bookkeeping
249
- _componentService.increasePoolBalance(
250
- instance.getInstanceStore(),
209
+ // do all the book keeping
210
+ _accountingService.increasePoolBalance(
211
+ instanceStore,
251
212
  poolNftId,
252
213
  netAmount,
253
214
  feeAmount);
254
215
 
255
- _bundleService.stake(instance, bundleNftId, netAmount);
216
+ _bundleService.stake(instanceReader, instanceStore, bundleNftId, netAmount);
256
217
 
257
- // collect tokens from bundle owner
258
- address bundleOwner = getRegistry().ownerOf(bundleNftId);
259
- emit LogPoolServiceBundleStaked(instance.getNftId(), poolNftId, bundleNftId, amount, netAmount);
260
- _collectStakingAmount(
261
- instanceReader,
262
- poolNftId,
263
- bundleOwner,
264
- amount);
218
+ emit LogPoolServiceBundleStaked(instanceNftId, poolNftId, bundleNftId, amount, netAmount);
219
+
220
+ // only collect staking amount when pool is not externally managed
221
+ if (!poolInfo.isExternallyManaged) {
222
+
223
+ // collect tokens from bundle owner
224
+ address bundleOwner = getRegistry().ownerOf(bundleNftId);
225
+ _pullStakingAmount(
226
+ instanceReader,
227
+ poolNftId,
228
+ bundleOwner,
229
+ amount);
230
+ }
265
231
  }
266
232
 
233
+
267
234
  /// @inheritdoc IPoolService
268
235
  function unstake(NftId bundleNftId, Amount amount)
269
236
  external
@@ -271,82 +238,129 @@ contract PoolService is
271
238
  // TODO: restricted() (once #462 is done)
272
239
  returns(Amount netAmount)
273
240
  {
274
- (NftId poolNftId,, IInstance instance) = _getAndVerifyActiveComponent(POOL());
275
- InstanceReader instanceReader = instance.getInstanceReader();
276
- InstanceStore instanceStore = instance.getInstanceStore();
277
- IBundle.BundleInfo memory bundleInfo = instanceReader.getBundleInfo(bundleNftId);
278
-
279
- if (bundleInfo.poolNftId != poolNftId) {
280
- revert ErrorPoolServiceBundlePoolMismatch(bundleNftId, poolNftId);
281
- }
282
-
283
- if (amount.eqz()) {
284
- revert ErrorPoolServiceAmountIsZero();
285
- }
241
+ (
242
+ InstanceReader instanceReader,
243
+ InstanceStore instanceStore,
244
+ NftId instanceNftId,
245
+ NftId poolNftId,
246
+ ) = PoolLib.checkAndGetPoolInfo(getRegistry(), msg.sender, bundleNftId);
286
247
 
287
248
  // call bundle service for bookkeeping and additional checks
288
- Amount unstakedAmount = _bundleService.unstake(instance, bundleNftId, amount);
249
+ Amount unstakedAmount = _bundleService.unstake(instanceStore, bundleNftId, amount);
289
250
 
290
251
  // Important: from now on work only with unstakedAmount as it is the only reliable amount.
291
252
  // if amount was max, this was set to the available amount
292
253
 
293
254
  // TODO: handle performance fees (issue #477)
255
+ netAmount = unstakedAmount;
294
256
 
295
257
  // update pool bookkeeping - performance fees stay in the pool, but as fees
296
- _componentService.decreasePoolBalance(
258
+ _accountingService.decreasePoolBalance(
297
259
  instanceStore,
298
260
  poolNftId,
299
261
  unstakedAmount,
300
262
  AmountLib.zero());
301
263
 
302
- IComponents.ComponentInfo memory poolComponentInfo = instanceReader.getComponentInfo(poolNftId);
303
- address poolWallet = poolComponentInfo.wallet;
304
264
 
305
- // check allowance
306
- {
307
- IERC20Metadata token = IERC20Metadata(poolComponentInfo.token);
308
- uint256 tokenAllowance = token.allowance(poolWallet, address(poolComponentInfo.tokenHandler));
309
- if (tokenAllowance < unstakedAmount.toInt()) {
310
- revert ErrorPoolServiceWalletAllowanceTooSmall(poolWallet, address(poolComponentInfo.tokenHandler), tokenAllowance, amount.toInt());
311
- }
265
+ emit LogPoolServiceBundleUnstaked(instanceNftId, poolNftId, bundleNftId, unstakedAmount, netAmount);
266
+
267
+ // only distribute staking amount when pool is not externally managed
268
+ if (!instanceReader.getPoolInfo(poolNftId).isExternallyManaged) {
269
+
270
+ // transfer amount to bundle owner
271
+ address bundleOwner = getRegistry().ownerOf(bundleNftId);
272
+ _pushUnstakingAmount(
273
+ instanceReader,
274
+ poolNftId,
275
+ bundleOwner,
276
+ netAmount);
312
277
  }
278
+ }
313
279
 
314
- // transfer amount to bundle owner
315
- address owner = getRegistry().ownerOf(bundleNftId);
316
- emit LogPoolServiceBundleUnstaked(instance.getNftId(), poolNftId, bundleNftId, unstakedAmount);
317
- // TODO: centralize token handling (issue #471)
318
- poolComponentInfo.tokenHandler.transfer(poolWallet, owner, unstakedAmount);
319
- return unstakedAmount;
280
+
281
+ function fundPoolWallet(Amount amount)
282
+ external
283
+ virtual
284
+ // restricted()
285
+ {
286
+ (
287
+ NftId poolNftId,
288
+ IInstance instance
289
+ ) = _getAndVerifyActivePool();
290
+
291
+ // check that pool is externally managed
292
+ InstanceReader reader = instance.getInstanceReader();
293
+ if (!reader.getPoolInfo(poolNftId).isExternallyManaged) {
294
+ revert ErrorPoolServicePoolNotExternallyManaged(poolNftId);
295
+ }
296
+
297
+ address poolOwner = getRegistry().ownerOf(poolNftId);
298
+ emit LogPoolServiceWalletFunded(poolNftId, poolOwner, amount);
299
+
300
+ _pullStakingAmount(
301
+ reader,
302
+ poolNftId,
303
+ poolOwner,
304
+ amount);
320
305
  }
321
306
 
307
+
308
+ function defundPoolWallet(Amount amount)
309
+ external
310
+ virtual
311
+ // restricted()
312
+ {
313
+ (
314
+ NftId poolNftId,
315
+ IInstance instance
316
+ ) = _getAndVerifyActivePool();
317
+
318
+ // check that pool is externally managed
319
+ InstanceReader reader = instance.getInstanceReader();
320
+ if (!reader.getPoolInfo(poolNftId).isExternallyManaged) {
321
+ revert ErrorPoolServicePoolNotExternallyManaged(poolNftId);
322
+ }
323
+
324
+ address poolOwner = getRegistry().ownerOf(poolNftId);
325
+ emit LogPoolServiceWalletDefunded(poolNftId, poolOwner, amount);
326
+
327
+ _pushUnstakingAmount(
328
+ reader,
329
+ poolNftId,
330
+ poolOwner,
331
+ amount);
332
+ }
333
+
334
+
322
335
  function processSale(
323
336
  NftId bundleNftId,
324
- IPolicy.Premium memory premium
337
+ IPolicy.PremiumInfo memory premium
325
338
  )
326
339
  external
327
340
  virtual
328
341
  restricted()
329
342
  {
343
+ _checkNftType(bundleNftId, BUNDLE());
344
+
330
345
  IRegistry registry = getRegistry();
331
- IRegistry.ObjectInfo memory bundleObjectInfo = registry.getObjectInfo(bundleNftId);
332
- IRegistry.ObjectInfo memory poolObjectInfo = registry.getObjectInfo(bundleObjectInfo.parentNftId);
333
- IRegistry.ObjectInfo memory instanceObjectInfo = registry.getObjectInfo(poolObjectInfo.parentNftId);
334
- IInstance instance = IInstance(instanceObjectInfo.objectAddress);
346
+ NftId poolNftId = registry.getParentNftId(bundleNftId);
347
+ (, address instanceAddress) = ContractLib.getInfoAndInstance(registry, poolNftId, true);
348
+ IInstance instance = IInstance(instanceAddress);
335
349
 
336
- Amount poolFeeAmount = AmountLib.toAmount(premium.poolFeeFixAmount + premium.poolFeeVarAmount);
337
- Amount bundleFeeAmount = AmountLib.toAmount(premium.bundleFeeFixAmount + premium.bundleFeeVarAmount);
338
- Amount bundleNetAmount = AmountLib.toAmount(premium.netPremiumAmount);
350
+ Amount poolFeeAmount = premium.poolFeeFixAmount + premium.poolFeeVarAmount;
351
+ Amount bundleFeeAmount = premium.bundleFeeFixAmount + premium.bundleFeeVarAmount;
352
+ Amount bundleNetAmount = premium.netPremiumAmount;
339
353
 
340
354
  InstanceStore instanceStore = instance.getInstanceStore();
341
- _componentService.increasePoolBalance(
355
+ _accountingService.increasePoolBalance(
342
356
  instanceStore,
343
- poolObjectInfo.nftId,
357
+ poolNftId,
344
358
  bundleNetAmount + bundleFeeAmount,
345
359
  poolFeeAmount);
346
360
 
347
- _componentService.increaseBundleBalance(
361
+ _accountingService.increaseBundleBalanceForPool(
348
362
  instanceStore,
349
- bundleObjectInfo.nftId,
363
+ bundleNftId,
350
364
  bundleNetAmount,
351
365
  bundleFeeAmount);
352
366
  }
@@ -364,14 +378,22 @@ contract PoolService is
364
378
  virtual
365
379
  restricted()
366
380
  returns (
367
- Amount localCollateralAmount,
368
- Amount totalCollateralAmount
381
+ Amount totalCollateralAmount,
382
+ Amount localCollateralAmount
369
383
  )
370
384
  {
385
+ _checkNftType(productNftId, PRODUCT());
386
+ _checkNftType(applicationNftId, POLICY());
387
+ _checkNftType(bundleNftId, BUNDLE());
388
+
389
+ NftId poolNftId;
390
+ bool poolIsVerifyingApplications;
371
391
  (
392
+ poolNftId,
393
+ totalCollateralAmount,
372
394
  localCollateralAmount,
373
- totalCollateralAmount
374
- ) = calculateRequiredCollateral(
395
+ poolIsVerifyingApplications
396
+ ) = PoolLib.calculateRequiredCollateral(
375
397
  instance.getInstanceReader(),
376
398
  productNftId,
377
399
  sumInsuredAmount);
@@ -389,36 +411,170 @@ contract PoolService is
389
411
  token,
390
412
  totalCollateralAmount);
391
413
 
392
- // hierarhical riskpool setup
393
- // TODO loop in with pool component to guarantee availability of external capital
394
- if(totalCollateralAmount > localCollateralAmount) {
414
+ // pool callback when required
415
+ if (poolIsVerifyingApplications) {
416
+ IPoolComponent pool = IPoolComponent(
417
+ getRegistry().getObjectAddress(poolNftId));
395
418
 
419
+ pool.verifyApplication(
420
+ applicationNftId,
421
+ bundleNftId,
422
+ totalCollateralAmount);
423
+
424
+ // TODO add logging
396
425
  }
397
- }
398
426
 
427
+ // TODO add logging
428
+ }
399
429
 
400
- function reduceCollateral(
401
- IInstance instance,
402
- address token,
430
+ function processPayout(
431
+ InstanceReader instanceReader,
432
+ InstanceStore instanceStore,
433
+ NftId productNftId,
403
434
  NftId policyNftId,
404
- IPolicy.PolicyInfo memory policyInfo,
405
- Amount payoutAmount
435
+ NftId bundleNftId,
436
+ PayoutId payoutId,
437
+ Amount payoutAmount,
438
+ address payoutBeneficiary
406
439
  )
407
440
  external
408
441
  virtual
409
442
  restricted()
410
443
  {
444
+ // checks
445
+ _checkNftType(policyNftId, POLICY());
446
+
447
+ // effects
448
+ NftId poolNftId = getRegistry().getParentNftId(bundleNftId);
449
+
450
+ _accountingService.decreasePoolBalance(
451
+ instanceStore,
452
+ poolNftId,
453
+ payoutAmount,
454
+ AmountLib.zero());
455
+
456
+ _accountingService.decreaseBundleBalanceForPool(
457
+ instanceStore,
458
+ bundleNftId,
459
+ payoutAmount,
460
+ AmountLib.zero());
461
+
411
462
  _bundleService.releaseCollateral(
412
- instance,
463
+ instanceStore,
413
464
  policyNftId,
414
- policyInfo.bundleNftId,
465
+ bundleNftId,
415
466
  payoutAmount);
416
467
 
417
468
  // update value locked with staking service
469
+ TokenHandler poolTokenHandler = instanceReader.getTokenHandler(poolNftId);
470
+
418
471
  _staking.decreaseTotalValueLocked(
419
- instance.getNftId(),
420
- token,
472
+ instanceReader.getInstanceNftId(),
473
+ address(poolTokenHandler.TOKEN()),
421
474
  payoutAmount);
475
+
476
+ // interactions
477
+ _transferTokenAndNotifyPolicyHolder(
478
+ instanceReader,
479
+ poolTokenHandler,
480
+ productNftId,
481
+ policyNftId,
482
+ payoutId,
483
+ payoutAmount,
484
+ payoutBeneficiary);
485
+ }
486
+
487
+ function _transferTokenAndNotifyPolicyHolder(
488
+ InstanceReader instanceReader,
489
+ TokenHandler poolTokenHandler,
490
+ NftId productNftId,
491
+ NftId policyNftId,
492
+ PayoutId payoutId,
493
+ Amount payoutAmount,
494
+ address payoutBeneficiary
495
+ )
496
+ internal
497
+ {
498
+ (
499
+ Amount netPayoutAmount,
500
+ Amount processingFeeAmount,
501
+ address beneficiary
502
+ ) = PoolLib.calculatePayoutAmounts(
503
+ getRegistry(),
504
+ instanceReader,
505
+ productNftId,
506
+ policyNftId,
507
+ payoutAmount,
508
+ payoutBeneficiary);
509
+
510
+ // 1st token tx to payout to beneficiary
511
+ poolTokenHandler.pushToken(
512
+ beneficiary,
513
+ netPayoutAmount);
514
+
515
+ // 2nd token tx to transfer processing fees to product wallet
516
+ // if processingFeeAmount > 0
517
+ if (processingFeeAmount.gtz()) {
518
+ poolTokenHandler.pushToken(
519
+ instanceReader.getWallet(productNftId),
520
+ processingFeeAmount);
521
+ }
522
+
523
+ // callback to policy holder if applicable
524
+ _policyHolderPayoutExecuted(
525
+ policyNftId,
526
+ payoutId,
527
+ beneficiary,
528
+ netPayoutAmount);
529
+ }
530
+
531
+
532
+ /// @inheritdoc IPoolService
533
+ function withdrawBundleFees(
534
+ NftId bundleNftId,
535
+ Amount amount
536
+ )
537
+ public
538
+ virtual
539
+ restricted()
540
+ returns (Amount withdrawnAmount)
541
+ {
542
+ // checks
543
+ _checkNftType(bundleNftId, BUNDLE());
544
+
545
+ (NftId poolNftId, IInstance instance) = _getAndVerifyActivePool();
546
+ InstanceReader reader = instance.getInstanceReader();
547
+
548
+ // determine withdrawn amount
549
+ withdrawnAmount = amount;
550
+ if (withdrawnAmount.gte(AmountLib.max())) {
551
+ withdrawnAmount = reader.getFeeAmount(bundleNftId);
552
+ } else {
553
+ if (withdrawnAmount > reader.getFeeAmount(bundleNftId)) {
554
+ revert ErrorPoolServiceFeesWithdrawAmountExceedsLimit(withdrawnAmount, reader.getFeeAmount(bundleNftId));
555
+ }
556
+ }
557
+
558
+ // effects
559
+ // decrease fee counters by withdrawnAmount
560
+ {
561
+ InstanceStore store = instance.getInstanceStore();
562
+ // decrease fee amount of the bundle
563
+ _accountingService.decreaseBundleBalanceForPool(store, bundleNftId, AmountLib.zero(), withdrawnAmount);
564
+ // decrease pool balance
565
+ _accountingService.decreasePoolBalance(store, poolNftId, withdrawnAmount, AmountLib.zero());
566
+ }
567
+
568
+ // interactions
569
+ // transfer amount to bundle owner
570
+ {
571
+ address bundleOwner = getRegistry().ownerOf(bundleNftId);
572
+ TokenHandler tokenHandler = reader.getTokenHandler(poolNftId);
573
+ address token = address(tokenHandler.TOKEN());
574
+ emit LogPoolServiceFeesWithdrawn(bundleNftId, bundleOwner, token, withdrawnAmount);
575
+
576
+ tokenHandler.pushToken(bundleOwner, withdrawnAmount);
577
+ }
422
578
  }
423
579
 
424
580
 
@@ -426,7 +582,6 @@ contract PoolService is
426
582
  /// may only be called by the policy service for unlocked pool components
427
583
  function releaseCollateral(
428
584
  IInstance instance,
429
- address token,
430
585
  NftId policyNftId,
431
586
  IPolicy.PolicyInfo memory policyInfo
432
587
  )
@@ -434,124 +589,165 @@ contract PoolService is
434
589
  virtual
435
590
  restricted()
436
591
  {
592
+ _checkNftType(policyNftId, POLICY());
593
+
437
594
  Amount remainingCollateralAmount = policyInfo.sumInsuredAmount - policyInfo.claimAmount;
438
595
 
439
596
  _bundleService.releaseCollateral(
440
- instance,
597
+ instance.getInstanceStore(),
441
598
  policyNftId,
442
599
  policyInfo.bundleNftId,
443
600
  remainingCollateralAmount);
444
601
 
445
- _bundleService.unlinkPolicy(
446
- instance,
447
- policyNftId);
448
-
449
602
  // update value locked with staking service
603
+ InstanceReader instanceReader = instance.getInstanceReader();
450
604
  _staking.decreaseTotalValueLocked(
451
- instance.getNftId(),
452
- token,
605
+ instanceReader.getInstanceNftId(),
606
+ address(instanceReader.getToken(policyInfo.productNftId)),
453
607
  remainingCollateralAmount);
454
608
  }
455
609
 
456
610
 
457
- function calculateRequiredCollateral(
458
- InstanceReader instanceReader,
459
- NftId productNftId,
460
- Amount sumInsuredAmount
611
+ // function calculateRequiredCollateral(
612
+ // InstanceReader instanceReader,
613
+ // NftId productNftId,
614
+ // Amount sumInsuredAmount
615
+ // )
616
+ // public
617
+ // view
618
+ // returns(
619
+ // NftId poolNftId,
620
+ // Amount totalCollateralAmount,
621
+ // Amount localCollateralAmount,
622
+ // bool poolIsVerifyingApplications
623
+ // )
624
+ // {
625
+ // return CollateralLib.calculateRequiredCollateral(
626
+ // instanceReader,
627
+ // productNftId,
628
+ // sumInsuredAmount);
629
+ // }
630
+
631
+ // _checkNftType(productNftId, PRODUCT());
632
+
633
+ // poolNftId = instanceReader.getProductInfo(productNftId).poolNftId;
634
+ // IComponents.PoolInfo memory poolInfo = instanceReader.getPoolInfo(poolNftId);
635
+ // poolIsVerifyingApplications = poolInfo.isVerifyingApplications;
636
+
637
+ // (
638
+ // totalCollateralAmount,
639
+ // localCollateralAmount
640
+ // ) = calculateRequiredCollateral(
641
+ // poolInfo.collateralizationLevel,
642
+ // poolInfo.retentionLevel,
643
+ // sumInsuredAmount);
644
+ // }
645
+
646
+
647
+ // function calculateRequiredCollateral(
648
+ // UFixed collateralizationLevel,
649
+ // UFixed retentionLevel,
650
+ // Amount sumInsuredAmount
651
+ // )
652
+ // public
653
+ // pure
654
+ // returns(
655
+ // Amount totalCollateralAmount,
656
+ // Amount localCollateralAmount
657
+ // )
658
+ // {
659
+ // // collateralization is applied to sum insured
660
+ // UFixed totalUFixed = collateralizationLevel * sumInsuredAmount.toUFixed();
661
+ // totalCollateralAmount = AmountLib.toAmount(totalUFixed.toInt());
662
+
663
+ // // retention level defines how much capital is required locally
664
+ // localCollateralAmount = AmountLib.toAmount(
665
+ // (retentionLevel * totalUFixed).toInt());
666
+ // }
667
+
668
+
669
+
670
+
671
+ function _policyHolderPayoutExecuted(
672
+ NftId policyNftId,
673
+ PayoutId payoutId,
674
+ address beneficiary,
675
+ Amount payoutAmount
461
676
  )
462
- public
463
- view
464
- returns(
465
- Amount localCollateralAmount,
466
- Amount totalCollateralAmount
467
- )
677
+ internal
468
678
  {
469
- NftId poolNftId = instanceReader.getProductInfo(productNftId).poolNftId;
470
- IComponents.PoolInfo memory poolInfo = instanceReader.getPoolInfo(poolNftId);
471
-
472
- (
473
- localCollateralAmount,
474
- totalCollateralAmount
475
- ) = calculateRequiredCollateral(
476
- poolInfo.collateralizationLevel,
477
- poolInfo.retentionLevel,
478
- sumInsuredAmount);
679
+ IPolicyHolder policyHolder = PoolLib.getPolicyHolder(getRegistry(), policyNftId);
680
+ if(address(policyHolder) != address(0)) {
681
+ policyHolder.payoutExecuted(policyNftId, payoutId, payoutAmount, beneficiary);
682
+ }
479
683
  }
480
684
 
481
685
 
482
- function calculateRequiredCollateral(
483
- UFixed collateralizationLevel,
484
- UFixed retentionLevel,
485
- Amount sumInsuredAmount
686
+ /// @dev Transfers the specified amount from the "from account" to the pool's wallet
687
+ function _pullStakingAmount(
688
+ InstanceReader reader,
689
+ NftId poolNftId,
690
+ address from,
691
+ Amount amount
486
692
  )
487
- public
488
- pure
489
- returns(
490
- Amount localCollateralAmount,
491
- Amount totalCollateralAmount
492
- )
693
+ internal
493
694
  {
494
- // TODO define if only applies to local collateral
495
- // TODO add minimalistic implementation
496
-
497
- // assumptions
498
- // - collateralizationLevel == 1.0
499
- // - retentionLevel == 1.0
500
- localCollateralAmount = sumInsuredAmount;
501
- totalCollateralAmount = localCollateralAmount;
695
+ IComponents.ComponentInfo memory info = reader.getComponentInfo(poolNftId);
696
+ info.tokenHandler.pullToken(
697
+ from,
698
+ amount);
502
699
  }
503
700
 
504
-
505
- function _processStakingFees(
506
- Fee memory stakingFee,
507
- Amount stakingAmount
701
+ /// @dev Transfers the specified amount from the pool's wallet to the "to account"
702
+ function _pushUnstakingAmount(
703
+ InstanceReader reader,
704
+ NftId poolNftId,
705
+ address to,
706
+ Amount amount
508
707
  )
509
708
  internal
510
- returns (Amount stakingNetAmount)
511
709
  {
512
- stakingNetAmount = stakingAmount;
513
-
514
- // check if any staking fees apply
515
- if (FeeLib.gtz(stakingFee)) {
516
- (Amount feeAmount, Amount netAmount) = FeeLib.calculateFee(stakingFee, stakingAmount);
517
- stakingNetAmount = netAmount;
518
-
519
- // TODO update fee balance for pool
520
- }
710
+ IComponents.ComponentInfo memory info = reader.getComponentInfo(poolNftId);
711
+ info.tokenHandler.pushToken(
712
+ to,
713
+ amount);
521
714
  }
522
715
 
523
716
 
524
- // TODO create (I)TreasuryService that deals with all gif related token transfers
525
- /// @dev transfers the specified amount from the bundle owner to the pool's wallet
526
- function _collectStakingAmount(
527
- InstanceReader instanceReader,
528
- NftId poolNftId,
529
- address bundleOwner,
530
- Amount amount
531
- )
717
+ function _getAndVerifyActivePool()
532
718
  internal
719
+ virtual
720
+ view
721
+ returns (
722
+ NftId poolNftId,
723
+ IInstance instance
724
+ )
533
725
  {
726
+ return PoolLib.getAndVerifyActivePool(getRegistry(), msg.sender);
727
+ }
534
728
 
535
- // collecting investor token
536
- IComponents.ComponentInfo memory componentInfo = instanceReader.getComponentInfo(poolNftId);
537
- TokenHandler tokenHandler = componentInfo.tokenHandler;
538
- address poolWallet = componentInfo.wallet;
539
-
540
- if(amount.gtz()) {
541
- uint256 allowance = IERC20Metadata(componentInfo.token).allowance(bundleOwner, address(tokenHandler));
542
- if (allowance < amount.toInt()) {
543
- revert ErrorPoolServiceWalletAllowanceTooSmall(bundleOwner, address(tokenHandler), allowance, amount.toInt());
544
- }
729
+ // function _getAndVerifyActivePool()
730
+ // internal
731
+ // virtual
732
+ // view
733
+ // returns (
734
+ // NftId poolNftId,
735
+ // IInstance instance
736
+ // )
737
+ // {
738
+ // (
739
+ // IRegistry.ObjectInfo memory info,
740
+ // address instanceAddress
741
+ // ) = ContractLib.getAndVerifyComponent(
742
+ // getRegistry(),
743
+ // msg.sender,
744
+ // POOL(),
745
+ // true); // only active pools
746
+
747
+ // poolNftId = info.nftId;
748
+ // instance = IInstance(instanceAddress);
749
+ // }
545
750
 
546
- // TODO: centralize token handling (issue #471)
547
- tokenHandler.transfer(
548
- bundleOwner,
549
- poolWallet,
550
- amount);
551
- } else {
552
- revert ErrorPoolServiceAmountIsZero();
553
- }
554
- }
555
751
 
556
752
  function _getDomain() internal pure override returns(ObjectType) {
557
753
  return POOL();