@etherisc/gif-next 0.0.2-a733491-751 → 0.0.2-a78920e-322

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