@etherisc/gif-next 0.0.2-9dd41ff-671 → 0.0.2-9e03baf-990

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 (543) hide show
  1. package/README.md +75 -9
  2. package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +4 -0
  3. package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +1293 -0
  4. package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.dbg.json +4 -0
  5. package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.json +1206 -0
  6. package/artifacts/contracts/authorization/Authorization.sol/Authorization.dbg.json +4 -0
  7. package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +414 -0
  8. package/artifacts/contracts/authorization/IAccess.sol/IAccess.dbg.json +4 -0
  9. package/artifacts/contracts/{instance/module/ISetup.sol/ISetup.json → authorization/IAccess.sol/IAccess.json} +2 -2
  10. package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.dbg.json +4 -0
  11. package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.json +1060 -0
  12. package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +4 -0
  13. package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +295 -0
  14. package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +4 -0
  15. package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.json +167 -0
  16. package/artifacts/contracts/authorization/ReleaseAccessManager.sol/ReleaseAccessManager.dbg.json +4 -0
  17. package/artifacts/contracts/{shared/AccessManagerCustom.sol/AccessManagerCustom.json → authorization/ReleaseAccessManager.sol/ReleaseAccessManager.json} +28 -25
  18. package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +4 -0
  19. package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +253 -0
  20. package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +4 -0
  21. package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +1324 -0
  22. package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +4 -0
  23. package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +470 -0
  24. package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
  25. package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +219 -596
  26. package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
  27. package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +340 -444
  28. package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
  29. package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +144 -133
  30. package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
  31. package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +226 -309
  32. package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
  33. package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +215 -94
  34. package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.dbg.json +4 -0
  35. package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.json +22 -0
  36. package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.dbg.json +4 -0
  37. package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.json +1429 -0
  38. package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +4 -0
  39. package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +502 -0
  40. package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +4 -0
  41. package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +1979 -0
  42. package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +4 -0
  43. package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +470 -0
  44. package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.dbg.json +4 -0
  45. package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.json +376 -0
  46. package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.dbg.json +4 -0
  47. package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.json +1430 -0
  48. package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +4 -0
  49. package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +1177 -0
  50. package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +4 -0
  51. package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +1606 -0
  52. package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +4 -0
  53. package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +2281 -0
  54. package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +4 -0
  55. package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +703 -0
  56. package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
  57. package/artifacts/contracts/instance/IInstance.sol/IInstance.json +112 -91
  58. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
  59. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +170 -84
  60. package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
  61. package/artifacts/contracts/instance/Instance.sol/Instance.json +127 -238
  62. package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
  63. package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +1183 -276
  64. package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +4 -0
  65. package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +561 -0
  66. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
  67. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +874 -395
  68. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
  69. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +255 -242
  70. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
  71. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +122 -103
  72. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
  73. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +1210 -389
  74. package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +4 -0
  75. package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +318 -0
  76. package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +1 -1
  77. package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.json +0 -53
  78. package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +4 -0
  79. package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +10 -0
  80. package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.dbg.json +4 -0
  81. package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.json +223 -0
  82. package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.dbg.json +4 -0
  83. package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.json +181 -0
  84. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
  85. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +21 -0
  86. package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
  87. package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +1 -1
  88. package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
  89. package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
  90. package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
  91. package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +4 -0
  92. package/artifacts/contracts/mock/Dip.sol/Dip.json +376 -0
  93. package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.dbg.json +4 -0
  94. package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.json +961 -0
  95. package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +4 -0
  96. package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +478 -0
  97. package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +4 -0
  98. package/artifacts/contracts/oracle/IOracle.sol/IOracle.json +52 -0
  99. package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +4 -0
  100. package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +776 -0
  101. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +4 -0
  102. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +709 -0
  103. package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +4 -0
  104. package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +877 -0
  105. package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +4 -0
  106. package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +982 -0
  107. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +4 -0
  108. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +746 -0
  109. package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +4 -0
  110. package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +1254 -0
  111. package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +4 -0
  112. package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +502 -0
  113. package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
  114. package/artifacts/contracts/pool/BundleService.sol/BundleService.json +507 -345
  115. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
  116. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +194 -111
  117. package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
  118. package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +275 -46
  119. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
  120. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +214 -400
  121. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
  122. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +490 -282
  123. package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
  124. package/artifacts/contracts/pool/Pool.sol/Pool.json +224 -621
  125. package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
  126. package/artifacts/contracts/pool/PoolService.sol/PoolService.json +634 -640
  127. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
  128. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +124 -117
  129. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
  130. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +132 -282
  131. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
  132. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +112 -97
  133. package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +4 -0
  134. package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +1148 -0
  135. package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +4 -0
  136. package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +470 -0
  137. package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
  138. package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +333 -299
  139. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
  140. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +153 -114
  141. package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
  142. package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +54 -1
  143. package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
  144. package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +196 -7
  145. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
  146. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +361 -81
  147. package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
  148. package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +154 -86
  149. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
  150. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +365 -221
  151. package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +4 -0
  152. package/artifacts/contracts/product/{IProductService.sol/IProductService.json → IRiskService.sol/IRiskService.json} +44 -57
  153. package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
  154. package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +422 -406
  155. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
  156. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +128 -137
  157. package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
  158. package/artifacts/contracts/product/PricingService.sol/PricingService.json +248 -348
  159. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
  160. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +143 -116
  161. package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
  162. package/artifacts/contracts/product/Product.sol/Product.json +364 -475
  163. package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +4 -0
  164. package/artifacts/contracts/product/RiskService.sol/RiskService.json +638 -0
  165. package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +4 -0
  166. package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +718 -0
  167. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
  168. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +59 -16
  169. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
  170. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +400 -50
  171. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
  172. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +112 -64
  173. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
  174. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +5 -18
  175. package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
  176. package/artifacts/contracts/registry/Registry.sol/Registry.json +840 -107
  177. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
  178. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +1743 -149
  179. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
  180. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +180 -200
  181. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
  182. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +105 -86
  183. package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +4 -0
  184. package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +205 -0
  185. package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +4 -0
  186. package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +1067 -0
  187. package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +4 -0
  188. package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +272 -0
  189. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
  190. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +314 -136
  191. package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
  192. package/artifacts/contracts/shared/Component.sol/Component.json +120 -317
  193. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
  194. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +1406 -213
  195. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +4 -0
  196. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +834 -0
  197. package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +4 -0
  198. package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +474 -0
  199. package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +4 -0
  200. package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +111 -0
  201. package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
  202. package/artifacts/contracts/shared/IComponent.sol/IComponent.json +114 -130
  203. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +4 -0
  204. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +1402 -0
  205. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +4 -0
  206. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +711 -0
  207. package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
  208. package/artifacts/contracts/{instance/base → shared}/IKeyValueStore.sol/IKeyValueStore.json +46 -14
  209. package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +4 -0
  210. package/artifacts/contracts/{instance/base → shared}/ILifecycle.sol/ILifecycle.json +35 -4
  211. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
  212. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +23 -1
  213. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
  214. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +16 -30
  215. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
  216. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +36 -1
  217. package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
  218. package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
  219. package/artifacts/contracts/shared/IService.sol/IService.json +49 -1
  220. package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.dbg.json +4 -0
  221. package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.json +53 -0
  222. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +4 -0
  223. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +799 -0
  224. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +4 -0
  225. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +538 -0
  226. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +4 -0
  227. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +174 -0
  228. package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.dbg.json +4 -0
  229. package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.json +306 -0
  230. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
  231. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +48 -70
  232. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
  233. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +20 -124
  234. package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
  235. package/artifacts/contracts/shared/Registerable.sol/Registerable.json +67 -103
  236. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
  237. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -15
  238. package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
  239. package/artifacts/contracts/shared/Service.sol/Service.json +54 -119
  240. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
  241. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +735 -27
  242. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.dbg.json +4 -0
  243. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.json +395 -0
  244. package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +4 -0
  245. package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +172 -0
  246. package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +4 -0
  247. package/artifacts/contracts/staking/IStaking.sol/IStaking.json +1435 -0
  248. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
  249. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +573 -53
  250. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +4 -0
  251. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +440 -0
  252. package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +4 -0
  253. package/artifacts/contracts/staking/Staking.sol/Staking.json +1816 -0
  254. package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.dbg.json +4 -0
  255. package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.json +205 -0
  256. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +4 -0
  257. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +780 -0
  258. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +4 -0
  259. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +587 -0
  260. package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
  261. package/artifacts/contracts/staking/StakingService.sol/StakingService.json +661 -182
  262. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
  263. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +125 -90
  264. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +4 -0
  265. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +2283 -0
  266. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +4 -0
  267. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +607 -0
  268. package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +1 -1
  269. package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.json +2 -2
  270. package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +1 -1
  271. package/artifacts/contracts/type/Amount.sol/AmountLib.json +121 -4
  272. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
  273. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +53 -2
  274. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +1 -1
  275. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +28 -4
  276. package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
  277. package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +4 -4
  278. package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +1 -1
  279. package/artifacts/contracts/type/Fee.sol/FeeLib.json +39 -34
  280. package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +1 -1
  281. package/artifacts/contracts/type/Key32.sol/Key32Lib.json +2 -2
  282. package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
  283. package/artifacts/contracts/type/NftId.sol/NftIdLib.json +47 -4
  284. package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
  285. package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +2 -2
  286. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
  287. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +149 -2
  288. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +1 -1
  289. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +19 -19
  290. package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +1 -1
  291. package/artifacts/contracts/type/Referral.sol/ReferralLib.json +4 -4
  292. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +4 -0
  293. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +204 -0
  294. package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +1 -1
  295. package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +60 -4
  296. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
  297. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +219 -6
  298. package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
  299. package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +124 -2
  300. package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +4 -0
  301. package/artifacts/contracts/type/Selector.sol/SelectorLib.json +129 -0
  302. package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +4 -0
  303. package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +10 -0
  304. package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
  305. package/artifacts/contracts/type/StateId.sol/StateIdLib.json +15 -2
  306. package/artifacts/contracts/type/String.sol/StrLib.dbg.json +4 -0
  307. package/artifacts/contracts/type/String.sol/StrLib.json +132 -0
  308. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
  309. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +36 -4
  310. package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +1 -1
  311. package/artifacts/contracts/type/UFixed.sol/MathLib.json +9 -3
  312. package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
  313. package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +71 -2
  314. package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +1 -1
  315. package/artifacts/contracts/type/Version.sol/VersionLib.json +2 -2
  316. package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +1 -1
  317. package/artifacts/contracts/type/Version.sol/VersionPartLib.json +21 -2
  318. package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.dbg.json +4 -0
  319. package/artifacts/contracts/{shared → upgradeability}/IVersionable.sol/IVersionable.json +1 -1
  320. package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.dbg.json +4 -0
  321. package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +618 -0
  322. package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +4 -0
  323. package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +129 -0
  324. package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +4 -0
  325. package/artifacts/contracts/{shared → upgradeability}/Versionable.sol/Versionable.json +1 -1
  326. package/contracts/authorization/AccessAdmin.sol +596 -0
  327. package/contracts/authorization/AccessManagerCloneable.sol +16 -0
  328. package/contracts/authorization/Authorization.sol +289 -0
  329. package/contracts/authorization/IAccess.sol +49 -0
  330. package/contracts/authorization/IAccessAdmin.sol +137 -0
  331. package/contracts/authorization/IAuthorization.sol +60 -0
  332. package/contracts/authorization/IServiceAuthorization.sol +40 -0
  333. package/contracts/authorization/ReleaseAccessManager.sol +38 -0
  334. package/contracts/authorization/ServiceAuthorization.sol +106 -0
  335. package/contracts/distribution/BasicDistribution.sol +139 -0
  336. package/contracts/distribution/BasicDistributionAuthorization.sol +47 -0
  337. package/contracts/distribution/Distribution.sol +156 -156
  338. package/contracts/distribution/DistributionService.sol +177 -173
  339. package/contracts/distribution/DistributionServiceManager.sol +8 -11
  340. package/contracts/distribution/IDistributionComponent.sol +28 -47
  341. package/contracts/distribution/IDistributionService.sol +24 -10
  342. package/contracts/examples/fire/DamageLevel.sol +59 -0
  343. package/contracts/examples/fire/FirePool.sol +86 -0
  344. package/contracts/examples/fire/FirePoolAuthorization.sol +34 -0
  345. package/contracts/examples/fire/FireProduct.sol +431 -0
  346. package/contracts/examples/fire/FireProductAuthorization.sol +44 -0
  347. package/contracts/examples/fire/FireUSD.sol +26 -0
  348. package/contracts/examples/unpermissioned/SimpleDistribution.sol +58 -0
  349. package/contracts/examples/unpermissioned/SimpleOracle.sol +137 -0
  350. package/contracts/examples/unpermissioned/SimplePool.sol +108 -0
  351. package/contracts/examples/unpermissioned/SimpleProduct.sol +345 -0
  352. package/contracts/instance/{BundleManager.sol → BundleSet.sol} +23 -23
  353. package/contracts/instance/IInstance.sol +28 -39
  354. package/contracts/instance/IInstanceService.sol +30 -32
  355. package/contracts/instance/Instance.sol +124 -122
  356. package/contracts/instance/InstanceAdmin.sol +208 -285
  357. package/contracts/instance/InstanceAuthorizationV3.sol +194 -0
  358. package/contracts/instance/InstanceReader.sol +194 -67
  359. package/contracts/instance/InstanceService.sol +246 -130
  360. package/contracts/instance/InstanceServiceManager.sol +8 -13
  361. package/contracts/instance/InstanceStore.sol +142 -66
  362. package/contracts/instance/base/BalanceStore.sol +123 -0
  363. package/contracts/instance/base/Cloneable.sol +2 -25
  364. package/contracts/instance/base/ObjectCounter.sol +21 -0
  365. package/contracts/instance/base/ObjectLifecycle.sol +111 -0
  366. package/contracts/instance/base/{ObjectManager.sol → ObjectSet.sol} +11 -14
  367. package/contracts/instance/module/IAccess.sol +2 -0
  368. package/contracts/instance/module/IBundle.sol +1 -4
  369. package/contracts/instance/module/IComponents.sol +22 -13
  370. package/contracts/instance/module/IDistribution.sol +0 -1
  371. package/contracts/instance/module/IPolicy.sol +33 -26
  372. package/contracts/mock/Dip.sol +26 -0
  373. package/contracts/oracle/BasicOracle.sol +47 -0
  374. package/contracts/oracle/BasicOracleAuthorization.sol +46 -0
  375. package/contracts/oracle/IOracle.sol +36 -0
  376. package/contracts/oracle/IOracleComponent.sol +33 -0
  377. package/contracts/oracle/IOracleService.sol +66 -0
  378. package/contracts/oracle/Oracle.sol +156 -0
  379. package/contracts/oracle/OracleService.sol +292 -0
  380. package/contracts/oracle/OracleServiceManager.sol +39 -0
  381. package/contracts/pool/BasicPool.sol +175 -0
  382. package/contracts/pool/BasicPoolAuthorization.sol +68 -0
  383. package/contracts/pool/BundleService.sol +314 -213
  384. package/contracts/pool/BundleServiceManager.sol +8 -11
  385. package/contracts/pool/IBundleService.sol +46 -24
  386. package/contracts/pool/IPoolComponent.sol +23 -75
  387. package/contracts/pool/IPoolService.sol +105 -47
  388. package/contracts/pool/Pool.sol +211 -168
  389. package/contracts/pool/PoolService.sol +448 -232
  390. package/contracts/pool/PoolServiceManager.sol +6 -9
  391. package/contracts/product/ApplicationService.sol +156 -84
  392. package/contracts/product/ApplicationServiceManager.sol +6 -6
  393. package/contracts/product/BasicProduct.sol +49 -0
  394. package/contracts/product/BasicProductAuthorization.sol +42 -0
  395. package/contracts/product/ClaimService.sol +333 -162
  396. package/contracts/product/ClaimServiceManager.sol +6 -6
  397. package/contracts/product/IApplicationService.sol +2 -1
  398. package/contracts/product/IClaimService.sol +35 -5
  399. package/contracts/product/IPolicyService.sol +41 -39
  400. package/contracts/product/IPricingService.sol +13 -11
  401. package/contracts/product/IProductComponent.sol +28 -10
  402. package/contracts/product/{IProductService.sol → IRiskService.sol} +2 -9
  403. package/contracts/product/PolicyService.sol +521 -204
  404. package/contracts/product/PolicyServiceManager.sol +6 -9
  405. package/contracts/product/PricingService.sol +107 -83
  406. package/contracts/product/PricingServiceManager.sol +5 -8
  407. package/contracts/product/Product.sol +199 -146
  408. package/contracts/product/RiskService.sol +96 -0
  409. package/contracts/product/RiskServiceManager.sol +39 -0
  410. package/contracts/registry/ChainNft.sol +75 -38
  411. package/contracts/registry/IRegistry.sol +85 -24
  412. package/contracts/registry/IRegistryService.sol +9 -6
  413. package/contracts/registry/ITransferInterceptor.sol +1 -2
  414. package/contracts/registry/Registry.sol +439 -179
  415. package/contracts/registry/RegistryAdmin.sol +396 -77
  416. package/contracts/registry/RegistryService.sol +73 -64
  417. package/contracts/registry/RegistryServiceManager.sol +6 -13
  418. package/contracts/registry/ReleaseLifecycle.sol +30 -0
  419. package/contracts/registry/ReleaseRegistry.sol +485 -0
  420. package/contracts/registry/ServiceAuthorizationV3.sol +203 -0
  421. package/contracts/registry/TokenRegistry.sol +261 -64
  422. package/contracts/shared/Component.sol +128 -170
  423. package/contracts/shared/ComponentService.sol +732 -94
  424. package/contracts/shared/ComponentServiceManager.sol +38 -0
  425. package/contracts/shared/ComponentVerifyingService.sol +128 -0
  426. package/contracts/shared/ContractLib.sol +54 -0
  427. package/contracts/shared/IComponent.sol +24 -47
  428. package/contracts/shared/IComponentService.sol +130 -0
  429. package/contracts/shared/IInstanceLinkedComponent.sol +41 -0
  430. package/contracts/{instance/base → shared}/IKeyValueStore.sol +7 -6
  431. package/contracts/{instance/base → shared}/ILifecycle.sol +5 -4
  432. package/contracts/shared/INftOwnable.sol +3 -1
  433. package/contracts/shared/IPolicyHolder.sol +12 -17
  434. package/contracts/shared/IRegisterable.sol +11 -0
  435. package/contracts/shared/IService.sol +9 -2
  436. package/contracts/shared/{ERC165.sol → InitializableERC165.sol} +4 -4
  437. package/contracts/shared/InstanceLinkedComponent.sol +205 -0
  438. package/contracts/{instance/base → shared}/KeyValueStore.sol +36 -74
  439. package/contracts/shared/Lifecycle.sol +88 -0
  440. package/contracts/shared/NftIdSet.sol +65 -0
  441. package/contracts/shared/NftOwnable.sol +32 -22
  442. package/contracts/shared/PolicyHolder.sol +18 -50
  443. package/contracts/shared/Registerable.sol +21 -13
  444. package/contracts/shared/RegistryLinked.sol +9 -14
  445. package/contracts/shared/Service.sol +48 -36
  446. package/contracts/shared/TokenHandler.sol +375 -13
  447. package/contracts/shared/TokenHandlerDeployerLib.sol +20 -0
  448. package/contracts/staking/IStaking.sol +173 -0
  449. package/contracts/staking/IStakingService.sol +103 -48
  450. package/contracts/staking/StakeManagerLib.sol +224 -0
  451. package/contracts/staking/Staking.sol +505 -0
  452. package/contracts/staking/StakingLifecycle.sol +23 -0
  453. package/contracts/staking/StakingManager.sol +52 -0
  454. package/contracts/staking/StakingReader.sol +190 -0
  455. package/contracts/staking/StakingService.sol +331 -47
  456. package/contracts/staking/StakingServiceManager.sol +11 -7
  457. package/contracts/staking/StakingStore.sol +605 -0
  458. package/contracts/staking/TargetManagerLib.sol +211 -0
  459. package/contracts/type/AddressSet.sol +1 -1
  460. package/contracts/type/Amount.sol +44 -3
  461. package/contracts/type/Blocknumber.sol +26 -3
  462. package/contracts/type/ClaimId.sol +6 -1
  463. package/contracts/type/Fee.sol +17 -16
  464. package/contracts/type/NftId.sol +15 -16
  465. package/contracts/type/NftIdSet.sol +1 -1
  466. package/contracts/type/ObjectType.sol +176 -62
  467. package/contracts/type/PayoutId.sol +10 -10
  468. package/contracts/type/Referral.sol +2 -1
  469. package/contracts/type/RequestId.sol +75 -0
  470. package/contracts/type/RiskId.sol +17 -3
  471. package/contracts/type/RoleId.sol +98 -75
  472. package/contracts/type/Seconds.sol +48 -1
  473. package/contracts/type/Selector.sol +102 -0
  474. package/contracts/type/StateId.sol +41 -2
  475. package/contracts/type/String.sol +53 -0
  476. package/contracts/type/Timestamp.sol +17 -3
  477. package/contracts/type/UFixed.sol +38 -9
  478. package/contracts/type/Version.sol +4 -2
  479. package/contracts/{shared → upgradeability}/ProxyManager.sol +73 -41
  480. package/contracts/{shared → upgradeability}/UpgradableProxyWithAdmin.sol +1 -3
  481. package/contracts/{shared → upgradeability}/Versionable.sol +2 -2
  482. package/package.json +11 -7
  483. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +0 -4
  484. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +0 -778
  485. package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +0 -4
  486. package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +0 -188
  487. package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +0 -4
  488. package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +0 -4
  489. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +0 -4
  490. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +0 -581
  491. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +0 -4
  492. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +0 -194
  493. package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +0 -4
  494. package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +0 -256
  495. package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +0 -4
  496. package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +0 -4
  497. package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.json +0 -10
  498. package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +0 -4
  499. package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +0 -4
  500. package/artifacts/contracts/product/ProductService.sol/ProductService.json +0 -883
  501. package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
  502. package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +0 -711
  503. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +0 -4
  504. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +0 -1018
  505. package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.dbg.json +0 -4
  506. package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.dbg.json +0 -4
  507. package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.json +0 -1715
  508. package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.dbg.json +0 -4
  509. package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.json +0 -1728
  510. package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.dbg.json +0 -4
  511. package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.json +0 -1747
  512. package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.dbg.json +0 -4
  513. package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.json +0 -1765
  514. package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +0 -4
  515. package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +0 -1206
  516. package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +0 -4
  517. package/artifacts/contracts/shared/ERC165.sol/ERC165.json +0 -73
  518. package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.dbg.json +0 -4
  519. package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.json +0 -1562
  520. package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.dbg.json +0 -4
  521. package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.json +0 -1594
  522. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +0 -4
  523. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +0 -4
  524. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +0 -630
  525. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +0 -4
  526. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +0 -129
  527. package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +0 -4
  528. package/contracts/instance/InstanceAuthorizationsLib.sol +0 -320
  529. package/contracts/instance/base/Lifecycle.sol +0 -121
  530. package/contracts/instance/module/ISetup.sol +0 -33
  531. package/contracts/instance/module/ITreasury.sol +0 -23
  532. package/contracts/product/ProductService.sol +0 -212
  533. package/contracts/product/ProductServiceManager.sol +0 -42
  534. package/contracts/registry/ReleaseManager.sol +0 -465
  535. package/contracts/shared/AccessManagerCustom.sol +0 -736
  536. package/contracts/shared/AccessManagerExtended.sol +0 -469
  537. package/contracts/shared/AccessManagerExtendedInitializeable.sol +0 -13
  538. package/contracts/shared/AccessManagerExtendedWithDisable.sol +0 -125
  539. package/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol +0 -14
  540. package/contracts/shared/AccessManagerUpgradeableInitializeable.sol +0 -13
  541. package/contracts/shared/IAccessManagerExtended.sol +0 -74
  542. package/contracts/shared/IAccessManagerExtendedWithDisable.sol +0 -17
  543. /package/contracts/{shared → upgradeability}/IVersionable.sol +0 -0
@@ -1,57 +1,35 @@
1
1
  // SPDX-License-Identifier: Apache-2.0
2
- pragma solidity ^0.8.19;
3
-
4
- import {IRisk} from "../instance/module/IRisk.sol";
5
- import {IService} from "./IApplicationService.sol";
6
-
7
- import {IComponents} from "../instance/module/IComponents.sol";
8
- import {IRegistry} from "../registry/IRegistry.sol";
9
- import {IProductComponent} from "./IProductComponent.sol";
10
- import {Product} from "./Product.sol";
11
- import {IPoolComponent} from "../pool/IPoolComponent.sol";
12
- import {IDistributionComponent} from "../distribution/IDistributionComponent.sol";
13
- import {IInstance} from "../instance/IInstance.sol";
14
- import {IPolicy} from "../instance/module/IPolicy.sol";
15
- import {IRisk} from "../instance/module/IRisk.sol";
16
- import {IBundle} from "../instance/module/IBundle.sol";
17
- import {IProductService} from "./IProductService.sol";
18
- import {ITreasury} from "../instance/module/ITreasury.sol";
19
- import {ISetup} from "../instance/module/ISetup.sol";
20
-
21
- import {TokenHandler} from "../shared/TokenHandler.sol";
22
-
23
- import {IVersionable} from "../shared/IVersionable.sol";
24
- import {Versionable} from "../shared/Versionable.sol";
2
+ pragma solidity ^0.8.20;
25
3
 
26
4
  import {Amount, AmountLib} from "../type/Amount.sol";
27
- import {Timestamp, TimestampLib, zeroTimestamp} from "../type/Timestamp.sol";
28
- import {UFixed, UFixedLib} from "../type/UFixed.sol";
29
- import {Blocknumber, blockNumber} from "../type/Blocknumber.sol";
30
- import {ObjectType, INSTANCE, PRODUCT, POOL, APPLICATION, POLICY, CLAIM, BUNDLE} from "../type/ObjectType.sol";
31
- import {SUBMITTED, ACTIVE, KEEP_STATE, DECLINED, CONFIRMED, CLOSED, PAID} from "../type/StateId.sol";
32
- import {NftId, NftIdLib, zeroNftId} from "../type/NftId.sol";
33
- import {Fee, FeeLib} from "../type/Fee.sol";
34
- import {ReferralId} from "../type/Referral.sol";
35
- import {RiskId} from "../type/RiskId.sol";
5
+ import {TimestampLib} from "../type/Timestamp.sol";
6
+ import {ObjectType, CLAIM, POLICY, POOL, PRODUCT} from "../type/ObjectType.sol";
7
+ import {SUBMITTED, KEEP_STATE, DECLINED, REVOKED, CONFIRMED, CLOSED, PAID} from "../type/StateId.sol";
8
+ import {NftId} from "../type/NftId.sol";
9
+ import {FeeLib} from "../type/Fee.sol";
36
10
  import {StateId} from "../type/StateId.sol";
37
11
  import {ClaimId, ClaimIdLib} from "../type/ClaimId.sol";
38
12
  import {PayoutId, PayoutIdLib} from "../type/PayoutId.sol";
39
- import {Version, VersionLib} from "../type/Version.sol";
40
-
41
- import {ComponentService} from "../shared/ComponentService.sol";
13
+ import {ComponentVerifyingService} from "../shared/ComponentVerifyingService.sol";
14
+ import {ContractLib} from "../shared/ContractLib.sol";
42
15
  import {InstanceReader} from "../instance/InstanceReader.sol";
43
- import {IBundleService} from "../pool/IBundleService.sol";
16
+ import {InstanceStore} from "../instance/InstanceStore.sol";
44
17
  import {IClaimService} from "./IClaimService.sol";
18
+ import {IComponents} from "../instance/module/IComponents.sol";
19
+ import {IInstance} from "../instance/IInstance.sol";
20
+ import {IPolicy} from "../instance/module/IPolicy.sol";
21
+ import {IPolicyHolder} from "../shared/IPolicyHolder.sol";
22
+ import {IPoolComponent} from "../pool/IPoolComponent.sol";
23
+ import {IPolicyService} from "../product/IPolicyService.sol";
45
24
  import {IPoolService} from "../pool/IPoolService.sol";
46
- import {IService} from "../shared/IService.sol";
47
- import {Service} from "../shared/Service.sol";
48
25
 
49
26
 
50
27
  contract ClaimService is
51
- ComponentService,
28
+ ComponentVerifyingService,
52
29
  IClaimService
53
30
  {
54
31
 
32
+ IPolicyService internal _policyService;
55
33
  IPoolService internal _poolService;
56
34
 
57
35
  function _initialize(
@@ -63,21 +41,16 @@ contract ClaimService is
63
41
  initializer()
64
42
  {
65
43
  (
66
- address registryAddress,,
67
- //address managerAddress
44
+ address registryAddress,
68
45
  address authority
69
- ) = abi.decode(data, (address, address, address));
46
+ ) = abi.decode(data, (address, address));
70
47
 
71
- initializeService(registryAddress, authority, owner);
48
+ _initializeService(registryAddress, authority, owner);
72
49
 
50
+ _policyService = IPolicyService(getRegistry().getServiceAddress(POLICY(), getVersion().toMajorPart()));
73
51
  _poolService = IPoolService(getRegistry().getServiceAddress(POOL(), getVersion().toMajorPart()));
74
52
 
75
- registerInterface(type(IClaimService).interfaceId);
76
- }
77
-
78
-
79
- function getDomain() public pure override returns(ObjectType) {
80
- return CLAIM();
53
+ _registerInterface(type(IClaimService).interfaceId);
81
54
  }
82
55
 
83
56
  function submit(
@@ -87,11 +60,15 @@ contract ClaimService is
87
60
  )
88
61
  external
89
62
  virtual
63
+ // nonReentrant() // prevents creating a reinsurance claim in a single tx
90
64
  returns (ClaimId claimId)
91
65
  {
66
+ _checkNftType(policyNftId, POLICY());
67
+
92
68
  (
93
- IInstance instance,
94
- InstanceReader instanceReader,
69
+ ,
70
+ IInstance instance,,
71
+ InstanceStore instanceStore,
95
72
  IPolicy.PolicyInfo memory policyInfo
96
73
  ) = _verifyCallerWithPolicy(policyNftId);
97
74
 
@@ -100,6 +77,7 @@ contract ClaimService is
100
77
  revert ErrorClaimServicePolicyNotOpen(policyNftId);
101
78
  }
102
79
 
80
+ // TODO check claim amount > 0
103
81
  // check policy including this claim is still within sum insured
104
82
  if(policyInfo.payoutAmount + claimAmount > policyInfo.sumInsuredAmount) {
105
83
  revert ErrorClaimServiceClaimExceedsSumInsured(
@@ -110,23 +88,23 @@ contract ClaimService is
110
88
 
111
89
  // create new claim
112
90
  claimId = ClaimIdLib.toClaimId(policyInfo.claimsCount + 1);
113
- instance.getInstanceStore().createClaim(
91
+ instanceStore.createClaim(
114
92
  policyNftId,
115
93
  claimId,
116
- IPolicy.ClaimInfo(
117
- claimAmount,
118
- AmountLib.zero(), // paidAmount
119
- 0, // payoutsCount
120
- 0, // openPayoutsCount
121
- claimData, // claim submission data
122
- "", // claim processing data
123
- TimestampLib.zero())); // closedAt
94
+ IPolicy.ClaimInfo({
95
+ claimAmount: claimAmount,
96
+ paidAmount: AmountLib.zero(),
97
+ payoutsCount: 0,
98
+ openPayoutsCount: 0,
99
+ submissionData: claimData,
100
+ processData: "",
101
+ closedAt: TimestampLib.zero()}));
124
102
 
125
103
  // update and save policy info with instance
104
+ // policy claim amount is only updated when claim is confirmed
126
105
  policyInfo.claimsCount += 1;
127
106
  policyInfo.openClaimsCount += 1;
128
- // policy claim amount is only updated when claim is confirmed
129
- instance.getInstanceStore().updatePolicyClaims(policyNftId, policyInfo, KEEP_STATE());
107
+ instanceStore.updatePolicyClaims(policyNftId, policyInfo, KEEP_STATE());
130
108
 
131
109
  emit LogClaimServiceClaimSubmitted(policyNftId, claimId, claimAmount);
132
110
  }
@@ -140,26 +118,45 @@ contract ClaimService is
140
118
  )
141
119
  external
142
120
  virtual
121
+ // nonReentrant() // prevents creating a reinsurance claim in a single tx
143
122
  {
123
+ _checkNftType(policyNftId, POLICY());
124
+
144
125
  (
126
+ NftId productNftId,
145
127
  IInstance instance,
146
128
  InstanceReader instanceReader,
129
+ InstanceStore instanceStore,
147
130
  IPolicy.PolicyInfo memory policyInfo
148
131
  ) = _verifyCallerWithPolicy(policyNftId);
149
132
 
133
+ // TODO add check for confirmedAmount > 0 and does not lead to exceeding sum insured
134
+
150
135
  // check/update claim info
151
136
  IPolicy.ClaimInfo memory claimInfo = _verifyClaim(instanceReader, policyNftId, claimId, SUBMITTED());
152
137
  claimInfo.claimAmount = confirmedAmount;
153
138
  claimInfo.processData = data;
154
- instance.getInstanceStore().updateClaim(policyNftId, claimId, claimInfo, CONFIRMED());
139
+ instanceStore.updateClaim(policyNftId, claimId, claimInfo, CONFIRMED());
155
140
 
156
141
  // update and save policy info with instance
157
142
  policyInfo.claimAmount = policyInfo.claimAmount + confirmedAmount;
158
- instance.getInstanceStore().updatePolicyClaims(policyNftId, policyInfo, KEEP_STATE());
143
+ instanceStore.updatePolicyClaims(policyNftId, policyInfo, KEEP_STATE());
144
+
145
+ // should policy still be active it needs to become expired
146
+ if (policyInfo.claimAmount >= policyInfo.sumInsuredAmount) {
147
+ _policyService.expirePolicy(instance, policyNftId, TimestampLib.blockTimestamp());
148
+ }
159
149
 
160
150
  emit LogClaimServiceClaimConfirmed(policyNftId, claimId, confirmedAmount);
151
+
152
+ // callback to pool if applicable
153
+ _processConfirmedClaimByPool(instanceReader, productNftId, policyNftId, claimId, confirmedAmount);
154
+
155
+ // callback to policy holder if applicable
156
+ _policyHolderClaimConfirmed(policyNftId, claimId, confirmedAmount);
161
157
  }
162
158
 
159
+
163
160
  function decline(
164
161
  NftId policyNftId,
165
162
  ClaimId claimId,
@@ -167,10 +164,15 @@ contract ClaimService is
167
164
  )
168
165
  external
169
166
  virtual
167
+ // nonReentrant() // prevents creating a reinsurance claim in a single tx
170
168
  {
169
+ _checkNftType(policyNftId, POLICY());
170
+
171
171
  (
172
+ ,
172
173
  IInstance instance,
173
174
  InstanceReader instanceReader,
175
+ InstanceStore instanceStore,
174
176
  IPolicy.PolicyInfo memory policyInfo
175
177
  ) = _verifyCallerWithPolicy(policyNftId);
176
178
 
@@ -178,25 +180,63 @@ contract ClaimService is
178
180
  IPolicy.ClaimInfo memory claimInfo = _verifyClaim(instanceReader, policyNftId, claimId, SUBMITTED());
179
181
  claimInfo.processData = data;
180
182
  claimInfo.closedAt = TimestampLib.blockTimestamp();
181
- instance.getInstanceStore().updateClaim(policyNftId, claimId, claimInfo, DECLINED());
183
+ instanceStore.updateClaim(policyNftId, claimId, claimInfo, DECLINED());
182
184
 
183
185
  // update and save policy info with instance
184
186
  policyInfo.openClaimsCount -= 1;
185
- instance.getInstanceStore().updatePolicyClaims(policyNftId, policyInfo, KEEP_STATE());
187
+ instanceStore.updatePolicyClaims(policyNftId, policyInfo, KEEP_STATE());
186
188
 
187
189
  emit LogClaimServiceClaimDeclined(policyNftId, claimId);
188
190
  }
189
191
 
192
+
193
+ // TODO add test case
194
+ function revoke(
195
+ NftId policyNftId,
196
+ ClaimId claimId
197
+ )
198
+ external
199
+ virtual
200
+ // nonReentrant() // prevents creating a reinsurance claim in a single tx
201
+ {
202
+ _checkNftType(policyNftId, POLICY());
203
+
204
+ (
205
+ ,
206
+ IInstance instance,
207
+ InstanceReader instanceReader,
208
+ InstanceStore instanceStore,
209
+ IPolicy.PolicyInfo memory policyInfo
210
+ ) = _verifyCallerWithPolicy(policyNftId);
211
+
212
+ // check/update claim info
213
+ IPolicy.ClaimInfo memory claimInfo = _verifyClaim(instanceReader, policyNftId, claimId, SUBMITTED());
214
+ claimInfo.closedAt = TimestampLib.blockTimestamp();
215
+ instanceStore.updateClaim(policyNftId, claimId, claimInfo, REVOKED());
216
+
217
+ // update and save policy info with instance
218
+ policyInfo.openClaimsCount -= 1;
219
+ instanceStore.updatePolicyClaims(policyNftId, policyInfo, KEEP_STATE());
220
+
221
+ emit LogClaimServiceClaimRevoked(policyNftId, claimId);
222
+ }
223
+
224
+
190
225
  function close(
191
226
  NftId policyNftId,
192
227
  ClaimId claimId
193
228
  )
194
229
  external
195
230
  virtual
231
+ // nonReentrant() // prevents creating a reinsurance claim in a single tx
196
232
  {
233
+ _checkNftType(policyNftId, POLICY());
234
+
197
235
  (
236
+ ,
198
237
  IInstance instance,
199
238
  InstanceReader instanceReader,
239
+ InstanceStore instanceStore,
200
240
  IPolicy.PolicyInfo memory policyInfo
201
241
  ) = _verifyCallerWithPolicy(policyNftId);
202
242
 
@@ -221,55 +261,56 @@ contract ClaimService is
221
261
  }
222
262
 
223
263
  claimInfo.closedAt = TimestampLib.blockTimestamp();
224
- instance.getInstanceStore().updateClaim(policyNftId, claimId, claimInfo, CLOSED());
264
+ instanceStore.updateClaim(policyNftId, claimId, claimInfo, CLOSED());
225
265
  }
226
266
 
227
267
 
228
- function createPayout(
268
+ function createPayoutForBeneficiary(
229
269
  NftId policyNftId,
230
270
  ClaimId claimId,
231
271
  Amount amount,
272
+ address beneficiary,
232
273
  bytes memory data
233
274
  )
234
275
  external
276
+ virtual
277
+ // nonReentrant() // prevents creating a reinsurance claim in a single tx
235
278
  returns (PayoutId payoutId)
236
279
  {
237
- (
238
- IInstance instance,
239
- InstanceReader instanceReader,
240
- IPolicy.PolicyInfo memory policyInfo
241
- ) = _verifyCallerWithPolicy(policyNftId);
242
-
243
- IPolicy.ClaimInfo memory claimInfo = instanceReader.getClaimInfo(policyNftId, claimId);
244
- StateId claimState = instanceReader.getClaimState(policyNftId, claimId);
245
-
246
- // TODO add checks
247
- // claim needs to be open
248
- // claim.paidAmount + amount <= claim.claimAmount
280
+ _checkNftType(policyNftId, POLICY());
281
+
282
+ if (beneficiary == address(0)) {
283
+ revert ErrorClaimServiceBeneficiaryIsZero(policyNftId, claimId);
284
+ }
249
285
 
250
- // check/update claim info
251
- // create payout info with instance
252
- uint8 claimNo = claimInfo.payoutsCount + 1;
253
- payoutId = PayoutIdLib.toPayoutId(claimId, claimNo);
254
- instance.getInstanceStore().createPayout(
286
+ return _createPayout(
255
287
  policyNftId,
256
- payoutId,
257
- IPolicy.PayoutInfo(
258
- payoutId.toClaimId(),
259
- amount,
260
- data,
261
- TimestampLib.zero()));
262
-
263
- // update and save claim info with instance
264
- claimInfo.payoutsCount += 1;
265
- claimInfo.openPayoutsCount += 1;
266
- instance.getInstanceStore().updateClaim(policyNftId, claimId, claimInfo, KEEP_STATE());
288
+ claimId,
289
+ amount,
290
+ beneficiary,
291
+ data);
292
+ }
267
293
 
268
- // update and save policy info with instance
269
- policyInfo.payoutAmount.add(amount);
270
- instance.getInstanceStore().updatePolicyClaims(policyNftId, policyInfo, KEEP_STATE());
271
294
 
272
- emit LogClaimServicePayoutCreated(policyNftId, payoutId, amount);
295
+ function createPayout(
296
+ NftId policyNftId,
297
+ ClaimId claimId,
298
+ Amount amount,
299
+ bytes memory data
300
+ )
301
+ external
302
+ virtual
303
+ // nonReentrant() // prevents creating a reinsurance payout in a single tx
304
+ returns (PayoutId payoutId)
305
+ {
306
+ _checkNftType(policyNftId, POLICY());
307
+
308
+ return _createPayout(
309
+ policyNftId,
310
+ claimId,
311
+ amount,
312
+ address(0), // defaults to owner of policy nft
313
+ data);
273
314
  }
274
315
 
275
316
 
@@ -279,10 +320,15 @@ contract ClaimService is
279
320
  )
280
321
  external
281
322
  virtual
323
+ // nonReentrant() // prevents creating a reinsurance payout in a single tx
282
324
  {
325
+ _checkNftType(policyNftId, POLICY());
326
+
283
327
  (
328
+ ,
284
329
  IInstance instance,
285
330
  InstanceReader instanceReader,
331
+ InstanceStore instanceStore,
286
332
  IPolicy.PolicyInfo memory policyInfo
287
333
  ) = _verifyCallerWithPolicy(policyNftId);
288
334
 
@@ -291,50 +337,130 @@ contract ClaimService is
291
337
 
292
338
  // update and save payout info with instance
293
339
  payoutInfo.paidAt = TimestampLib.blockTimestamp();
294
- instance.getInstanceStore().updatePayout(policyNftId, payoutId, payoutInfo, PAID());
340
+ instanceStore.updatePayout(policyNftId, payoutId, payoutInfo, PAID());
295
341
 
296
- // TODO update and save claim info with instance
297
- ClaimId claimId = payoutId.toClaimId();
298
342
  Amount payoutAmount = payoutInfo.amount;
299
- IPolicy.ClaimInfo memory claimInfo = instanceReader.getClaimInfo(policyNftId, claimId);
300
- claimInfo.paidAmount = claimInfo.paidAmount.add(payoutAmount);
301
- claimInfo.openPayoutsCount -= 1;
302
-
303
- // check if this payout is closing the linked claim
304
- // update claim and policy info accordingly
305
- if(claimInfo.openPayoutsCount == 0 && claimInfo.paidAmount == claimInfo.claimAmount) {
306
- claimInfo.closedAt == TimestampLib.blockTimestamp();
307
- instance.getInstanceStore().updateClaim(policyNftId, claimId, claimInfo, CLOSED());
308
-
309
- policyInfo.openClaimsCount -= 1;
310
- } else {
311
- instance.getInstanceStore().updateClaim(policyNftId, claimId, claimInfo, KEEP_STATE());
343
+
344
+ {
345
+ ClaimId claimId = payoutId.toClaimId();
346
+ IPolicy.ClaimInfo memory claimInfo = instanceReader.getClaimInfo(policyNftId, claimId);
347
+ claimInfo.paidAmount = claimInfo.paidAmount.add(payoutAmount);
348
+ claimInfo.openPayoutsCount -= 1;
349
+
350
+ // check if this payout is closing the linked claim
351
+ // update claim and policy info accordingly
352
+ if(claimInfo.openPayoutsCount == 0 && claimInfo.paidAmount == claimInfo.claimAmount) {
353
+ claimInfo.closedAt = TimestampLib.blockTimestamp();
354
+ instanceStore.updateClaim(policyNftId, claimId, claimInfo, CLOSED());
355
+
356
+ policyInfo.openClaimsCount -= 1;
357
+ } else {
358
+ instanceStore.updateClaim(policyNftId, claimId, claimInfo, KEEP_STATE());
359
+ }
312
360
  }
313
361
 
314
362
  // update and save policy info with instance
315
363
  policyInfo.payoutAmount = policyInfo.payoutAmount.add(payoutAmount);
316
- instance.getInstanceStore().updatePolicyClaims(policyNftId, policyInfo, KEEP_STATE());
364
+ instanceStore.updatePolicyClaims(policyNftId, policyInfo, KEEP_STATE());
317
365
 
318
366
  // inform pool about payout
319
- _poolService.reduceCollateral(instance, policyNftId, policyInfo, payoutAmount);
320
-
367
+ _poolService.processPayout(
368
+ instance,
369
+ address(instanceReader.getComponentInfo(policyInfo.productNftId).token),
370
+ policyNftId,
371
+ policyInfo,
372
+ payoutAmount);
373
+
321
374
  // transfer payout token and fee
375
+ {
376
+ (
377
+ Amount netPayoutAmount,
378
+ Amount processingFeeAmount,
379
+ address beneficiary
380
+ ) = _calculatePayoutAmount(
381
+ instanceReader,
382
+ policyNftId,
383
+ policyInfo,
384
+ payoutInfo);
385
+
386
+ emit LogClaimServicePayoutProcessed(policyNftId, payoutId, payoutAmount, beneficiary, netPayoutAmount, processingFeeAmount);
387
+
388
+ {
389
+ NftId poolNftId = getRegistry().getObjectInfo(policyInfo.bundleNftId).parentNftId;
390
+ IComponents.ComponentInfo memory poolInfo = instanceReader.getComponentInfo(poolNftId);
391
+ poolInfo.tokenHandler.pushToken(
392
+ beneficiary,
393
+ netPayoutAmount);
394
+
395
+ // TODO add 2nd token tx if processingFeeAmount > 0
396
+ }
397
+
398
+ // callback to policy holder if applicable
399
+ _policyHolderPayoutExecuted(policyNftId, payoutId, beneficiary, payoutAmount);
400
+ }
401
+ }
402
+
403
+ // internal functions
404
+
405
+
406
+ function _createPayout(
407
+ NftId policyNftId,
408
+ ClaimId claimId,
409
+ Amount amount,
410
+ address beneficiary,
411
+ bytes memory data
412
+ )
413
+ internal
414
+ virtual
415
+ returns (PayoutId payoutId)
416
+ {
322
417
  (
323
- Amount netPayoutAmount,
324
- address beneficiary
325
- ) = _transferPayoutAmount(
326
- instanceReader,
327
- policyNftId,
328
- policyInfo,
329
- payoutInfo);
418
+ ,
419
+ ,
420
+ InstanceReader instanceReader,
421
+ InstanceStore instanceStore,
422
+ IPolicy.PolicyInfo memory policyInfo
423
+ ) = _verifyCallerWithPolicy(policyNftId);
424
+
425
+ IPolicy.ClaimInfo memory claimInfo = instanceReader.getClaimInfo(policyNftId, claimId);
426
+ StateId claimState = instanceReader.getClaimState(policyNftId, claimId);
427
+
428
+ // TODO add checks
429
+ // claim needs to be open
430
+ // claim.paidAmount + amount <= claim.claimAmount
330
431
 
331
- // TODO callback IPolicyHolder
432
+ // check/update claim info
433
+ // create payout info with instance
434
+ uint24 payoutNo = claimInfo.payoutsCount + 1;
435
+ payoutId = PayoutIdLib.toPayoutId(claimId, payoutNo);
436
+ if (beneficiary == address(0)) {
437
+ beneficiary = getRegistry().ownerOf(policyNftId);
438
+ }
332
439
 
333
- emit LogClaimServicePayoutProcessed(policyNftId, payoutId, payoutAmount, beneficiary, netPayoutAmount);
440
+ instanceStore.createPayout(
441
+ policyNftId,
442
+ payoutId,
443
+ IPolicy.PayoutInfo({
444
+ claimId: payoutId.toClaimId(),
445
+ amount: amount,
446
+ beneficiary: beneficiary,
447
+ data: data,
448
+ paidAt: TimestampLib.zero()}));
449
+
450
+ // update and save claim info with instance
451
+ claimInfo.payoutsCount += 1;
452
+ claimInfo.openPayoutsCount += 1;
453
+ instanceStore.updateClaim(policyNftId, claimId, claimInfo, KEEP_STATE());
454
+
455
+ // update and save policy info with instance
456
+ policyInfo.payoutAmount.add(amount);
457
+ instanceStore.updatePolicyClaims(policyNftId, policyInfo, KEEP_STATE());
458
+
459
+ emit LogClaimServicePayoutCreated(policyNftId, payoutId, amount, beneficiary);
334
460
  }
335
461
 
336
- // TODO create (I)TreasuryService that deals with all gif related token transfers
337
- function _transferPayoutAmount(
462
+
463
+ function _calculatePayoutAmount(
338
464
  InstanceReader instanceReader,
339
465
  NftId policyNftId,
340
466
  IPolicy.PolicyInfo memory policyInfo,
@@ -343,6 +469,7 @@ contract ClaimService is
343
469
  internal
344
470
  returns (
345
471
  Amount netPayoutAmount,
472
+ Amount processingFeeAmount,
346
473
  address beneficiary
347
474
  )
348
475
  {
@@ -350,58 +477,44 @@ contract ClaimService is
350
477
 
351
478
  if(payoutAmount.gtz()) {
352
479
  NftId productNftId = policyInfo.productNftId;
353
- ISetup.ProductSetupInfo memory setupInfo = instanceReader.getProductSetupInfo(productNftId);
354
480
 
355
481
  // get pool component info from policy or product
356
482
  NftId poolNftId = getRegistry().getObjectInfo(policyInfo.bundleNftId).parentNftId;
357
483
  IComponents.ComponentInfo memory poolInfo = instanceReader.getComponentInfo(poolNftId);
358
484
 
359
485
  netPayoutAmount = payoutAmount;
360
- beneficiary = _getBeneficiary(policyNftId, payoutInfo.claimId);
361
486
 
362
- if(FeeLib.gtz(setupInfo.processingFee)) {
363
- // TODO calculate net payout and processing fees
364
- // TODO transfer processing fees to product wallet
365
- // TODO inform product to update fee book keeping
487
+ if (payoutInfo.beneficiary == address(0)) {
488
+ beneficiary = getRegistry().ownerOf(policyNftId);
489
+ } else {
490
+ beneficiary = payoutInfo.beneficiary;
366
491
  }
367
492
 
368
- poolInfo.tokenHandler.transfer(
369
- poolInfo.wallet,
370
- beneficiary,
371
- netPayoutAmount);
493
+ IComponents.ProductInfo memory productInfo = instanceReader.getProductInfo(productNftId);
494
+ if(FeeLib.gtz(productInfo.processingFee)) {
495
+ // TODO calculate and set net payout and processing fees
496
+ }
372
497
  }
373
498
  }
374
499
 
375
- // internal functions
376
-
377
- function _getBeneficiary(
378
- NftId policyNftId,
379
- ClaimId claimId
380
- )
381
- internal
382
- returns (address beneficiary)
383
- {
384
- // TODO check if owner is IPolicyHolder
385
- // if so, obtain beneficiary from this contract
386
-
387
- // default beneficiary is policy nft owner
388
- beneficiary = getRegistry().ownerOf(policyNftId);
389
- }
390
-
391
500
 
392
501
  function _verifyCallerWithPolicy(
393
502
  NftId policyNftId
394
503
  )
395
504
  internal
505
+ view
506
+ virtual
396
507
  returns (
508
+ NftId productNftId,
397
509
  IInstance instance,
398
510
  InstanceReader instanceReader,
511
+ InstanceStore instanceStore,
399
512
  IPolicy.PolicyInfo memory policyInfo
400
513
  )
401
514
  {
402
- NftId productNftId;
403
- (productNftId,, instance) = _getAndVerifyCallingComponentAndInstance(PRODUCT());
515
+ (productNftId,, instance) = _getAndVerifyActiveComponent(PRODUCT());
404
516
  instanceReader = instance.getInstanceReader();
517
+ instanceStore = instance.getInstanceStore();
405
518
 
406
519
  // check caller(product) policy match
407
520
  policyInfo = instanceReader.getPolicyInfo(policyNftId);
@@ -435,9 +548,67 @@ contract ClaimService is
435
548
  claimInfo = instanceReader.getClaimInfo(policyNftId, claimId);
436
549
  }
437
550
 
438
- function _getAndVerifyInstanceAndProduct() internal view returns (Product product) {
439
- IRegistry.ObjectInfo memory productInfo;
440
- (, productInfo,) = _getAndVerifyCallingComponentAndInstance(PRODUCT());
441
- product = Product(productInfo.objectAddress);
551
+ function _processConfirmedClaimByPool(
552
+ InstanceReader instanceReader,
553
+ NftId productNftId,
554
+ NftId policyNftId,
555
+ ClaimId claimId,
556
+ Amount amount
557
+ )
558
+ internal
559
+ {
560
+ NftId poolNftId = instanceReader.getProductInfo(productNftId).poolNftId;
561
+ if (instanceReader.getPoolInfo(poolNftId).isProcessingConfirmedClaims) {
562
+ address poolAddress = getRegistry().getObjectAddress(poolNftId);
563
+ IPoolComponent(poolAddress).processConfirmedClaim(policyNftId, claimId, amount);
564
+ }
565
+ }
566
+
567
+
568
+ function _policyHolderClaimConfirmed(
569
+ NftId policyNftId,
570
+ ClaimId claimId,
571
+ Amount confirmedAmount
572
+ )
573
+ internal
574
+ {
575
+ IPolicyHolder policyHolder = _getPolicyHolder(policyNftId);
576
+ if(address(policyHolder) != address(0)) {
577
+ policyHolder.claimConfirmed(policyNftId, claimId, confirmedAmount);
578
+ }
579
+ }
580
+
581
+
582
+ function _policyHolderPayoutExecuted(
583
+ NftId policyNftId,
584
+ PayoutId payoutId,
585
+ address beneficiary,
586
+ Amount payoutAmount
587
+ )
588
+ internal
589
+ {
590
+ IPolicyHolder policyHolder = _getPolicyHolder(policyNftId);
591
+ if(address(policyHolder) != address(0)) {
592
+ policyHolder.payoutExecuted(policyNftId, payoutId, payoutAmount, beneficiary);
593
+ }
594
+ }
595
+
596
+
597
+ function _getPolicyHolder(NftId policyNftId)
598
+ internal
599
+ view
600
+ returns (IPolicyHolder policyHolder)
601
+ {
602
+ address policyHolderAddress = getRegistry().ownerOf(policyNftId);
603
+ policyHolder = IPolicyHolder(policyHolderAddress);
604
+
605
+ if (!ContractLib.isPolicyHolder(policyHolderAddress)) {
606
+ policyHolder = IPolicyHolder(address(0));
607
+ }
608
+ }
609
+
610
+
611
+ function _getDomain() internal pure override returns(ObjectType) {
612
+ return CLAIM();
442
613
  }
443
614
  }