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

Sign up to get free protection for your applications and to get access to all the features.
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
+ }