@etherisc/gif-next 0.0.2-cff6256-424 → 0.0.2-cff7366-494

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 (708) hide show
  1. package/README.md +146 -22
  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/AccessAdmin.sol/IAccessManagedChecker.dbg.json +4 -0
  5. package/artifacts/contracts/authorization/AccessAdmin.sol/IAccessManagedChecker.json +24 -0
  6. package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.dbg.json +4 -0
  7. package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.json +1206 -0
  8. package/artifacts/contracts/authorization/Authorization.sol/Authorization.dbg.json +4 -0
  9. package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +414 -0
  10. package/artifacts/contracts/authorization/IAccess.sol/IAccess.dbg.json +4 -0
  11. package/artifacts/contracts/{instance/module/ISetup.sol/ISetup.json → authorization/IAccess.sol/IAccess.json} +2 -2
  12. package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.dbg.json +4 -0
  13. package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.json +1060 -0
  14. package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +4 -0
  15. package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +295 -0
  16. package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +4 -0
  17. package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.json +167 -0
  18. package/artifacts/contracts/authorization/ReleaseAccessManager.sol/ReleaseAccessManager.dbg.json +4 -0
  19. package/artifacts/contracts/{instance/IAccessManagerSimple.sol/IAccessManagerSimple.json → authorization/ReleaseAccessManager.sol/ReleaseAccessManager.json} +125 -11
  20. package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +4 -0
  21. package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +253 -0
  22. package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +4 -0
  23. package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +1310 -0
  24. package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +4 -0
  25. package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +470 -0
  26. package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +4 -0
  27. package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +1004 -0
  28. package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +4 -0
  29. package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +1494 -0
  30. package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
  31. package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +862 -0
  32. package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +4 -0
  33. package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +903 -0
  34. package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +4 -0
  35. package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +984 -0
  36. package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.dbg.json +4 -0
  37. package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.json +22 -0
  38. package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.dbg.json +4 -0
  39. package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.json +1415 -0
  40. package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +4 -0
  41. package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +502 -0
  42. package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +4 -0
  43. package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +1965 -0
  44. package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +4 -0
  45. package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +470 -0
  46. package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.dbg.json +4 -0
  47. package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.json +376 -0
  48. package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.dbg.json +4 -0
  49. package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.json +1429 -0
  50. package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +4 -0
  51. package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +1163 -0
  52. package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +4 -0
  53. package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +1592 -0
  54. package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +4 -0
  55. package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +2267 -0
  56. package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +4 -0
  57. package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +808 -0
  58. package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
  59. package/artifacts/contracts/instance/IInstance.sol/IInstance.json +585 -309
  60. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
  61. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +400 -171
  62. package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
  63. package/artifacts/contracts/instance/Instance.sol/Instance.json +399 -3011
  64. package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +4 -0
  65. package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +1684 -0
  66. package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +4 -0
  67. package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +574 -0
  68. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
  69. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +1541 -538
  70. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
  71. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +487 -296
  72. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
  73. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +370 -92
  74. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +4 -0
  75. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +3668 -0
  76. package/artifacts/contracts/instance/RiskSet.sol/RiskSet.dbg.json +4 -0
  77. package/artifacts/contracts/instance/RiskSet.sol/RiskSet.json +810 -0
  78. package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +4 -0
  79. package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +318 -0
  80. package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +4 -0
  81. package/artifacts/contracts/instance/{AccessManagedSimple.sol/AccessManagedSimple.json → base/Cloneable.sol/Cloneable.json} +38 -2
  82. package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +4 -0
  83. package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +10 -0
  84. package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.dbg.json +4 -0
  85. package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.json +223 -0
  86. package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.dbg.json +4 -0
  87. package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.json +181 -0
  88. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
  89. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +30 -112
  90. package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
  91. package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +4 -0
  92. package/artifacts/contracts/instance/module/{ITreasury.sol/ITreasury.json → IComponents.sol/IComponents.json} +2 -2
  93. package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
  94. package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
  95. package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
  96. package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +4 -0
  97. package/artifacts/contracts/mock/Dip.sol/Dip.json +376 -0
  98. package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.dbg.json +4 -0
  99. package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.json +947 -0
  100. package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +4 -0
  101. package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +478 -0
  102. package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +4 -0
  103. package/artifacts/contracts/oracle/IOracle.sol/IOracle.json +52 -0
  104. package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +4 -0
  105. package/artifacts/contracts/{instance/service/IProductService.sol/IProductService.json → oracle/IOracleComponent.sol/IOracleComponent.json} +382 -371
  106. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +4 -0
  107. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +709 -0
  108. package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +4 -0
  109. package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +863 -0
  110. package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +4 -0
  111. package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +990 -0
  112. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +4 -0
  113. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +766 -0
  114. package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +4 -0
  115. package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +1240 -0
  116. package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +4 -0
  117. package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +502 -0
  118. package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +4 -0
  119. package/artifacts/contracts/pool/BundleService.sol/BundleService.json +1360 -0
  120. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
  121. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +822 -0
  122. package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +4 -0
  123. package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +922 -0
  124. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
  125. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +895 -0
  126. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +4 -0
  127. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +1285 -0
  128. package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +4 -0
  129. package/artifacts/contracts/pool/Pool.sol/Pool.json +1015 -0
  130. package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +4 -0
  131. package/artifacts/contracts/pool/PoolService.sol/PoolService.json +1619 -0
  132. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
  133. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +794 -0
  134. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +4 -0
  135. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +806 -0
  136. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
  137. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +730 -0
  138. package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +4 -0
  139. package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +1134 -0
  140. package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +4 -0
  141. package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +470 -0
  142. package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +4 -0
  143. package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +1439 -0
  144. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
  145. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +858 -0
  146. package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +4 -0
  147. package/artifacts/contracts/{instance/service/IPoolService.sol/IPoolService.json → product/IApplicationService.sol/IApplicationService.json} +268 -256
  148. package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +4 -0
  149. package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +942 -0
  150. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +4 -0
  151. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +944 -0
  152. package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +4 -0
  153. package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +578 -0
  154. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +4 -0
  155. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +991 -0
  156. package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +4 -0
  157. package/artifacts/contracts/{instance/service/IComponentOwnerService.sol/IComponentOwnerService.json → product/IRiskService.sol/IRiskService.json} +150 -187
  158. package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +4 -0
  159. package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +1313 -0
  160. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
  161. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +810 -0
  162. package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +4 -0
  163. package/artifacts/contracts/product/PricingService.sol/PricingService.json +923 -0
  164. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +4 -0
  165. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +786 -0
  166. package/artifacts/contracts/product/Product.sol/Product.dbg.json +4 -0
  167. package/artifacts/contracts/product/Product.sol/Product.json +1092 -0
  168. package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +4 -0
  169. package/artifacts/contracts/product/RiskService.sol/RiskService.json +638 -0
  170. package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +4 -0
  171. package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +718 -0
  172. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
  173. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +72 -16
  174. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
  175. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +606 -173
  176. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
  177. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +371 -205
  178. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
  179. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +5 -0
  180. package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
  181. package/artifacts/contracts/registry/Registry.sol/Registry.json +938 -206
  182. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +4 -0
  183. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +1899 -0
  184. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
  185. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +347 -322
  186. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
  187. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +340 -128
  188. package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +4 -0
  189. package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +205 -0
  190. package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +4 -0
  191. package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +1067 -0
  192. package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +4 -0
  193. package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +272 -0
  194. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
  195. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +351 -100
  196. package/artifacts/contracts/shared/Component.sol/Component.dbg.json +4 -0
  197. package/artifacts/contracts/shared/Component.sol/Component.json +695 -0
  198. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +4 -0
  199. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +1908 -0
  200. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +4 -0
  201. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +850 -0
  202. package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +4 -0
  203. package/artifacts/contracts/{instance/base/ComponentServiceBase.sol/ComponentServiceBase.json → shared/ComponentVerifyingService.sol/ComponentVerifyingService.json} +182 -189
  204. package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +4 -0
  205. package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +488 -0
  206. package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.dbg.json +4 -0
  207. package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.json +24 -0
  208. package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.dbg.json +4 -0
  209. package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.json +30 -0
  210. package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +4 -0
  211. package/artifacts/contracts/{instance/service/IDistributionService.sol/IDistributionService.json → shared/IComponent.sol/IComponent.json} +346 -172
  212. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +4 -0
  213. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +1467 -0
  214. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +4 -0
  215. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +697 -0
  216. package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
  217. package/artifacts/contracts/{instance/base → shared}/IKeyValueStore.sol/IKeyValueStore.json +95 -14
  218. package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +4 -0
  219. package/artifacts/contracts/{instance/base → shared}/ILifecycle.sol/ILifecycle.json +35 -4
  220. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
  221. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +46 -26
  222. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +4 -0
  223. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +175 -0
  224. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
  225. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +40 -31
  226. package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +4 -0
  227. package/artifacts/contracts/{experiment/inheritance/IA.sol/ISharedA.json → shared/IRegistryLinked.sol/IRegistryLinked.json} +15 -17
  228. package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
  229. package/artifacts/contracts/shared/IService.sol/IService.json +119 -165
  230. package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.dbg.json +4 -0
  231. package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.json +53 -0
  232. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +4 -0
  233. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +785 -0
  234. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +4 -0
  235. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +538 -0
  236. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +4 -0
  237. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +174 -0
  238. package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.dbg.json +4 -0
  239. package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.json +306 -0
  240. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
  241. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +81 -30
  242. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +4 -0
  243. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +198 -0
  244. package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
  245. package/artifacts/contracts/shared/Registerable.sol/Registerable.json +96 -48
  246. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +4 -0
  247. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +58 -0
  248. package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
  249. package/artifacts/contracts/shared/Service.sol/Service.json +150 -176
  250. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
  251. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +734 -8
  252. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.dbg.json +4 -0
  253. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.json +395 -0
  254. package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +4 -0
  255. package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +172 -0
  256. package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +4 -0
  257. package/artifacts/contracts/staking/IStaking.sol/IStaking.json +1435 -0
  258. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +4 -0
  259. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +1043 -0
  260. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +4 -0
  261. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +440 -0
  262. package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +4 -0
  263. package/artifacts/contracts/staking/Staking.sol/Staking.json +1816 -0
  264. package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.dbg.json +4 -0
  265. package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.json +205 -0
  266. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +4 -0
  267. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +780 -0
  268. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +4 -0
  269. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +587 -0
  270. package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +4 -0
  271. package/artifacts/contracts/staking/StakingService.sol/StakingService.json +1265 -0
  272. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +4 -0
  273. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +734 -0
  274. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +4 -0
  275. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +2283 -0
  276. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +4 -0
  277. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +607 -0
  278. package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +4 -0
  279. package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.json +10 -0
  280. package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +4 -0
  281. package/artifacts/contracts/type/Amount.sol/AmountLib.json +398 -0
  282. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +4 -0
  283. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +225 -0
  284. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
  285. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +203 -0
  286. package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +4 -0
  287. package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +104 -0
  288. package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +4 -0
  289. package/artifacts/contracts/type/Fee.sol/FeeLib.json +317 -0
  290. package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +4 -0
  291. package/artifacts/contracts/type/Key32.sol/Key32Lib.json +125 -0
  292. package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.dbg.json +4 -0
  293. package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.json +33 -0
  294. package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +4 -0
  295. package/artifacts/contracts/type/NftId.sol/NftIdLib.json +228 -0
  296. package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +4 -0
  297. package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +33 -0
  298. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +4 -0
  299. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +239 -0
  300. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
  301. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +209 -0
  302. package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +4 -0
  303. package/artifacts/contracts/type/Referral.sol/ReferralLib.json +142 -0
  304. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +4 -0
  305. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +204 -0
  306. package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +4 -0
  307. package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +180 -0
  308. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +4 -0
  309. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +369 -0
  310. package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +4 -0
  311. package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +246 -0
  312. package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +4 -0
  313. package/artifacts/contracts/type/Selector.sol/SelectorLib.json +129 -0
  314. package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +4 -0
  315. package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +10 -0
  316. package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +4 -0
  317. package/artifacts/contracts/type/StateId.sol/StateIdLib.json +105 -0
  318. package/artifacts/contracts/type/String.sol/StrLib.dbg.json +4 -0
  319. package/artifacts/contracts/type/String.sol/StrLib.json +132 -0
  320. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +4 -0
  321. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +312 -0
  322. package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +4 -0
  323. package/artifacts/contracts/type/UFixed.sol/MathLib.json +16 -0
  324. package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +4 -0
  325. package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +548 -0
  326. package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +4 -0
  327. package/artifacts/contracts/type/Version.sol/VersionLib.json +177 -0
  328. package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +4 -0
  329. package/artifacts/contracts/type/Version.sol/VersionPartLib.json +68 -0
  330. package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.dbg.json +4 -0
  331. package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.json +55 -0
  332. package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.dbg.json +4 -0
  333. package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +618 -0
  334. package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +4 -0
  335. package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +129 -0
  336. package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +4 -0
  337. package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.json +78 -0
  338. package/contracts/authorization/AccessAdmin.sol +616 -0
  339. package/contracts/authorization/AccessManagerCloneable.sol +16 -0
  340. package/contracts/authorization/Authorization.sol +289 -0
  341. package/contracts/authorization/IAccess.sol +49 -0
  342. package/contracts/authorization/IAccessAdmin.sol +137 -0
  343. package/contracts/authorization/IAuthorization.sol +60 -0
  344. package/contracts/authorization/IServiceAuthorization.sol +40 -0
  345. package/contracts/authorization/ReleaseAccessManager.sol +38 -0
  346. package/contracts/authorization/ServiceAuthorization.sol +106 -0
  347. package/contracts/distribution/BasicDistribution.sol +139 -0
  348. package/contracts/distribution/BasicDistributionAuthorization.sol +47 -0
  349. package/contracts/distribution/Distribution.sol +284 -0
  350. package/contracts/distribution/DistributionService.sol +354 -0
  351. package/contracts/distribution/DistributionServiceManager.sol +39 -0
  352. package/contracts/distribution/IDistributionComponent.sol +52 -0
  353. package/contracts/distribution/IDistributionService.sol +100 -0
  354. package/contracts/examples/fire/DamageLevel.sol +59 -0
  355. package/contracts/examples/fire/FirePool.sol +86 -0
  356. package/contracts/examples/fire/FirePoolAuthorization.sol +34 -0
  357. package/contracts/examples/fire/FireProduct.sol +431 -0
  358. package/contracts/examples/fire/FireProductAuthorization.sol +44 -0
  359. package/contracts/examples/fire/FireUSD.sol +26 -0
  360. package/contracts/examples/unpermissioned/SimpleDistribution.sol +65 -0
  361. package/contracts/examples/unpermissioned/SimpleOracle.sol +137 -0
  362. package/contracts/examples/unpermissioned/SimplePool.sol +108 -0
  363. package/contracts/examples/unpermissioned/SimpleProduct.sol +345 -0
  364. package/contracts/instance/BundleSet.sol +130 -0
  365. package/contracts/instance/IInstance.sol +57 -19
  366. package/contracts/instance/IInstanceService.sol +57 -17
  367. package/contracts/instance/Instance.sol +169 -373
  368. package/contracts/instance/InstanceAdmin.sol +285 -0
  369. package/contracts/instance/InstanceAuthorizationV3.sol +218 -0
  370. package/contracts/instance/InstanceReader.sol +362 -73
  371. package/contracts/instance/InstanceService.sol +336 -103
  372. package/contracts/instance/InstanceServiceManager.sol +14 -31
  373. package/contracts/instance/InstanceStore.sol +287 -0
  374. package/contracts/instance/RiskSet.sol +119 -0
  375. package/contracts/instance/base/BalanceStore.sol +123 -0
  376. package/contracts/instance/base/Cloneable.sol +28 -0
  377. package/contracts/instance/base/ObjectCounter.sol +21 -0
  378. package/contracts/instance/base/ObjectLifecycle.sol +111 -0
  379. package/contracts/instance/base/ObjectSet.sol +78 -0
  380. package/contracts/instance/module/IAccess.sol +29 -21
  381. package/contracts/instance/module/IBundle.sol +8 -7
  382. package/contracts/instance/module/IComponents.sol +50 -0
  383. package/contracts/instance/module/IDistribution.sol +6 -4
  384. package/contracts/instance/module/IPolicy.sol +59 -19
  385. package/contracts/instance/module/IRisk.sol +2 -1
  386. package/contracts/{test/Usdc.sol → mock/Dip.sol} +6 -6
  387. package/contracts/oracle/BasicOracle.sol +47 -0
  388. package/contracts/oracle/BasicOracleAuthorization.sol +46 -0
  389. package/contracts/oracle/IOracle.sol +36 -0
  390. package/contracts/oracle/IOracleComponent.sol +33 -0
  391. package/contracts/oracle/IOracleService.sol +66 -0
  392. package/contracts/oracle/Oracle.sol +156 -0
  393. package/contracts/oracle/OracleService.sol +309 -0
  394. package/contracts/oracle/OracleServiceManager.sol +39 -0
  395. package/contracts/pool/BasicPool.sol +175 -0
  396. package/contracts/pool/BasicPoolAuthorization.sol +68 -0
  397. package/contracts/pool/BundleService.sol +423 -0
  398. package/contracts/pool/BundleServiceManager.sol +39 -0
  399. package/contracts/pool/IBundleService.sol +122 -0
  400. package/contracts/pool/IPoolComponent.sol +62 -0
  401. package/contracts/pool/IPoolService.sol +153 -0
  402. package/contracts/pool/Pool.sol +345 -0
  403. package/contracts/pool/PoolService.sol +612 -0
  404. package/contracts/pool/PoolServiceManager.sol +39 -0
  405. package/contracts/product/ApplicationService.sol +259 -0
  406. package/contracts/product/ApplicationServiceManager.sol +38 -0
  407. package/contracts/product/BasicProduct.sol +49 -0
  408. package/contracts/product/BasicProductAuthorization.sol +42 -0
  409. package/contracts/product/ClaimService.sol +614 -0
  410. package/contracts/product/ClaimServiceManager.sol +38 -0
  411. package/contracts/product/IApplicationService.sol +66 -0
  412. package/contracts/product/IClaimService.sol +123 -0
  413. package/contracts/product/IPolicyService.sol +90 -0
  414. package/contracts/product/IPricingService.sol +39 -0
  415. package/contracts/product/IProductComponent.sol +59 -0
  416. package/contracts/product/IRiskService.sol +33 -0
  417. package/contracts/product/PolicyService.sol +733 -0
  418. package/contracts/product/PolicyServiceManager.sol +39 -0
  419. package/contracts/product/PricingService.sol +300 -0
  420. package/contracts/product/PricingServiceManager.sol +39 -0
  421. package/contracts/product/Product.sol +427 -0
  422. package/contracts/product/RiskService.sol +107 -0
  423. package/contracts/product/RiskServiceManager.sol +39 -0
  424. package/contracts/registry/ChainNft.sol +78 -33
  425. package/contracts/registry/IRegistry.sol +127 -48
  426. package/contracts/registry/IRegistryService.sol +45 -16
  427. package/contracts/registry/ITransferInterceptor.sol +1 -1
  428. package/contracts/registry/Registry.sol +540 -304
  429. package/contracts/registry/RegistryAdmin.sol +451 -0
  430. package/contracts/registry/RegistryService.sol +126 -284
  431. package/contracts/registry/RegistryServiceManager.sol +26 -53
  432. package/contracts/registry/ReleaseLifecycle.sol +30 -0
  433. package/contracts/registry/ReleaseRegistry.sol +485 -0
  434. package/contracts/registry/ServiceAuthorizationV3.sol +176 -0
  435. package/contracts/registry/TokenRegistry.sol +261 -57
  436. package/contracts/shared/Component.sol +222 -0
  437. package/contracts/shared/ComponentService.sol +866 -0
  438. package/contracts/shared/ComponentServiceManager.sol +38 -0
  439. package/contracts/shared/ComponentVerifyingService.sol +128 -0
  440. package/contracts/shared/ContractLib.sol +224 -0
  441. package/contracts/shared/IComponent.sol +67 -0
  442. package/contracts/shared/IComponentService.sol +134 -0
  443. package/contracts/shared/IInstanceLinkedComponent.sol +30 -0
  444. package/contracts/{instance/base → shared}/IKeyValueStore.sol +16 -11
  445. package/contracts/{instance/base → shared}/ILifecycle.sol +5 -4
  446. package/contracts/shared/INftOwnable.sol +15 -12
  447. package/contracts/shared/IPolicyHolder.sol +35 -0
  448. package/contracts/shared/IRegisterable.sol +15 -6
  449. package/contracts/shared/IRegistryLinked.sol +11 -0
  450. package/contracts/shared/IService.sol +16 -6
  451. package/contracts/shared/InitializableERC165.sol +27 -0
  452. package/contracts/shared/InstanceLinkedComponent.sol +197 -0
  453. package/contracts/shared/KeyValueStore.sol +131 -0
  454. package/contracts/shared/Lifecycle.sol +88 -0
  455. package/contracts/shared/NftIdSet.sol +65 -0
  456. package/contracts/shared/NftOwnable.sol +75 -84
  457. package/contracts/shared/PolicyHolder.sol +62 -0
  458. package/contracts/shared/Registerable.sol +34 -41
  459. package/contracts/shared/RegistryLinked.sol +38 -0
  460. package/contracts/shared/Service.sol +61 -31
  461. package/contracts/shared/TokenHandler.sol +374 -12
  462. package/contracts/shared/TokenHandlerDeployerLib.sol +20 -0
  463. package/contracts/staking/IStaking.sol +173 -0
  464. package/contracts/staking/IStakingService.sol +157 -0
  465. package/contracts/staking/StakeManagerLib.sol +224 -0
  466. package/contracts/staking/Staking.sol +505 -0
  467. package/contracts/staking/StakingLifecycle.sol +23 -0
  468. package/contracts/staking/StakingManager.sol +52 -0
  469. package/contracts/staking/StakingReader.sol +190 -0
  470. package/contracts/staking/StakingService.sol +440 -0
  471. package/contracts/staking/StakingServiceManager.sol +44 -0
  472. package/contracts/staking/StakingStore.sol +605 -0
  473. package/contracts/staking/TargetManagerLib.sol +211 -0
  474. package/contracts/{types → type}/AddressSet.sol +1 -1
  475. package/contracts/type/Amount.sol +150 -0
  476. package/contracts/{types → type}/Blocknumber.sol +27 -3
  477. package/contracts/type/ClaimId.sol +80 -0
  478. package/contracts/{types → type}/DistributorType.sol +2 -2
  479. package/contracts/{types → type}/Fee.sol +33 -23
  480. package/contracts/{types → type}/Key32.sol +2 -2
  481. package/contracts/type/Key32Set.sol +62 -0
  482. package/contracts/{types → type}/NftId.sol +28 -15
  483. package/contracts/type/NftIdSet.sol +62 -0
  484. package/contracts/type/ObjectType.sol +278 -0
  485. package/contracts/type/PayoutId.sol +82 -0
  486. package/contracts/{types → type}/Referral.sol +6 -1
  487. package/contracts/type/RequestId.sol +75 -0
  488. package/contracts/{types → type}/RiskId.sol +31 -5
  489. package/contracts/type/RoleId.sol +162 -0
  490. package/contracts/type/Seconds.sol +101 -0
  491. package/contracts/type/Selector.sol +102 -0
  492. package/contracts/{types → type}/StateId.sol +48 -4
  493. package/contracts/type/String.sol +53 -0
  494. package/contracts/{types → type}/Timestamp.sol +34 -15
  495. package/contracts/{types → type}/UFixed.sol +39 -9
  496. package/contracts/{types → type}/Version.sol +5 -2
  497. package/contracts/{shared → upgradeability}/IVersionable.sol +5 -48
  498. package/contracts/upgradeability/ProxyManager.sol +232 -0
  499. package/contracts/{shared → upgradeability}/UpgradableProxyWithAdmin.sol +1 -3
  500. package/contracts/upgradeability/Versionable.sol +59 -0
  501. package/package.json +11 -7
  502. package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +0 -4
  503. package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.json +0 -327
  504. package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +0 -4
  505. package/artifacts/contracts/components/Distribution.sol/Distribution.json +0 -670
  506. package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +0 -4
  507. package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.json +0 -280
  508. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +0 -4
  509. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +0 -204
  510. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +0 -4
  511. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +0 -249
  512. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +0 -4
  513. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +0 -157
  514. package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +0 -4
  515. package/artifacts/contracts/components/Pool.sol/Pool.json +0 -790
  516. package/artifacts/contracts/components/Product.sol/Product.dbg.json +0 -4
  517. package/artifacts/contracts/components/Product.sol/Product.json +0 -775
  518. package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.dbg.json +0 -4
  519. package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.json +0 -66
  520. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.dbg.json +0 -4
  521. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.json +0 -24
  522. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.dbg.json +0 -4
  523. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.json +0 -42
  524. package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +0 -4
  525. package/artifacts/contracts/experiment/errors/Require.sol/Require.json +0 -105
  526. package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +0 -4
  527. package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +0 -105
  528. package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +0 -4
  529. package/artifacts/contracts/experiment/inheritance/A.sol/A.json +0 -128
  530. package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +0 -4
  531. package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +0 -42
  532. package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +0 -4
  533. package/artifacts/contracts/experiment/inheritance/B.sol/B.json +0 -76
  534. package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +0 -4
  535. package/artifacts/contracts/experiment/inheritance/C.sol/C.json +0 -89
  536. package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +0 -4
  537. package/artifacts/contracts/experiment/inheritance/IA.sol/IA.json +0 -128
  538. package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +0 -4
  539. package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +0 -4
  540. package/artifacts/contracts/experiment/inheritance/IB.sol/IB.json +0 -50
  541. package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +0 -4
  542. package/artifacts/contracts/experiment/inheritance/IC.sol/IC.json +0 -63
  543. package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.dbg.json +0 -4
  544. package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +0 -59
  545. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +0 -4
  546. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.json +0 -124
  547. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +0 -4
  548. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.json +0 -74
  549. package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +0 -4
  550. package/artifacts/contracts/experiment/statemachine/SM.sol/SM.json +0 -124
  551. package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +0 -4
  552. package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.json +0 -207
  553. package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +0 -4
  554. package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.json +0 -10
  555. package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +0 -4
  556. package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.json +0 -10
  557. package/artifacts/contracts/instance/AccessManagedSimple.sol/AccessManagedSimple.dbg.json +0 -4
  558. package/artifacts/contracts/instance/AccessManagerSimple.sol/AccessManagerSimple.dbg.json +0 -4
  559. package/artifacts/contracts/instance/AccessManagerSimple.sol/AccessManagerSimple.json +0 -1132
  560. package/artifacts/contracts/instance/IAccessManagerSimple.sol/IAccessManagerSimple.dbg.json +0 -4
  561. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +0 -4
  562. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +0 -917
  563. package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +0 -4
  564. package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +0 -4
  565. package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.json +0 -113
  566. package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +0 -4
  567. package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +0 -4
  568. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +0 -4
  569. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +0 -502
  570. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +0 -4
  571. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +0 -169
  572. package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +0 -4
  573. package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +0 -4
  574. package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +0 -4
  575. package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +0 -827
  576. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +0 -4
  577. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +0 -641
  578. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +0 -4
  579. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +0 -428
  580. package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +0 -4
  581. package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +0 -4
  582. package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +0 -4
  583. package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +0 -4
  584. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +0 -4
  585. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +0 -107
  586. package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +0 -4
  587. package/artifacts/contracts/shared/ERC165.sol/ERC165.json +0 -35
  588. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +0 -4
  589. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +0 -205
  590. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +0 -4
  591. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +0 -349
  592. package/artifacts/contracts/shared/RegisterableUpgradable.sol/RegisterableUpgradable.dbg.json +0 -4
  593. package/artifacts/contracts/shared/RegisterableUpgradable.sol/RegisterableUpgradable.json +0 -442
  594. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +0 -4
  595. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +0 -129
  596. package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +0 -4
  597. package/artifacts/contracts/shared/Versionable.sol/Versionable.json +0 -228
  598. package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +0 -4
  599. package/artifacts/contracts/test/TestFee.sol/TestFee.json +0 -119
  600. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +0 -4
  601. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +0 -305
  602. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +0 -4
  603. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +0 -116
  604. package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +0 -4
  605. package/artifacts/contracts/test/TestService.sol/TestService.json +0 -600
  606. package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +0 -4
  607. package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +0 -376
  608. package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +0 -4
  609. package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +0 -218
  610. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +0 -4
  611. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +0 -286
  612. package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +0 -4
  613. package/artifacts/contracts/test/Usdc.sol/USDC.json +0 -376
  614. package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +0 -4
  615. package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.json +0 -10
  616. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +0 -4
  617. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +0 -174
  618. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +0 -4
  619. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +0 -10
  620. package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +0 -4
  621. package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.json +0 -104
  622. package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +0 -4
  623. package/artifacts/contracts/types/Fee.sol/FeeLib.json +0 -257
  624. package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +0 -4
  625. package/artifacts/contracts/types/Key32.sol/Key32Lib.json +0 -125
  626. package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +0 -4
  627. package/artifacts/contracts/types/NftId.sol/NftIdLib.json +0 -153
  628. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +0 -4
  629. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.json +0 -10
  630. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +0 -4
  631. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.json +0 -100
  632. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +0 -4
  633. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +0 -92
  634. package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +0 -4
  635. package/artifacts/contracts/types/Referral.sol/ReferralLib.json +0 -123
  636. package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +0 -4
  637. package/artifacts/contracts/types/RiskId.sol/RiskIdLib.json +0 -86
  638. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +0 -4
  639. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +0 -156
  640. package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +0 -4
  641. package/artifacts/contracts/types/StateId.sol/StateIdLib.json +0 -92
  642. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +0 -4
  643. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +0 -249
  644. package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +0 -4
  645. package/artifacts/contracts/types/UFixed.sol/MathLib.json +0 -10
  646. package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +0 -4
  647. package/artifacts/contracts/types/UFixed.sol/UFixedLib.json +0 -479
  648. package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +0 -4
  649. package/artifacts/contracts/types/Version.sol/VersionLib.json +0 -177
  650. package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +0 -4
  651. package/artifacts/contracts/types/Version.sol/VersionPartLib.json +0 -49
  652. package/contracts/components/BaseComponent.sol +0 -91
  653. package/contracts/components/Distribution.sol +0 -166
  654. package/contracts/components/IBaseComponent.sol +0 -25
  655. package/contracts/components/IDistributionComponent.sol +0 -46
  656. package/contracts/components/IPoolComponent.sol +0 -62
  657. package/contracts/components/IProductComponent.sol +0 -35
  658. package/contracts/components/Pool.sol +0 -258
  659. package/contracts/components/Product.sol +0 -297
  660. package/contracts/experiment/cloning/Cloner.sol +0 -47
  661. package/contracts/experiment/errors/Require.sol +0 -38
  662. package/contracts/experiment/errors/Revert.sol +0 -44
  663. package/contracts/experiment/inheritance/A.sol +0 -53
  664. package/contracts/experiment/inheritance/B.sol +0 -28
  665. package/contracts/experiment/inheritance/C.sol +0 -34
  666. package/contracts/experiment/inheritance/IA.sol +0 -13
  667. package/contracts/experiment/inheritance/IB.sol +0 -10
  668. package/contracts/experiment/inheritance/IC.sol +0 -12
  669. package/contracts/experiment/statemachine/Dummy.sol +0 -27
  670. package/contracts/experiment/statemachine/ISM.sol +0 -25
  671. package/contracts/experiment/statemachine/SM.sol +0 -57
  672. package/contracts/experiment/statemachine/SimpleStateMachine.sol +0 -31
  673. package/contracts/experiment/types/TypeA.sol +0 -47
  674. package/contracts/experiment/types/TypeB.sol +0 -29
  675. package/contracts/instance/AccessManagedSimple.sol +0 -115
  676. package/contracts/instance/AccessManagerSimple.sol +0 -692
  677. package/contracts/instance/IAccessManagerSimple.sol +0 -391
  678. package/contracts/instance/InstanceAccessManager.sol +0 -288
  679. package/contracts/instance/base/ComponentServiceBase.sol +0 -39
  680. package/contracts/instance/base/IInstanceBase.sol +0 -23
  681. package/contracts/instance/base/KeyValueStore.sol +0 -172
  682. package/contracts/instance/base/Lifecycle.sol +0 -100
  683. package/contracts/instance/module/ISetup.sol +0 -43
  684. package/contracts/instance/module/ITreasury.sol +0 -23
  685. package/contracts/instance/service/ComponentOwnerService.sol +0 -317
  686. package/contracts/instance/service/DistributionService.sol +0 -96
  687. package/contracts/instance/service/DistributionServiceManager.sol +0 -53
  688. package/contracts/instance/service/IComponentOwnerService.sol +0 -20
  689. package/contracts/instance/service/IDistributionService.sol +0 -12
  690. package/contracts/instance/service/IPoolService.sol +0 -37
  691. package/contracts/instance/service/IProductService.sol +0 -107
  692. package/contracts/shared/ContractDeployerLib.sol +0 -72
  693. package/contracts/shared/ERC165.sol +0 -25
  694. package/contracts/shared/ProxyManager.sol +0 -94
  695. package/contracts/shared/RegisterableUpgradable.sol +0 -16
  696. package/contracts/shared/Versionable.sol +0 -147
  697. package/contracts/test/TestFee.sol +0 -25
  698. package/contracts/test/TestRegisterable.sol +0 -18
  699. package/contracts/test/TestRoleId.sol +0 -14
  700. package/contracts/test/TestService.sol +0 -24
  701. package/contracts/test/TestToken.sol +0 -26
  702. package/contracts/test/TestVersion.sol +0 -44
  703. package/contracts/test/TestVersionable.sol +0 -17
  704. package/contracts/types/ChainId.sol +0 -38
  705. package/contracts/types/NftIdSet.sol +0 -60
  706. package/contracts/types/NumberId.sol +0 -52
  707. package/contracts/types/ObjectType.sol +0 -152
  708. package/contracts/types/RoleId.sol +0 -88
@@ -0,0 +1,866 @@
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 {IPoolComponent} from "../pool/IPoolComponent.sol";
21
+ import {IProductComponent} from "../product/IProductComponent.sol";
22
+ import {IRegisterable} from "../shared/IRegisterable.sol";
23
+ import {IRegistry} from "../registry/IRegistry.sol";
24
+ import {IRegistryService} from "../registry/IRegistryService.sol";
25
+
26
+ import {Amount, AmountLib} from "../type/Amount.sol";
27
+ import {ContractLib} from "../shared/ContractLib.sol";
28
+ import {Fee, FeeLib} from "../type/Fee.sol";
29
+ import {KEEP_STATE} from "../type/StateId.sol";
30
+ import {NftId} from "../type/NftId.sol";
31
+ import {ObjectType, REGISTRY, BUNDLE, COMPONENT, DISTRIBUTION, DISTRIBUTOR, INSTANCE, ORACLE, POOL, PRODUCT, STAKING} from "../type/ObjectType.sol";
32
+ import {Service} from "../shared/Service.sol";
33
+ import {TokenHandler} from "../shared/TokenHandler.sol";
34
+ import {TokenHandlerDeployerLib} from "../shared/TokenHandlerDeployerLib.sol";
35
+ import {VersionPart} from "../type/Version.sol";
36
+
37
+
38
+ contract ComponentService is
39
+ Service,
40
+ IComponentService
41
+ {
42
+ bool private constant INCREASE = true;
43
+ bool private constant DECREASE = false;
44
+
45
+ IRegistryService private _registryService;
46
+ IInstanceService private _instanceService;
47
+
48
+ modifier onlyComponent(address component) {
49
+ _checkSupportsInterface(component);
50
+ _;
51
+ }
52
+
53
+ modifier onlyInstance() {
54
+ NftId instanceNftId = getRegistry().getNftIdForAddress(msg.sender);
55
+ if (instanceNftId.eqz()) {
56
+ revert ErrorComponentServiceNotRegistered(msg.sender);
57
+ }
58
+
59
+ ObjectType objectType = getRegistry().getObjectInfo(instanceNftId).objectType;
60
+ if (objectType != INSTANCE()) {
61
+ revert ErrorComponentServiceNotInstance(msg.sender, objectType);
62
+ }
63
+
64
+ VersionPart instanceVersion = IInstance(msg.sender).getRelease();
65
+ if (instanceVersion != getVersion().toMajorPart()) {
66
+ revert ErrorComponentServiceInstanceVersionMismatch(msg.sender, instanceVersion);
67
+ }
68
+
69
+ _;
70
+ }
71
+
72
+
73
+ function _initialize(
74
+ address owner,
75
+ bytes memory data
76
+ )
77
+ internal
78
+ virtual override
79
+ initializer()
80
+ {
81
+ (
82
+ address registryAddress,
83
+ address authority
84
+ ) = abi.decode(data, (address, address));
85
+
86
+ _initializeService(registryAddress, authority, owner);
87
+
88
+ _registryService = IRegistryService(_getServiceAddress(REGISTRY()));
89
+ _instanceService = IInstanceService(_getServiceAddress(INSTANCE()));
90
+
91
+ _registerInterface(type(IComponentService).interfaceId);
92
+ }
93
+
94
+ //-------- component ----------------------------------------------------//
95
+
96
+ function registerComponent(address component)
97
+ external
98
+ virtual
99
+ onlyComponent(component)
100
+ returns (NftId componentNftId)
101
+ {
102
+ // type specific registration
103
+ ObjectType componentType = IInstanceLinkedComponent(component).getInitialInfo().objectType;
104
+ if (componentType == POOL()) {
105
+ return _registerPool(component);
106
+ }
107
+ if (componentType == DISTRIBUTION()) {
108
+ return _registerDistribution(component);
109
+ }
110
+ if (componentType == ORACLE()) {
111
+ return _registerOracle(component);
112
+ }
113
+
114
+ // fail
115
+ revert ErrorComponentServiceTypeNotSupported(component, componentType);
116
+ }
117
+
118
+ function approveTokenHandler(
119
+ IERC20Metadata token,
120
+ Amount amount
121
+ )
122
+ external
123
+ virtual
124
+ {
125
+ // checks
126
+ (NftId componentNftId, IInstance instance) = _getAndVerifyActiveComponent(COMPONENT());
127
+ TokenHandler tokenHandler = instance.getInstanceReader().getComponentInfo(
128
+ componentNftId).tokenHandler;
129
+
130
+ // effects
131
+ tokenHandler.approve(token, amount);
132
+ }
133
+
134
+
135
+ function approveStakingTokenHandler(
136
+ IERC20Metadata token,
137
+ Amount amount
138
+ )
139
+ external
140
+ virtual
141
+ {
142
+ // checks
143
+ ContractLib.getAndVerifyStaking(
144
+ getRegistry(),
145
+ msg.sender); // only active
146
+
147
+ // effects
148
+ TokenHandler tokenHandler = IComponent(msg.sender).getTokenHandler();
149
+ tokenHandler.approve(token, amount);
150
+ }
151
+
152
+
153
+ function setWallet(address newWallet)
154
+ external
155
+ virtual
156
+ {
157
+ // checks
158
+ (NftId componentNftId, IInstance instance) = _getAndVerifyActiveComponent(COMPONENT());
159
+ TokenHandler tokenHandler = instance.getInstanceReader().getComponentInfo(
160
+ componentNftId).tokenHandler;
161
+
162
+ // effects
163
+ tokenHandler.setWallet(newWallet);
164
+ }
165
+
166
+ /// @inheritdoc IComponentService
167
+ function setLockedFromInstance(address componentAddress, bool locked)
168
+ external
169
+ virtual
170
+ onlyInstance()
171
+ {
172
+ address instanceAddress = msg.sender;
173
+ // NftId instanceNftId = getRegistry().getNftIdForAddress(msg.sender);
174
+ IInstance instance = IInstance(instanceAddress);
175
+ _setLocked(instance.getInstanceAdmin(), componentAddress, locked);
176
+ }
177
+
178
+ /// @inheritdoc IComponentService
179
+ function setLockedFromComponent(address componentAddress, bool locked)
180
+ external
181
+ virtual
182
+ onlyComponent(msg.sender)
183
+ {
184
+ (, IInstance instance) = _getAndVerifyComponent(COMPONENT(), false);
185
+ _setLocked(instance.getInstanceAdmin(), componentAddress, locked);
186
+ }
187
+
188
+ function withdrawFees(Amount amount)
189
+ external
190
+ virtual
191
+ returns (Amount withdrawnAmount)
192
+ {
193
+ (NftId componentNftId, IInstance instance) = _getAndVerifyActiveComponent(COMPONENT());
194
+ IComponents.ComponentInfo memory info = instance.getInstanceReader().getComponentInfo(componentNftId);
195
+ address componentWallet = info.tokenHandler.getWallet();
196
+
197
+ // determine withdrawn amount
198
+ withdrawnAmount = amount;
199
+ if (withdrawnAmount.gte(AmountLib.max())) {
200
+ withdrawnAmount = instance.getInstanceReader().getFeeAmount(componentNftId);
201
+ } else if (withdrawnAmount.eqz()) {
202
+ revert ErrorComponentServiceWithdrawAmountIsZero();
203
+ } else {
204
+ Amount withdrawLimit = instance.getInstanceReader().getFeeAmount(componentNftId);
205
+ if (withdrawnAmount.gt(withdrawLimit)) {
206
+ revert ErrorComponentServiceWithdrawAmountExceedsLimit(withdrawnAmount, withdrawLimit);
207
+ }
208
+ }
209
+
210
+ // decrease fee counters by withdrawnAmount
211
+ _changeTargetBalance(DECREASE, instance.getInstanceStore(), componentNftId, AmountLib.zero(), withdrawnAmount);
212
+
213
+ // transfer amount to component owner
214
+ address componentOwner = getRegistry().ownerOf(componentNftId);
215
+ emit LogComponentServiceComponentFeesWithdrawn(componentNftId, componentOwner, address(info.token), withdrawnAmount);
216
+ info.tokenHandler.distributeTokens(componentWallet, componentOwner, withdrawnAmount);
217
+ }
218
+
219
+
220
+ //-------- product ------------------------------------------------------//
221
+
222
+ function registerProduct(address productAddress)
223
+ external
224
+ virtual
225
+ onlyComponent(productAddress)
226
+ returns (NftId productNftId)
227
+ {
228
+ // register/create component setup
229
+ InstanceAdmin instanceAdmin;
230
+ InstanceStore instanceStore;
231
+ (, instanceAdmin, instanceStore,, productNftId) = _register(
232
+ productAddress,
233
+ PRODUCT());
234
+
235
+ // get product
236
+ IProductComponent product = IProductComponent(productAddress);
237
+
238
+ // create info
239
+ instanceStore.createProduct(
240
+ productNftId,
241
+ product.getInitialProductInfo());
242
+
243
+ // authorize
244
+ instanceAdmin.initializeComponentAuthorization(product);
245
+ }
246
+
247
+
248
+ function setProductFees(
249
+ Fee memory productFee, // product fee on net premium
250
+ Fee memory processingFee // product fee on payout amounts
251
+ )
252
+ external
253
+ virtual
254
+ {
255
+ (NftId productNftId, IInstance instance) = _getAndVerifyActiveComponent(PRODUCT());
256
+ IComponents.ProductInfo memory productInfo = instance.getInstanceReader().getProductInfo(productNftId);
257
+ bool feesChanged = false;
258
+
259
+ // update product fee if required
260
+ if(!FeeLib.eq(productInfo.productFee, productFee)) {
261
+ _logUpdateFee(productNftId, "ProductFee", productInfo.productFee, productFee);
262
+ productInfo.productFee = productFee;
263
+ feesChanged = true;
264
+ }
265
+
266
+ // update processing fee if required
267
+ if(!FeeLib.eq(productInfo.processingFee, processingFee)) {
268
+ _logUpdateFee(productNftId, "ProcessingFee", productInfo.processingFee, processingFee);
269
+ productInfo.processingFee = processingFee;
270
+ feesChanged = true;
271
+ }
272
+
273
+ if(feesChanged) {
274
+ instance.getInstanceStore().updateProduct(productNftId, productInfo, KEEP_STATE());
275
+ emit LogComponentServiceProductFeesUpdated(productNftId);
276
+ }
277
+ }
278
+
279
+ function increaseProductFees(
280
+ InstanceStore instanceStore,
281
+ NftId productNftId,
282
+ Amount feeAmount
283
+ )
284
+ external
285
+ virtual
286
+ // TODO re-enable once role granting is stable and fixed
287
+ // restricted()
288
+ {
289
+ _checkNftType(productNftId, PRODUCT());
290
+ _changeTargetBalance(INCREASE, instanceStore, productNftId, AmountLib.zero(), feeAmount);
291
+ }
292
+
293
+
294
+ function decreaseProductFees(InstanceStore instanceStore, NftId productNftId, Amount feeAmount)
295
+ external
296
+ virtual
297
+ // TODO re-enable once role granting is stable and fixed
298
+ // restricted()
299
+ {
300
+ _checkNftType(productNftId, PRODUCT());
301
+ _changeTargetBalance(DECREASE, instanceStore, productNftId, AmountLib.zero(), feeAmount);
302
+ }
303
+
304
+ //-------- distribution -------------------------------------------------//
305
+
306
+ /// @dev registers the sending component as a distribution component
307
+ function _registerDistribution(address distributioAddress)
308
+ internal
309
+ virtual
310
+ returns (NftId distributionNftId)
311
+ {
312
+ // register/create component info
313
+ InstanceReader instanceReader;
314
+ InstanceAdmin instanceAdmin;
315
+ InstanceStore instanceStore;
316
+ NftId productNftId;
317
+ (instanceReader, instanceAdmin, instanceStore, productNftId, distributionNftId) = _register(
318
+ distributioAddress,
319
+ DISTRIBUTION());
320
+
321
+ // check product is still expecting a distribution registration
322
+ IComponents.ProductInfo memory productInfo = instanceReader.getProductInfo(productNftId);
323
+ if (!productInfo.hasDistribution) {
324
+ revert ErrorProductServiceNoDistributionExpected(productNftId);
325
+ }
326
+ if (productInfo.distributionNftId.gtz()) {
327
+ revert ErrorProductServiceDistributionAlreadyRegistered(productNftId, productInfo.distributionNftId);
328
+ }
329
+
330
+ // set distribution in product info
331
+ productInfo.distributionNftId = distributionNftId;
332
+ instanceStore.updateProduct(productNftId, productInfo, KEEP_STATE());
333
+
334
+ // authorize
335
+ instanceAdmin.initializeComponentAuthorization(
336
+ IInstanceLinkedComponent(distributioAddress));
337
+ }
338
+
339
+
340
+ function setDistributionFees(
341
+ Fee memory distributionFee, // distribution fee for sales that do not include commissions
342
+ Fee memory minDistributionOwnerFee // min fee required by distribution owner (not including commissions for distributors)
343
+ )
344
+ external
345
+ virtual
346
+ {
347
+ (NftId distributionNftId, IInstance instance) = _getAndVerifyActiveComponent(DISTRIBUTION());
348
+ (NftId productNftId, IComponents.ProductInfo memory productInfo) = _getLinkedProductInfo(
349
+ instance.getInstanceReader(), distributionNftId);
350
+ bool feesChanged = false;
351
+
352
+ // update distributino fee if required
353
+ if(!FeeLib.eq(productInfo.distributionFee, distributionFee)) {
354
+ _logUpdateFee(productNftId, "DistributionFee", productInfo.distributionFee, distributionFee);
355
+ productInfo.distributionFee = distributionFee;
356
+ feesChanged = true;
357
+ }
358
+
359
+ // update min distribution owner fee if required
360
+ if(!FeeLib.eq(productInfo.minDistributionOwnerFee, minDistributionOwnerFee)) {
361
+ _logUpdateFee(productNftId, "MinDistributionOwnerFee", productInfo.minDistributionOwnerFee, minDistributionOwnerFee);
362
+ productInfo.minDistributionOwnerFee = minDistributionOwnerFee;
363
+ feesChanged = true;
364
+ }
365
+
366
+ if(feesChanged) {
367
+ instance.getInstanceStore().updateProduct(productNftId, productInfo, KEEP_STATE());
368
+ emit LogComponentServiceDistributionFeesUpdated(distributionNftId);
369
+ }
370
+ }
371
+
372
+ function increaseDistributionBalance(
373
+ InstanceStore instanceStore,
374
+ NftId distributionNftId,
375
+ Amount amount,
376
+ Amount feeAmount
377
+ )
378
+ external
379
+ virtual
380
+ // TODO re-enable once role granting is stable and fixed
381
+ // restricted()
382
+ {
383
+ _checkNftType(distributionNftId, DISTRIBUTION());
384
+ _changeTargetBalance(INCREASE, instanceStore, distributionNftId, amount, feeAmount);
385
+ }
386
+
387
+
388
+ function decreaseDistributionBalance(
389
+ InstanceStore instanceStore,
390
+ NftId distributionNftId,
391
+ Amount amount,
392
+ Amount feeAmount
393
+ )
394
+ external
395
+ virtual
396
+ // TODO re-enable once role granting is stable and fixed
397
+ // restricted()
398
+ {
399
+ _checkNftType(distributionNftId, DISTRIBUTION());
400
+ _changeTargetBalance(DECREASE, instanceStore, distributionNftId, amount, feeAmount);
401
+ }
402
+
403
+ //-------- distributor -------------------------------------------------------//
404
+
405
+ function increaseDistributorBalance(
406
+ InstanceStore instanceStore,
407
+ NftId distributorNftId,
408
+ Amount amount,
409
+ Amount feeAmount
410
+ )
411
+ external
412
+ virtual
413
+ // TODO re-enable once role granting is stable and fixed
414
+ // restricted()
415
+ {
416
+ _checkNftType(distributorNftId, DISTRIBUTOR());
417
+ _changeTargetBalance(INCREASE, instanceStore, distributorNftId, amount, feeAmount);
418
+ }
419
+
420
+ function decreaseDistributorBalance(
421
+ InstanceStore instanceStore,
422
+ NftId distributorNftId,
423
+ Amount amount,
424
+ Amount feeAmount
425
+ )
426
+ external
427
+ virtual
428
+ // TODO re-enable once role granting is stable and fixed
429
+ // restricted()
430
+ {
431
+ _checkNftType(distributorNftId, DISTRIBUTOR());
432
+ _changeTargetBalance(DECREASE, instanceStore, distributorNftId, amount, feeAmount);
433
+ }
434
+
435
+ //-------- oracle -------------------------------------------------------//
436
+
437
+ function _registerOracle(address oracleAddress)
438
+ internal
439
+ virtual
440
+ returns (NftId oracleNftId)
441
+ {
442
+ // register/create component setup
443
+ InstanceReader instanceReader;
444
+ InstanceAdmin instanceAdmin;
445
+ InstanceStore instanceStore;
446
+ NftId productNftId;
447
+
448
+ (instanceReader, instanceAdmin, instanceStore, productNftId, oracleNftId) = _register(
449
+ oracleAddress,
450
+ ORACLE());
451
+
452
+ // check product is still expecting an oracle registration
453
+ IComponents.ProductInfo memory productInfo = instanceReader.getProductInfo(productNftId);
454
+ if (productInfo.expectedNumberOfOracles == 0) {
455
+ revert ErrorProductServiceNoOraclesExpected(productNftId);
456
+ }
457
+ if (productInfo.numberOfOracles == productInfo.expectedNumberOfOracles) {
458
+ revert ErrorProductServiceOraclesAlreadyRegistered(productNftId, productInfo.expectedNumberOfOracles);
459
+ }
460
+
461
+ // update/add oracle to product info
462
+ productInfo.oracleNftId[productInfo.numberOfOracles] = oracleNftId;
463
+ productInfo.numberOfOracles++;
464
+ instanceStore.updateProduct(productNftId, productInfo, KEEP_STATE());
465
+
466
+ // authorize
467
+ instanceAdmin.initializeComponentAuthorization(
468
+ IInstanceLinkedComponent(oracleAddress));
469
+ }
470
+
471
+ //-------- pool ---------------------------------------------------------//
472
+
473
+ function _registerPool(address poolAddress)
474
+ internal
475
+ virtual
476
+ returns (NftId poolNftId)
477
+ {
478
+ // register/create component setup
479
+ InstanceReader instanceReader;
480
+ InstanceAdmin instanceAdmin;
481
+ InstanceStore instanceStore;
482
+ NftId productNftId;
483
+
484
+ (instanceReader, instanceAdmin, instanceStore, productNftId, poolNftId) = _register(
485
+ poolAddress,
486
+ POOL());
487
+
488
+ // check product is still expecting a pool registration
489
+ IComponents.ProductInfo memory productInfo = instanceReader.getProductInfo(productNftId);
490
+ if (productInfo.poolNftId.gtz()) {
491
+ revert ErrorProductServicePoolAlreadyRegistered(productNftId, productInfo.poolNftId);
492
+ }
493
+
494
+ // create info
495
+ IPoolComponent pool = IPoolComponent(poolAddress);
496
+ instanceStore.createPool(
497
+ poolNftId,
498
+ pool.getInitialPoolInfo());
499
+
500
+ // update pool in product info
501
+ productInfo.poolNftId = poolNftId;
502
+ instanceStore.updateProduct(productNftId, productInfo, KEEP_STATE());
503
+
504
+ // authorize
505
+ instanceAdmin.initializeComponentAuthorization(pool);
506
+ }
507
+
508
+
509
+ function setPoolFees(
510
+ Fee memory poolFee, // pool fee on net premium
511
+ Fee memory stakingFee, // pool fee on staked capital from investor
512
+ Fee memory performanceFee // pool fee on profits from capital investors
513
+ )
514
+ external
515
+ virtual
516
+ {
517
+ (NftId poolNftId, IInstance instance) = _getAndVerifyActiveComponent(POOL());
518
+
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 = getRegistry().getObjectInfo(componentNftId).parentNftId;
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 = IInstance(registry.getObjectAddress(instanceNftId));
811
+ }
812
+
813
+ function _setLocked(InstanceAdmin instanceAdmin, address componentAddress, bool locked) internal {
814
+ instanceAdmin.setTargetLocked(componentAddress, locked);
815
+ }
816
+
817
+ function _getAndVerifyActiveComponent(ObjectType expectedType)
818
+ internal
819
+ view
820
+ returns (
821
+ NftId componentNftId,
822
+ IInstance instance
823
+ )
824
+ {
825
+ return _getAndVerifyComponent(expectedType, true); // only active
826
+ }
827
+
828
+ function _getAndVerifyComponent(ObjectType expectedType, bool isActive)
829
+ internal
830
+ view
831
+ returns (
832
+ NftId componentNftId,
833
+ IInstance instance
834
+ )
835
+ {
836
+ IRegistry.ObjectInfo memory info;
837
+ address instanceAddress;
838
+
839
+ if (expectedType != COMPONENT()) {
840
+ (info, instanceAddress) = ContractLib.getAndVerifyComponent(
841
+ getRegistry(),
842
+ msg.sender, // caller
843
+ expectedType,
844
+ isActive);
845
+ } else {
846
+ (info, instanceAddress) = ContractLib.getAndVerifyAnyComponent(
847
+ getRegistry(),
848
+ msg.sender,
849
+ isActive);
850
+ }
851
+
852
+ // get component nft id and instance
853
+ componentNftId = info.nftId;
854
+ instance = IInstance(instanceAddress);
855
+ }
856
+
857
+ function _getDomain() internal pure virtual override returns(ObjectType) {
858
+ return COMPONENT();
859
+ }
860
+
861
+ function _checkSupportsInterface(address component) internal view {
862
+ if (!ContractLib.supportsInterface(component, type(IInstanceLinkedComponent).interfaceId)) {
863
+ revert ErrorComponentServiceNotInstanceLinkedComponent(component);
864
+ }
865
+ }
866
+ }