@etherisc/gif-next 0.0.2-ceb30b2-601 → 0.0.2-ceed5e3-261

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 (564) hide show
  1. package/README.md +9 -1
  2. package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +4 -0
  3. package/artifacts/contracts/{components → distribution}/Distribution.sol/Distribution.json +239 -155
  4. package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +4 -0
  5. package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +1378 -0
  6. package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
  7. package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +826 -0
  8. package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +4 -0
  9. package/artifacts/contracts/{components → distribution}/IDistributionComponent.sol/IDistributionComponent.json +118 -99
  10. package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +4 -0
  11. package/artifacts/contracts/{instance/service → distribution}/IDistributionService.sol/IDistributionService.json +52 -307
  12. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
  13. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +36 -105
  14. package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
  15. package/artifacts/contracts/instance/IInstance.sol/IInstance.json +250 -2313
  16. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
  17. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +181 -12
  18. package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
  19. package/artifacts/contracts/instance/Instance.sol/Instance.json +361 -2789
  20. package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +4 -0
  21. package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +708 -0
  22. package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +4 -0
  23. package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +228 -0
  24. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
  25. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +643 -350
  26. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
  27. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +266 -145
  28. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
  29. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +122 -88
  30. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +4 -0
  31. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +3598 -0
  32. package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +4 -0
  33. package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +318 -0
  34. package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +4 -0
  35. package/artifacts/contracts/instance/{Cloneable.sol → base/Cloneable.sol}/Cloneable.json +1 -54
  36. package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +4 -0
  37. package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +10 -0
  38. package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +4 -0
  39. package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +187 -0
  40. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
  41. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +8 -116
  42. package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
  43. package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +1 -1
  44. package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
  45. package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
  46. package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
  47. package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +4 -0
  48. package/artifacts/contracts/mock/Dip.sol/Dip.json +376 -0
  49. package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +4 -0
  50. package/artifacts/contracts/{instance/module/ISetup.sol/ISetup.json → oracle/IOracle.sol/IOracle.json} +2 -2
  51. package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +4 -0
  52. package/artifacts/contracts/{components/IProductComponent.sol/IProductComponent.json → oracle/IOracleComponent.sol/IOracleComponent.json} +158 -216
  53. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +4 -0
  54. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +675 -0
  55. package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +4 -0
  56. package/artifacts/contracts/{components/Product.sol/Product.json → oracle/Oracle.sol/Oracle.json} +256 -264
  57. package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +4 -0
  58. package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +1034 -0
  59. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +4 -0
  60. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +730 -0
  61. package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +4 -0
  62. package/artifacts/contracts/pool/BundleService.sol/BundleService.json +1134 -0
  63. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
  64. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +754 -0
  65. package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +4 -0
  66. package/artifacts/contracts/{instance/service → pool}/IBundleService.sol/IBundleService.json +56 -54
  67. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
  68. package/artifacts/contracts/{components → pool}/IPoolComponent.sol/IPoolComponent.json +200 -97
  69. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +4 -0
  70. package/artifacts/contracts/{instance/service → pool}/IPoolService.sol/IPoolService.json +157 -156
  71. package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +4 -0
  72. package/artifacts/contracts/{components → pool}/Pool.sol/Pool.json +305 -103
  73. package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +4 -0
  74. package/artifacts/contracts/pool/PoolService.sol/PoolService.json +1453 -0
  75. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
  76. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +742 -0
  77. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +4 -0
  78. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +863 -0
  79. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
  80. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +730 -0
  81. package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +4 -0
  82. package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +1315 -0
  83. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
  84. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +822 -0
  85. package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +4 -0
  86. package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +512 -0
  87. package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +4 -0
  88. package/artifacts/contracts/{instance/service → product}/IClaimService.sol/IClaimService.json +43 -2
  89. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +4 -0
  90. package/artifacts/contracts/{instance/service → product}/IPolicyService.sol/IPolicyService.json +140 -71
  91. package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +4 -0
  92. package/artifacts/contracts/{instance/service/IApplicationService.sol/IApplicationService.json → product/IPricingService.sol/IPricingService.json} +66 -136
  93. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +4 -0
  94. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +995 -0
  95. package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +4 -0
  96. package/artifacts/contracts/{instance/service → product}/IProductService.sol/IProductService.json +14 -56
  97. package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +4 -0
  98. package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +1183 -0
  99. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
  100. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +766 -0
  101. package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +4 -0
  102. package/artifacts/contracts/product/PricingService.sol/PricingService.json +1012 -0
  103. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +4 -0
  104. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +786 -0
  105. package/artifacts/contracts/product/Product.sol/Product.dbg.json +4 -0
  106. package/artifacts/contracts/product/Product.sol/Product.json +1397 -0
  107. package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +4 -0
  108. package/artifacts/contracts/product/ProductService.sol/ProductService.json +708 -0
  109. package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +4 -0
  110. package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +702 -0
  111. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
  112. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +2 -2
  113. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
  114. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +179 -29
  115. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
  116. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +317 -52
  117. package/artifacts/contracts/registry/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +4 -0
  118. package/artifacts/contracts/registry/IServiceAuthorization.sol/IServiceAuthorization.json +129 -0
  119. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
  120. package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
  121. package/artifacts/contracts/registry/Registry.sol/Registry.json +420 -43
  122. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +4 -0
  123. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +1901 -0
  124. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
  125. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +374 -72
  126. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
  127. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +105 -41
  128. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
  129. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +762 -103
  130. package/artifacts/contracts/registry/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +4 -0
  131. package/artifacts/contracts/registry/ServiceAuthorization.sol/ServiceAuthorization.json +171 -0
  132. package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +4 -0
  133. package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +187 -0
  134. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
  135. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +316 -140
  136. package/artifacts/contracts/shared/AccessAdmin.sol/AccessAdmin.dbg.json +4 -0
  137. package/artifacts/contracts/shared/AccessAdmin.sol/AccessAdmin.json +1559 -0
  138. package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.dbg.json +4 -0
  139. package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.json +1193 -0
  140. package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.dbg.json +4 -0
  141. package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.json +1747 -0
  142. package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.dbg.json +4 -0
  143. package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.json +1760 -0
  144. package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.dbg.json +4 -0
  145. package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.json +1838 -0
  146. package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.dbg.json +4 -0
  147. package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.json +1856 -0
  148. package/artifacts/contracts/shared/Component.sol/Component.dbg.json +4 -0
  149. package/artifacts/contracts/{components → shared}/Component.sol/Component.json +143 -76
  150. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +4 -0
  151. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +1511 -0
  152. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +4 -0
  153. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +796 -0
  154. package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +4 -0
  155. package/artifacts/contracts/{instance/base/ComponentService.sol/ComponentService.json → shared/ComponentVerifyingService.sol/ComponentVerifyingService.json} +22 -114
  156. package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
  157. package/artifacts/contracts/shared/ERC165.sol/ERC165.json +2 -2
  158. package/artifacts/contracts/shared/IAccessAdmin.sol/IAccessAdmin.dbg.json +4 -0
  159. package/artifacts/contracts/shared/IAccessAdmin.sol/IAccessAdmin.json +1189 -0
  160. package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.dbg.json +4 -0
  161. package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.json +1562 -0
  162. package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.dbg.json +4 -0
  163. package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.json +1600 -0
  164. package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +4 -0
  165. package/artifacts/contracts/{components → shared}/IComponent.sol/IComponent.json +114 -75
  166. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +4 -0
  167. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +880 -0
  168. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +4 -0
  169. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +705 -0
  170. package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
  171. package/artifacts/contracts/{instance/base → shared}/IKeyValueStore.sol/IKeyValueStore.json +50 -11
  172. package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +4 -0
  173. package/artifacts/contracts/{instance/base → shared}/ILifecycle.sol/ILifecycle.json +1 -1
  174. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
  175. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +7 -1
  176. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
  177. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +45 -3
  178. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
  179. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +7 -1
  180. package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
  181. package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
  182. package/artifacts/contracts/shared/IService.sol/IService.json +20 -1
  183. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
  184. package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.dbg.json +4 -0
  185. package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.json +39 -0
  186. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +4 -0
  187. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +1036 -0
  188. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +4 -0
  189. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +571 -0
  190. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +4 -0
  191. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +194 -0
  192. package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.dbg.json +4 -0
  193. package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.json +306 -0
  194. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
  195. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +15 -9
  196. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
  197. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +56 -7
  198. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
  199. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +70 -22
  200. package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
  201. package/artifacts/contracts/shared/Registerable.sol/Registerable.json +23 -9
  202. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
  203. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -2
  204. package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
  205. package/artifacts/contracts/shared/Service.sol/Service.json +20 -1
  206. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
  207. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +60 -6
  208. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
  209. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +2 -2
  210. package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
  211. package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +4 -0
  212. package/artifacts/contracts/staking/IStaking.sol/IStaking.json +1438 -0
  213. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +4 -0
  214. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +1035 -0
  215. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +4 -0
  216. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +460 -0
  217. package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +4 -0
  218. package/artifacts/contracts/staking/Staking.sol/Staking.json +2005 -0
  219. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +4 -0
  220. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +761 -0
  221. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +4 -0
  222. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +597 -0
  223. package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +4 -0
  224. package/artifacts/contracts/staking/StakingService.sol/StakingService.json +1343 -0
  225. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +4 -0
  226. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +718 -0
  227. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +4 -0
  228. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +2261 -0
  229. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +4 -0
  230. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +571 -0
  231. package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +4 -0
  232. package/artifacts/contracts/{types → type}/AddressSet.sol/LibAddressSet.json +3 -3
  233. package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +4 -0
  234. package/artifacts/contracts/type/Amount.sol/AmountLib.json +345 -0
  235. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +4 -0
  236. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +225 -0
  237. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
  238. package/artifacts/contracts/{types → type}/ClaimId.sol/ClaimIdLib.json +5 -5
  239. package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +4 -0
  240. package/artifacts/contracts/{types → type}/DistributorType.sol/DistributorTypeLib.json +5 -5
  241. package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +4 -0
  242. package/artifacts/contracts/type/Fee.sol/FeeLib.json +312 -0
  243. package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +4 -0
  244. package/artifacts/contracts/{types → type}/Key32.sol/Key32Lib.json +3 -3
  245. package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +4 -0
  246. package/artifacts/contracts/type/NftId.sol/NftIdLib.json +209 -0
  247. package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +4 -0
  248. package/artifacts/contracts/{types → type}/NftIdSet.sol/LibNftIdSet.json +3 -3
  249. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +4 -0
  250. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +186 -0
  251. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
  252. package/artifacts/contracts/{types → type}/PayoutId.sol/PayoutIdLib.json +5 -5
  253. package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +4 -0
  254. package/artifacts/contracts/type/Referral.sol/ReferralLib.json +142 -0
  255. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +4 -0
  256. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +204 -0
  257. package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +4 -0
  258. package/artifacts/contracts/{types → type}/RiskId.sol/RiskIdLib.json +5 -5
  259. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +4 -0
  260. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +266 -0
  261. package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +4 -0
  262. package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +198 -0
  263. package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +4 -0
  264. package/artifacts/contracts/type/Selector.sol/SelectorLib.json +129 -0
  265. package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +4 -0
  266. package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +10 -0
  267. package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +4 -0
  268. package/artifacts/contracts/{types → type}/StateId.sol/StateIdLib.json +3 -3
  269. package/artifacts/contracts/type/String.sol/StrLib.dbg.json +4 -0
  270. package/artifacts/contracts/type/String.sol/StrLib.json +132 -0
  271. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +4 -0
  272. package/artifacts/contracts/{types → type}/Timestamp.sol/TimestampLib.json +20 -7
  273. package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +4 -0
  274. package/artifacts/contracts/{types → type}/UFixed.sol/MathLib.json +3 -3
  275. package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +4 -0
  276. package/artifacts/contracts/{types → type}/UFixed.sol/UFixedLib.json +3 -3
  277. package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +4 -0
  278. package/artifacts/contracts/{types → type}/Version.sol/VersionLib.json +3 -3
  279. package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +4 -0
  280. package/artifacts/contracts/{types → type}/Version.sol/VersionPartLib.json +3 -3
  281. package/contracts/{components → distribution}/Distribution.sol +41 -64
  282. package/contracts/distribution/DistributionService.sol +297 -0
  283. package/contracts/distribution/DistributionServiceManager.sol +42 -0
  284. package/contracts/{components → distribution}/IDistributionComponent.sol +11 -16
  285. package/contracts/{instance/service → distribution}/IDistributionService.sol +19 -37
  286. package/contracts/instance/BundleManager.sol +5 -5
  287. package/contracts/instance/IInstance.sol +51 -68
  288. package/contracts/instance/IInstanceService.sol +50 -16
  289. package/contracts/instance/Instance.sol +134 -189
  290. package/contracts/instance/InstanceAdmin.sol +331 -0
  291. package/contracts/instance/InstanceAuthorizationsLib.sol +377 -0
  292. package/contracts/instance/InstanceReader.sol +130 -55
  293. package/contracts/instance/InstanceService.sol +237 -282
  294. package/contracts/instance/InstanceServiceManager.sol +11 -21
  295. package/contracts/instance/InstanceStore.sol +269 -0
  296. package/contracts/instance/base/BalanceStore.sol +123 -0
  297. package/contracts/instance/base/Cloneable.sol +28 -0
  298. package/contracts/instance/base/ObjectCounter.sol +21 -0
  299. package/contracts/instance/{ObjectManager.sol → base/ObjectManager.sol} +7 -9
  300. package/contracts/instance/module/IAccess.sol +4 -12
  301. package/contracts/instance/module/IBundle.sol +6 -9
  302. package/contracts/instance/module/IComponents.sol +21 -10
  303. package/contracts/instance/module/IDistribution.sol +7 -6
  304. package/contracts/instance/module/IPolicy.sol +20 -14
  305. package/contracts/instance/module/IRisk.sol +1 -1
  306. package/contracts/{test/TestToken.sol → mock/Dip.sol} +5 -5
  307. package/contracts/oracle/IOracle.sol +20 -0
  308. package/contracts/oracle/IOracleComponent.sol +32 -0
  309. package/contracts/oracle/IOracleService.sol +65 -0
  310. package/contracts/oracle/Oracle.sol +145 -0
  311. package/contracts/oracle/OracleService.sol +278 -0
  312. package/contracts/oracle/OracleServiceManager.sol +42 -0
  313. package/contracts/pool/BundleService.sol +296 -0
  314. package/contracts/pool/BundleServiceManager.sol +42 -0
  315. package/contracts/{instance/service → pool}/IBundleService.sol +33 -29
  316. package/contracts/{components → pool}/IPoolComponent.sol +16 -17
  317. package/contracts/{instance/service → pool}/IPoolService.sol +57 -51
  318. package/contracts/{components → pool}/Pool.sol +52 -55
  319. package/contracts/pool/PoolService.sol +452 -0
  320. package/contracts/pool/PoolServiceManager.sol +42 -0
  321. package/contracts/product/ApplicationService.sol +254 -0
  322. package/contracts/{instance/service → product}/ApplicationServiceManager.sol +11 -8
  323. package/contracts/{instance/service → product}/ClaimService.sol +170 -89
  324. package/contracts/{instance/service → product}/ClaimServiceManager.sol +11 -8
  325. package/contracts/{instance/service → product}/IApplicationService.sol +13 -29
  326. package/contracts/{instance/service → product}/IClaimService.sol +24 -15
  327. package/contracts/{instance/service → product}/IPolicyService.sol +24 -26
  328. package/contracts/product/IPricingService.sol +39 -0
  329. package/contracts/product/IProductComponent.sol +42 -0
  330. package/contracts/product/IProductService.sol +33 -0
  331. package/contracts/product/PolicyService.sol +475 -0
  332. package/contracts/product/PolicyServiceManager.sol +42 -0
  333. package/contracts/product/PricingService.sol +300 -0
  334. package/contracts/product/PricingServiceManager.sol +42 -0
  335. package/contracts/{components → product}/Product.sol +83 -77
  336. package/contracts/product/ProductService.sol +124 -0
  337. package/contracts/product/ProductServiceManager.sol +42 -0
  338. package/contracts/registry/ChainNft.sol +8 -1
  339. package/contracts/registry/IRegistry.sol +44 -21
  340. package/contracts/registry/IRegistryService.sol +37 -34
  341. package/contracts/registry/IServiceAuthorization.sol +35 -0
  342. package/contracts/registry/Registry.sol +198 -83
  343. package/contracts/registry/RegistryAdmin.sol +333 -0
  344. package/contracts/registry/RegistryService.sol +71 -87
  345. package/contracts/registry/RegistryServiceManager.sol +21 -30
  346. package/contracts/registry/ReleaseManager.sol +400 -197
  347. package/contracts/registry/ServiceAuthorization.sol +86 -0
  348. package/contracts/registry/ServiceAuthorizationV3.sol +200 -0
  349. package/contracts/registry/TokenRegistry.sol +261 -62
  350. package/contracts/shared/AccessAdmin.sol +759 -0
  351. package/contracts/shared/AccessManagerCustom.sol +741 -0
  352. package/contracts/shared/AccessManagerExtended.sol +481 -0
  353. package/contracts/shared/AccessManagerExtendedInitializeable.sol +13 -0
  354. package/contracts/shared/AccessManagerExtendedWithDisable.sol +137 -0
  355. package/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol +14 -0
  356. package/contracts/shared/Component.sol +281 -0
  357. package/contracts/shared/ComponentService.sol +617 -0
  358. package/contracts/shared/ComponentServiceManager.sol +35 -0
  359. package/contracts/shared/ComponentVerifyingService.sol +117 -0
  360. package/contracts/shared/ERC165.sol +1 -1
  361. package/contracts/shared/IAccessAdmin.sol +168 -0
  362. package/contracts/shared/IAccessManagerExtended.sol +74 -0
  363. package/contracts/shared/IAccessManagerExtendedWithDisable.sol +18 -0
  364. package/contracts/{components → shared}/IComponent.sol +23 -29
  365. package/contracts/shared/IComponentService.sol +102 -0
  366. package/contracts/shared/IInstanceLinkedComponent.sol +46 -0
  367. package/contracts/{instance/base → shared}/IKeyValueStore.sol +15 -11
  368. package/contracts/{instance/base → shared}/ILifecycle.sol +3 -3
  369. package/contracts/shared/INftOwnable.sol +2 -2
  370. package/contracts/shared/IPolicyHolder.sol +14 -7
  371. package/contracts/shared/IService.sol +9 -2
  372. package/contracts/shared/IVersionable.sol +1 -1
  373. package/contracts/shared/InitializableCustom.sol +177 -0
  374. package/contracts/shared/InstanceLinkedComponent.sol +144 -0
  375. package/contracts/shared/KeyValueStore.sol +127 -0
  376. package/contracts/{instance/base → shared}/Lifecycle.sol +18 -5
  377. package/contracts/shared/NftIdSetManager.sol +65 -0
  378. package/contracts/shared/NftOwnable.sol +3 -14
  379. package/contracts/shared/PolicyHolder.sol +32 -17
  380. package/contracts/shared/ProxyManager.sol +34 -4
  381. package/contracts/shared/Registerable.sol +3 -3
  382. package/contracts/shared/Service.sol +32 -21
  383. package/contracts/shared/TokenHandler.sol +27 -2
  384. package/contracts/shared/Versionable.sol +1 -1
  385. package/contracts/staking/IStaking.sol +168 -0
  386. package/contracts/staking/IStakingService.sol +153 -0
  387. package/contracts/staking/StakeManagerLib.sol +231 -0
  388. package/contracts/staking/Staking.sol +513 -0
  389. package/contracts/staking/StakingManager.sol +54 -0
  390. package/contracts/staking/StakingReader.sol +187 -0
  391. package/contracts/staking/StakingService.sol +411 -0
  392. package/contracts/staking/StakingServiceManager.sol +44 -0
  393. package/contracts/staking/StakingStore.sol +613 -0
  394. package/contracts/staking/TargetManagerLib.sol +207 -0
  395. package/contracts/{types → type}/AddressSet.sol +1 -1
  396. package/contracts/{types → type}/Amount.sol +59 -1
  397. package/contracts/{types → type}/Blocknumber.sol +20 -3
  398. package/contracts/{types → type}/Fee.sol +24 -22
  399. package/contracts/{types → type}/NftId.sol +14 -16
  400. package/contracts/{types → type}/NftIdSet.sol +2 -2
  401. package/contracts/type/ObjectType.sol +241 -0
  402. package/contracts/{types → type}/Referral.sol +1 -1
  403. package/contracts/type/RequestId.sol +75 -0
  404. package/contracts/{types → type}/RiskId.sol +1 -1
  405. package/contracts/type/RoleId.sol +201 -0
  406. package/contracts/{types → type}/Seconds.sol +27 -0
  407. package/contracts/type/Selector.sol +102 -0
  408. package/contracts/{types → type}/StateId.sol +27 -2
  409. package/contracts/type/String.sol +53 -0
  410. package/contracts/{types → type}/Timestamp.sol +6 -2
  411. package/contracts/{types → type}/Version.sol +1 -1
  412. package/package.json +4 -3
  413. package/artifacts/contracts/components/Component.sol/Component.dbg.json +0 -4
  414. package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +0 -4
  415. package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +0 -4
  416. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +0 -4
  417. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +0 -4
  418. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +0 -4
  419. package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +0 -4
  420. package/artifacts/contracts/components/Product.sol/Product.dbg.json +0 -4
  421. package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +0 -4
  422. package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +0 -1206
  423. package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +0 -4
  424. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +0 -4
  425. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +0 -1330
  426. package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +0 -4
  427. package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +0 -256
  428. package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.dbg.json +0 -4
  429. package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +0 -4
  430. package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +0 -4
  431. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +0 -4
  432. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +0 -532
  433. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +0 -4
  434. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +0 -194
  435. package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +0 -4
  436. package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +0 -4
  437. package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.json +0 -10
  438. package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.dbg.json +0 -4
  439. package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.json +0 -1092
  440. package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +0 -4
  441. package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.json +0 -672
  442. package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +0 -4
  443. package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +0 -1313
  444. package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +0 -4
  445. package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +0 -712
  446. package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.dbg.json +0 -4
  447. package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.json +0 -1316
  448. package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +0 -4
  449. package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.json +0 -724
  450. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +0 -4
  451. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +0 -1798
  452. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +0 -4
  453. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +0 -780
  454. package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.dbg.json +0 -4
  455. package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +0 -4
  456. package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.dbg.json +0 -4
  457. package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +0 -4
  458. package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +0 -4
  459. package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +0 -4
  460. package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +0 -4
  461. package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +0 -4
  462. package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +0 -1153
  463. package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +0 -4
  464. package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +0 -676
  465. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +0 -4
  466. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +0 -1598
  467. package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +0 -4
  468. package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +0 -696
  469. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +0 -4
  470. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +0 -864
  471. package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
  472. package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +0 -640
  473. package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +0 -4
  474. package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +0 -285
  475. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +0 -4
  476. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +0 -107
  477. package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +0 -4
  478. package/artifacts/contracts/test/TestFee.sol/TestFee.json +0 -119
  479. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +0 -4
  480. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +0 -370
  481. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +0 -4
  482. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +0 -116
  483. package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +0 -4
  484. package/artifacts/contracts/test/TestService.sol/TestService.json +0 -588
  485. package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +0 -4
  486. package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +0 -376
  487. package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +0 -4
  488. package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +0 -218
  489. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +0 -4
  490. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +0 -104
  491. package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +0 -4
  492. package/artifacts/contracts/test/Usdc.sol/USDC.json +0 -376
  493. package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +0 -4
  494. package/artifacts/contracts/types/Amount.sol/AmountLib.dbg.json +0 -4
  495. package/artifacts/contracts/types/Amount.sol/AmountLib.json +0 -209
  496. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +0 -4
  497. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +0 -174
  498. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +0 -4
  499. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +0 -10
  500. package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.dbg.json +0 -4
  501. package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +0 -4
  502. package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +0 -4
  503. package/artifacts/contracts/types/Fee.sol/FeeLib.json +0 -288
  504. package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +0 -4
  505. package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +0 -4
  506. package/artifacts/contracts/types/NftId.sol/NftIdLib.json +0 -166
  507. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +0 -4
  508. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +0 -4
  509. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.json +0 -100
  510. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +0 -4
  511. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +0 -92
  512. package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.dbg.json +0 -4
  513. package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +0 -4
  514. package/artifacts/contracts/types/Referral.sol/ReferralLib.json +0 -142
  515. package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +0 -4
  516. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +0 -4
  517. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +0 -156
  518. package/artifacts/contracts/types/Seconds.sol/SecondsLib.dbg.json +0 -4
  519. package/artifacts/contracts/types/Seconds.sol/SecondsLib.json +0 -124
  520. package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +0 -4
  521. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +0 -4
  522. package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +0 -4
  523. package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +0 -4
  524. package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +0 -4
  525. package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +0 -4
  526. package/contracts/components/Component.sol +0 -253
  527. package/contracts/components/IProductComponent.sol +0 -40
  528. package/contracts/instance/AccessManagerUpgradeableInitializeable.sol +0 -13
  529. package/contracts/instance/Cloneable.sol +0 -51
  530. package/contracts/instance/InstanceAccessManager.sol +0 -527
  531. package/contracts/instance/base/ComponentService.sol +0 -130
  532. package/contracts/instance/base/KeyValueStore.sol +0 -149
  533. package/contracts/instance/module/ISetup.sol +0 -33
  534. package/contracts/instance/module/ITreasury.sol +0 -23
  535. package/contracts/instance/service/ApplicationService.sol +0 -356
  536. package/contracts/instance/service/BundleService.sol +0 -443
  537. package/contracts/instance/service/BundleServiceManager.sol +0 -51
  538. package/contracts/instance/service/DistributionService.sol +0 -431
  539. package/contracts/instance/service/DistributionServiceManager.sol +0 -51
  540. package/contracts/instance/service/IProductService.sol +0 -40
  541. package/contracts/instance/service/PolicyService.sol +0 -358
  542. package/contracts/instance/service/PolicyServiceManager.sol +0 -54
  543. package/contracts/instance/service/PoolService.sol +0 -349
  544. package/contracts/instance/service/PoolServiceManager.sol +0 -51
  545. package/contracts/instance/service/ProductService.sol +0 -210
  546. package/contracts/instance/service/ProductServiceManager.sol +0 -54
  547. package/contracts/registry/RegistryAccessManager.sol +0 -216
  548. package/contracts/shared/ContractDeployerLib.sol +0 -72
  549. package/contracts/test/TestFee.sol +0 -25
  550. package/contracts/test/TestRegisterable.sol +0 -18
  551. package/contracts/test/TestRoleId.sol +0 -14
  552. package/contracts/test/TestService.sol +0 -25
  553. package/contracts/test/TestVersion.sol +0 -44
  554. package/contracts/test/TestVersionable.sol +0 -17
  555. package/contracts/test/Usdc.sol +0 -26
  556. package/contracts/types/ChainId.sol +0 -38
  557. package/contracts/types/NumberId.sol +0 -52
  558. package/contracts/types/ObjectType.sol +0 -157
  559. package/contracts/types/RoleId.sol +0 -97
  560. /package/contracts/{types → type}/ClaimId.sol +0 -0
  561. /package/contracts/{types → type}/DistributorType.sol +0 -0
  562. /package/contracts/{types → type}/Key32.sol +0 -0
  563. /package/contracts/{types → type}/PayoutId.sol +0 -0
  564. /package/contracts/{types → type}/UFixed.sol +0 -0
@@ -0,0 +1,333 @@
1
+ // SPDX-License-Identifier: UNLICENSED
2
+ pragma solidity ^0.8.20;
3
+
4
+ import {AccessAdmin} from "../shared/AccessAdmin.sol";
5
+ import {IAccessAdmin} from "../shared/IAccessAdmin.sol";
6
+ import {IRegistry} from "./IRegistry.sol";
7
+ import {IService} from "../shared/IService.sol";
8
+ import {IServiceAuthorization} from "./IServiceAuthorization.sol";
9
+ import {IStaking} from "../staking/IStaking.sol";
10
+ import {ObjectType, ObjectTypeLib, ALL, POOL, RELEASE} from "../type/ObjectType.sol";
11
+ import {ReleaseManager} from "./ReleaseManager.sol";
12
+ import {RoleId, RoleIdLib, ADMIN_ROLE, GIF_MANAGER_ROLE, GIF_ADMIN_ROLE, PUBLIC_ROLE} from "../type/RoleId.sol";
13
+ import {StakingStore} from "../staking/StakingStore.sol";
14
+ import {STAKING} from "../type/ObjectType.sol";
15
+ import {TokenRegistry} from "./TokenRegistry.sol";
16
+ import {VersionPart} from "../type/Version.sol";
17
+
18
+ /*
19
+ 1) GIF_MANAGER_ROLE
20
+ - can have arbitrary number of members
21
+ - responsible for services registrations
22
+ - responsible for token registration and activation
23
+
24
+ 2) GIF_ADMIN_ROLE
25
+ - admin of GIF_MANAGER_ROLE
26
+ - MUST have 1 member at any time
27
+ - granted/revoked ONLY in transferAdminRole() -> consider lock out situations!!!
28
+ - responsible for creation and activation of releases
29
+
30
+ createServiceTarget(type, release)
31
+ createServiceRole(type,release)
32
+ getServiceRole(type, release)
33
+ */
34
+ contract RegistryAdmin is
35
+ AccessAdmin
36
+ {
37
+ error ErrorRegistryAdminIsAlreadySetUp();
38
+
39
+ string public constant GIF_ADMIN_ROLE_NAME = "GifAdminRole";
40
+ string public constant GIF_MANAGER_ROLE_NAME = "GifManagerRole";
41
+ string public constant STAKING_SERVICE_ROLE_NAME = "StakingServiceRole";
42
+ string public constant POOL_SERVICE_ROLE_NAME = "PoolServiceRole";
43
+
44
+ string public constant RELEASE_MANAGER_TARGET_NAME = "ReleaseManagerTarget";
45
+ string public constant TOKEN_REGISTRY_TARGET_NAME = "TokenRegistryTarget";
46
+ string public constant STAKING_TARGET_NAME = "StakingTarget";
47
+ string public constant STAKING_STORE_TARGET_NAME = "StakingStoreTarget";
48
+
49
+ mapping(address service => VersionPart majorVersion) private _ServiceRelease;
50
+
51
+ address private _releaseManager;
52
+ address private _tokenRegistry;
53
+ address private _staking;
54
+ address private _stakingStore;
55
+ bool private _setupCompleted;
56
+
57
+ constructor() AccessAdmin() { }
58
+
59
+ function completeSetup(
60
+ IRegistry registry,
61
+ address gifAdmin,
62
+ address gifManager
63
+ )
64
+ external
65
+ onlyDeployer()
66
+ {
67
+ if (_setupCompleted) { revert ErrorRegistryAdminIsAlreadySetUp(); }
68
+ else { _setupCompleted = true; }
69
+
70
+ _releaseManager = registry.getReleaseManagerAddress();
71
+ _tokenRegistry = registry.getTokenRegistryAddress();
72
+ _staking = registry.getStakingAddress();
73
+ _stakingStore = address(
74
+ IStaking(_staking).getStakingStore());
75
+
76
+ // at this moment all registry contracts are deployed and fully intialized
77
+ _createTarget(_tokenRegistry, TOKEN_REGISTRY_TARGET_NAME);
78
+
79
+ _setupGifAdminRole(gifAdmin);
80
+ _setupGifManagerRole(gifManager);
81
+
82
+ _setupReleaseManager();
83
+ _setupStaking();
84
+ }
85
+
86
+
87
+ /// @dev Sets up authorizaion for specified service.
88
+ /// For all authorized services its authorized functions are enabled.
89
+ /// Permissioned function: Access is restricted to release manager.
90
+ function authorizeService(
91
+ IServiceAuthorization serviceAuthorization,
92
+ IService service
93
+ )
94
+ external
95
+ restricted()
96
+ {
97
+ _createServiceTargetAndRole(service);
98
+ _authorizeServiceFunctions(serviceAuthorization, service);
99
+ }
100
+
101
+
102
+ function grantServiceRoleForAllVersions(IService service, ObjectType domain)
103
+ external
104
+ restricted()
105
+ {
106
+ _grantRoleToAccount(
107
+ RoleIdLib.roleForTypeAndAllVersions(domain),
108
+ address(service));
109
+ }
110
+
111
+
112
+ function _createServiceTargetAndRole(IService service)
113
+ private
114
+ {
115
+ ObjectType domain = service.getDomain();
116
+ string memory baseName = ObjectTypeLib.toName(domain);
117
+ VersionPart version = service.getVersion().toMajorPart();
118
+ uint256 versionInt = version.toInt();
119
+ string memory versionName = "_v0";
120
+ string memory versionNumber = ObjectTypeLib.toString(versionInt);
121
+
122
+ if (versionInt >= 10) {
123
+ versionName = "_v";
124
+ }
125
+
126
+ // create service target
127
+ string memory serviceTargetName = string(
128
+ abi.encodePacked(
129
+ baseName,
130
+ "Service",
131
+ versionName,
132
+ versionNumber));
133
+
134
+ _createTarget(
135
+ address(service),
136
+ serviceTargetName);
137
+
138
+ // create service role
139
+ string memory serviceRoleName = string(
140
+ abi.encodePacked(
141
+ baseName,
142
+ "ServiceRole",
143
+ versionName,
144
+ versionNumber));
145
+
146
+ RoleId roleId = RoleIdLib.roleForTypeAndVersion(
147
+ domain,
148
+ version);
149
+
150
+ _createRole(
151
+ roleId,
152
+ ADMIN_ROLE(),
153
+ serviceRoleName,
154
+ 1, // service roles must only be given to this unique service
155
+ true); // it must not be possible to remove this role once granted
156
+
157
+ _grantRoleToAccount(
158
+ roleId,
159
+ address(service));
160
+ }
161
+
162
+
163
+ function _authorizeServiceFunctions(
164
+ IServiceAuthorization serviceAuthorization,
165
+ IService service
166
+ )
167
+ private
168
+ {
169
+ ObjectType serviceDomain = service.getDomain();
170
+ ObjectType authorizedDomain;
171
+ RoleId authorizedRoleId;
172
+
173
+ VersionPart release = service.getVersion().toMajorPart();
174
+ ObjectType[] memory authorizedDomains = serviceAuthorization.getAuthorizedDomains(serviceDomain);
175
+
176
+ for (uint256 i = 0; i < authorizedDomains.length; i++) {
177
+ authorizedDomain = authorizedDomains[i];
178
+
179
+ // derive authorized role from authorized domain
180
+ if (authorizedDomain == ALL()) {
181
+ authorizedRoleId = PUBLIC_ROLE();
182
+ } else {
183
+ authorizedRoleId = RoleIdLib.roleForTypeAndVersion(
184
+ authorizedDomain,
185
+ release);
186
+ }
187
+
188
+ // get authorized functions for authorized domain
189
+ IAccessAdmin.Function[] memory authorizatedFunctions = serviceAuthorization.getAuthorizedFunctions(
190
+ serviceDomain,
191
+ authorizedDomain);
192
+
193
+ _authorizeTargetFunctions(
194
+ address(service),
195
+ authorizedRoleId,
196
+ authorizatedFunctions);
197
+ }
198
+ }
199
+
200
+ /*function transferAdmin(address to)
201
+ external
202
+ restricted // only with GIF_ADMIN_ROLE or nft owner
203
+ {
204
+ _accessManager.revoke(GIF_ADMIN_ROLE, );
205
+ _accesssManager.grant(GIF_ADMIN_ROLE, to, 0);
206
+ }*/
207
+
208
+ //--- view functions ----------------------------------------------------//
209
+
210
+ function getGifAdminRole() external view returns (RoleId) {
211
+ return GIF_ADMIN_ROLE();
212
+ }
213
+
214
+ function getGifManagerRole() external view returns (RoleId) {
215
+ return GIF_MANAGER_ROLE();
216
+ }
217
+
218
+ //--- private functions -------------------------------------------------//
219
+
220
+ function _setupGifAdminRole(address gifAdmin) private {
221
+ // TODO decide on max member count
222
+ _createRole(GIF_ADMIN_ROLE(), getAdminRole(), GIF_ADMIN_ROLE_NAME, 2, false);
223
+ _grantRoleToAccount(GIF_ADMIN_ROLE(), gifAdmin);
224
+
225
+ // for ReleaseManager
226
+ Function[] memory functions;
227
+ functions = new Function[](2);
228
+ functions[0] = toFunction(ReleaseManager.createNextRelease.selector, "createNextRelease");
229
+ functions[1] = toFunction(ReleaseManager.activateNextRelease.selector, "activateNextRelease");
230
+ _authorizeTargetFunctions(_releaseManager, GIF_ADMIN_ROLE(), functions);
231
+
232
+ // for Staking
233
+ }
234
+
235
+ function _setupGifManagerRole(address gifManager) private {
236
+ _createRole(GIF_MANAGER_ROLE(), GIF_ADMIN_ROLE(), GIF_MANAGER_ROLE_NAME, 1, false);
237
+ _grantRoleToAccount(GIF_MANAGER_ROLE(), gifManager);
238
+
239
+ // for TokenRegistry
240
+ Function[] memory functions;
241
+ functions = new Function[](5);
242
+ functions[0] = toFunction(TokenRegistry.registerToken.selector, "registerToken");
243
+ functions[1] = toFunction(TokenRegistry.registerRemoteToken.selector, "registerRemoteToken");
244
+ functions[2] = toFunction(TokenRegistry.setActive.selector, "setActive");
245
+ functions[3] = toFunction(TokenRegistry.setActiveForVersion.selector, "setActiveForVersion");
246
+ // TODO find a better way (only needed for testing)
247
+ functions[4] = toFunction(TokenRegistry.setActiveWithVersionCheck.selector, "setActiveWithVersionCheck");
248
+ _authorizeTargetFunctions(_tokenRegistry, GIF_MANAGER_ROLE(), functions);
249
+
250
+ // for ReleaseManager
251
+ functions = new Function[](2);
252
+ functions[0] = toFunction(ReleaseManager.prepareNextRelease.selector, "prepareNextRelease");
253
+ functions[1] = toFunction(ReleaseManager.registerService.selector, "registerService");
254
+ _authorizeTargetFunctions(_releaseManager, GIF_MANAGER_ROLE(), functions);
255
+
256
+ // for Staking
257
+ }
258
+
259
+
260
+ function _setupReleaseManager() private {
261
+ _createTarget(_releaseManager, RELEASE_MANAGER_TARGET_NAME);
262
+
263
+ RoleId releaseManagerRoleId = RoleIdLib.roleForType(RELEASE());
264
+ _createRole(releaseManagerRoleId, ADMIN_ROLE(), RELEASE_MANAGER_TARGET_NAME, 1, true);
265
+ _grantRoleToAccount(releaseManagerRoleId, _releaseManager);
266
+
267
+ Function[] memory functions;
268
+ functions = new Function[](2);
269
+ functions[0] = toFunction(RegistryAdmin.authorizeService.selector, "authorizeService");
270
+ functions[1] = toFunction(RegistryAdmin.grantServiceRoleForAllVersions.selector, "grantServiceRoleForAllVersions");
271
+ _authorizeTargetFunctions(address(this), releaseManagerRoleId, functions);
272
+ }
273
+
274
+
275
+ function _setupStaking() private {
276
+ _createTarget(_staking, STAKING_TARGET_NAME);
277
+ _createTarget(_stakingStore, STAKING_STORE_TARGET_NAME);
278
+
279
+
280
+ // staking function authorization for staking service
281
+ RoleId stakingServiceRoleId = RoleIdLib.roleForTypeAndAllVersions(STAKING());
282
+ _createRole(stakingServiceRoleId, ADMIN_ROLE(), STAKING_SERVICE_ROLE_NAME, 1, true);
283
+
284
+ Function[] memory functions;
285
+ functions = new Function[](13);
286
+ functions[0] = toFunction(IStaking.registerTarget.selector, "registerTarget");
287
+ functions[1] = toFunction(IStaking.setLockingPeriod.selector, "setLockingPeriod");
288
+ functions[2] = toFunction(IStaking.setRewardRate.selector, "setRewardRate");
289
+ functions[3] = toFunction(IStaking.refillRewardReserves.selector, "refillRewardReserves");
290
+ functions[4] = toFunction(IStaking.withdrawRewardReserves.selector, "withdrawRewardReserves");
291
+ functions[5] = toFunction(IStaking.createStake.selector, "createStake");
292
+ functions[6] = toFunction(IStaking.stake.selector, "stake");
293
+ functions[7] = toFunction(IStaking.unstake.selector, "unstake");
294
+ functions[8] = toFunction(IStaking.restake.selector, "restake");
295
+ functions[9] = toFunction(IStaking.updateRewards.selector, "updateRewards");
296
+ functions[10] = toFunction(IStaking.claimRewards.selector, "claimRewards");
297
+ functions[11] = toFunction(IStaking.collectDipAmount.selector, "collectDipAmount");
298
+ functions[12] = toFunction(IStaking.transferDipAmount.selector, "transferDipAmount");
299
+ _authorizeTargetFunctions(_staking, stakingServiceRoleId, functions);
300
+
301
+ // staking function authorization for pool service
302
+ RoleId poolServiceRoleId = RoleIdLib.roleForTypeAndAllVersions(POOL());
303
+ _createRole(poolServiceRoleId, ADMIN_ROLE(), POOL_SERVICE_ROLE_NAME, 1, true);
304
+
305
+ // staking function authorizations
306
+ functions = new Function[](2);
307
+ functions[0] = toFunction(IStaking.increaseTotalValueLocked.selector, "increaseTotalValueLocked");
308
+ functions[1] = toFunction(IStaking.decreaseTotalValueLocked.selector, "decreaseTotalValueLocked");
309
+ _authorizeTargetFunctions(_staking, poolServiceRoleId, functions);
310
+
311
+ // staking store function authorizations
312
+ RoleId stakingRoleId = RoleIdLib.roleForType(STAKING());
313
+ _createRole(stakingRoleId, ADMIN_ROLE(), STAKING_TARGET_NAME, 1, true);
314
+ _grantRoleToAccount(stakingRoleId, _staking);
315
+
316
+ functions = new Function[](14);
317
+ functions[0] = toFunction(StakingStore.setStakingRate.selector, "setStakingRate");
318
+ functions[1] = toFunction(StakingStore.createTarget.selector, "createTarget");
319
+ functions[2] = toFunction(StakingStore.updateTarget.selector, "updateTarget");
320
+ functions[3] = toFunction(StakingStore.increaseReserves.selector, "increaseReserves");
321
+ functions[4] = toFunction(StakingStore.decreaseReserves.selector, "decreaseReserves");
322
+ functions[5] = toFunction(StakingStore.increaseTotalValueLocked.selector, "increaseTotalValueLocked");
323
+ functions[6] = toFunction(StakingStore.decreaseTotalValueLocked.selector, "decreaseTotalValueLocked");
324
+ functions[7] = toFunction(StakingStore.create.selector, "create");
325
+ functions[8] = toFunction(StakingStore.update.selector, "update");
326
+ functions[9] = toFunction(StakingStore.increaseStake.selector, "increaseStake");
327
+ functions[10] = toFunction(StakingStore.restakeRewards.selector, "restakeRewards");
328
+ functions[11] = toFunction(StakingStore.updateRewards.selector, "updateRewards");
329
+ functions[12] = toFunction(StakingStore.claimUpTo.selector, "claimUpTo");
330
+ functions[13] = toFunction(StakingStore.unstakeUpTo.selector, "unstakeUpTo");
331
+ _authorizeTargetFunctions(_stakingStore, stakingRoleId, functions);
332
+ }
333
+ }
@@ -7,23 +7,21 @@ import {ERC165Checker} from "@openzeppelin/contracts/utils/introspection/ERC165C
7
7
  import {IRegistry} from "./IRegistry.sol";
8
8
  import {IInstance} from "../instance/IInstance.sol";
9
9
 
10
- import {ContractDeployerLib} from "../shared/ContractDeployerLib.sol";
11
- import {IComponent} from "../../contracts/components/IComponent.sol";
12
- import {IPoolComponent} from "../../contracts/components/IPoolComponent.sol";
13
- import {IProductComponent} from "../../contracts/components/IProductComponent.sol";
14
- import {IDistributionComponent} from "../../contracts/components/IDistributionComponent.sol";
10
+ import {IComponent} from "../../contracts/shared/IComponent.sol";
11
+ import {IPoolComponent} from "../../contracts/pool/IPoolComponent.sol";
12
+ import {IProductComponent} from "../../contracts/product/IProductComponent.sol";
13
+ import {IDistributionComponent} from "../../contracts/distribution/IDistributionComponent.sol";
15
14
 
16
15
  import {IVersionable} from "../../contracts/shared/IVersionable.sol";
17
16
  import {Versionable} from "../../contracts/shared/Versionable.sol";
18
17
  import {IRegisterable} from "../../contracts/shared/IRegisterable.sol";
19
- import {Registerable} from "../../contracts/shared/Registerable.sol";
20
18
 
21
- import {RoleId, PRODUCT_OWNER_ROLE, POOL_OWNER_ROLE, ORACLE_OWNER_ROLE} from "../../contracts/types/RoleId.sol";
22
- import {ObjectType, REGISTRY, SERVICE, PRODUCT, ORACLE, POOL, INSTANCE, DISTRIBUTION, DISTRIBUTOR, APPLICATION, POLICY, CLAIM, BUNDLE, STAKE} from "../../contracts/types/ObjectType.sol";
23
- import {StateId, ACTIVE, PAUSED} from "../../contracts/types/StateId.sol";
24
- import {NftId, NftIdLib, zeroNftId} from "../../contracts/types/NftId.sol";
25
- import {Fee, FeeLib} from "../../contracts/types/Fee.sol";
26
- import {Version, VersionPart, VersionLib} from "../../contracts/types/Version.sol";
19
+ import {RoleId, PRODUCT_OWNER_ROLE, POOL_OWNER_ROLE, ORACLE_OWNER_ROLE} from "../../contracts/type/RoleId.sol";
20
+ import {ObjectType, REGISTRY, SERVICE, PRODUCT, ORACLE, POOL, INSTANCE, COMPONENT, DISTRIBUTION, DISTRIBUTOR, APPLICATION, POLICY, CLAIM, BUNDLE, STAKE, STAKING, PRICE} from "../../contracts/type/ObjectType.sol";
21
+ import {StateId, ACTIVE, PAUSED} from "../../contracts/type/StateId.sol";
22
+ import {NftId, NftIdLib} from "../../contracts/type/NftId.sol";
23
+ import {Fee, FeeLib} from "../../contracts/type/Fee.sol";
24
+ import {Version, VersionPart, VersionLib} from "../../contracts/type/Version.sol";
27
25
 
28
26
  import {Service} from "../shared/Service.sol";
29
27
  import {IService} from "../shared/IService.sol";
@@ -39,11 +37,6 @@ contract RegistryService is
39
37
  // TODO update to real hash when registry is stable
40
38
  bytes32 public constant REGISTRY_CREATION_CODE_HASH = bytes32(0);
41
39
 
42
- // From IService
43
- function getDomain() public pure override returns(ObjectType serviceDomain) {
44
- return REGISTRY();
45
- }
46
-
47
40
  // from Versionable
48
41
 
49
42
  /// @dev top level initializer
@@ -61,19 +54,33 @@ contract RegistryService is
61
54
  ) = abi.decode(data, (address, address));
62
55
 
63
56
  initializeService(registryAddress, initialAuthority, owner);
64
-
65
57
  registerInterface(type(IRegistryService).interfaceId);
66
58
  }
67
59
 
60
+
61
+ function registerStaking(IRegisterable staking, address owner)
62
+ external
63
+ virtual
64
+ restricted()
65
+ returns(
66
+ IRegistry.ObjectInfo memory info
67
+ )
68
+ {
69
+ info = _getAndVerifyContractInfo(staking, STAKING(), owner);
70
+ info.nftId = getRegistry().register(info);
71
+ }
72
+
73
+
68
74
  function registerInstance(IRegisterable instance, address owner)
69
75
  external
76
+ virtual
70
77
  restricted
71
78
  returns(
72
79
  IRegistry.ObjectInfo memory info
73
80
  )
74
81
  {
75
82
  if(!instance.supportsInterface(type(IInstance).interfaceId)) {
76
- revert NotInstance();
83
+ revert ErrorRegistryServiceNotInstance(address(instance));
77
84
  }
78
85
 
79
86
  info = _getAndVerifyContractInfo(instance, INSTANCE(), owner);
@@ -91,13 +98,33 @@ contract RegistryService is
91
98
  {
92
99
  // CAN revert if no ERC165 support -> will revert with empty message
93
100
  if(!product.supportsInterface(type(IProductComponent).interfaceId)) {
94
- revert NotProduct();
101
+ revert ErrorRegistryServiceNotProduct(address(product));
95
102
  }
96
103
 
97
104
  info = _getAndVerifyContractInfo(product, PRODUCT(), owner);
98
105
  info.nftId = getRegistry().register(info);
99
106
  }
100
107
 
108
+ function registerComponent(
109
+ IComponent component,
110
+ ObjectType objectType,
111
+ address initialOwner
112
+ )
113
+ external
114
+ restricted
115
+ returns(
116
+ IRegistry.ObjectInfo memory info
117
+ )
118
+ {
119
+ // CAN revert if no ERC165 support -> will revert with empty message
120
+ if(!component.supportsInterface(type(IComponent).interfaceId)) {
121
+ revert ErrorRegistryServiceNotComponent(address(component));
122
+ }
123
+
124
+ info = _getAndVerifyContractInfo(component, objectType, initialOwner);
125
+ info.nftId = getRegistry().register(info);
126
+ }
127
+
101
128
  function registerPool(IComponent pool, address owner)
102
129
  external
103
130
  restricted
@@ -106,7 +133,7 @@ contract RegistryService is
106
133
  )
107
134
  {
108
135
  if(!pool.supportsInterface(type(IPoolComponent).interfaceId)) {
109
- revert NotPool();
136
+ revert ErrorRegistryServiceNotPool(address(pool));
110
137
  }
111
138
 
112
139
  info = _getAndVerifyContractInfo(pool, POOL(), owner);
@@ -121,7 +148,7 @@ contract RegistryService is
121
148
  )
122
149
  {
123
150
  if(!distribution.supportsInterface(type(IDistributionComponent).interfaceId)) {
124
- revert NotDistribution();
151
+ revert ErrorRegistryServiceNotDistribution(address(distribution));
125
152
  }
126
153
 
127
154
  info = _getAndVerifyContractInfo(distribution, DISTRIBUTION(), owner);
@@ -143,7 +170,6 @@ contract RegistryService is
143
170
  returns(NftId nftId)
144
171
  {
145
172
  _verifyObjectInfo(info, POLICY());
146
-
147
173
  nftId = getRegistry().register(info);
148
174
  }
149
175
 
@@ -153,7 +179,6 @@ contract RegistryService is
153
179
  returns(NftId nftId)
154
180
  {
155
181
  _verifyObjectInfo(info, BUNDLE());
156
-
157
182
  nftId = getRegistry().register(info);
158
183
  }
159
184
 
@@ -163,59 +188,9 @@ contract RegistryService is
163
188
  returns(NftId nftId)
164
189
  {
165
190
  _verifyObjectInfo(info, STAKE());
166
-
167
191
  nftId = getRegistry().register(info);
168
192
  }
169
193
 
170
- // from IRegisterable
171
-
172
- function getFunctionConfigs()
173
- external
174
- pure
175
- returns(
176
- FunctionConfig[] memory config
177
- )
178
- {
179
- config = new FunctionConfig[](8);
180
-
181
- // order of service registrations MUST be reverse to this array
182
- /*config[-1].serviceDomain = STAKE();
183
- config[-1].selector = RegistryService.registerStake.selector;*/
184
-
185
- config[0].serviceDomain = POLICY();
186
- config[0].selectors = new bytes4[](0);
187
-
188
- config[1].serviceDomain = APPLICATION();
189
- config[1].selectors = new bytes4[](1);
190
- config[1].selectors[0] = RegistryService.registerPolicy.selector;
191
-
192
- config[2].serviceDomain = CLAIM();
193
- config[2].selectors = new bytes4[](0);
194
-
195
- config[3].serviceDomain = PRODUCT();
196
- config[3].selectors = new bytes4[](1);
197
- config[3].selectors[0] = RegistryService.registerProduct.selector;
198
-
199
- config[4].serviceDomain = POOL();
200
- config[4].selectors = new bytes4[](1);
201
- config[4].selectors[0] = RegistryService.registerPool.selector;
202
-
203
- // registration of bundle service must preceed registration of pool service
204
- config[5].serviceDomain = BUNDLE();
205
- config[5].selectors = new bytes4[](1);
206
- config[5].selectors[0] = RegistryService.registerBundle.selector;
207
-
208
- config[6].serviceDomain = DISTRIBUTION();
209
- config[6].selectors = new bytes4[](2);
210
- config[6].selectors[0] = RegistryService.registerDistribution.selector;
211
- config[6].selectors[1] = RegistryService.registerDistributor.selector;
212
-
213
- // registerInstance() have no restriction
214
- config[7].serviceDomain = INSTANCE();
215
- config[7].selectors = new bytes4[](1);
216
- config[7].selectors[0] = RegistryService.registerInstance.selector;
217
- }
218
-
219
194
  // Internal
220
195
 
221
196
  function _getAndVerifyContractInfo(
@@ -224,34 +199,37 @@ contract RegistryService is
224
199
  address expectedOwner // assume can be 0 when given by other service
225
200
  )
226
201
  internal
227
- // view
202
+ view
228
203
  returns(
229
204
  IRegistry.ObjectInfo memory info
230
205
  )
231
206
  {
232
207
  info = registerable.getInitialInfo();
233
- info.objectAddress = address(registerable);
208
+
209
+ if(info.objectAddress != address(registerable)) {
210
+ revert ErrorRegistryServiceRegisterableAddressInvalid(registerable, info.objectAddress);
211
+ }
234
212
 
235
213
  if(info.objectType != expectedType) {// type is checked in registry anyway...but service logic may depend on expected value
236
- revert UnexpectedRegisterableType(expectedType, info.objectType);
214
+ revert ErrorRegistryServiceRegisterableTypeInvalid(registerable, expectedType, info.objectType);
237
215
  }
238
216
 
239
217
  address owner = info.initialOwner;
240
218
 
241
219
  if(owner != expectedOwner) { // registerable owner protection
242
- revert NotRegisterableOwner(expectedOwner);
220
+ revert ErrorRegistryServiceRegisterableOwnerInvalid(registerable, expectedOwner, owner);
243
221
  }
244
222
 
245
223
  if(owner == address(registerable)) {
246
- revert SelfRegistration();
224
+ revert ErrorRegistryServiceRegisterableSelfRegistration(registerable);
247
225
  }
248
226
 
249
227
  if(owner == address(0)) {
250
- revert RegisterableOwnerIsZero();
228
+ revert ErrorRegistryServiceRegisterableOwnerZero(registerable);
251
229
  }
252
230
 
253
231
  if(getRegistry().isRegistered(owner)) {
254
- revert RegisterableOwnerIsRegistered();
232
+ revert ErrorRegistryServiceRegisterableOwnerRegistered(registerable, owner);
255
233
  }
256
234
  }
257
235
 
@@ -262,21 +240,27 @@ contract RegistryService is
262
240
  internal
263
241
  view
264
242
  {
265
- // enforce instead of check
266
- info.objectAddress = address(0);
243
+ if(info.objectAddress > address(0)) {
244
+ revert ErrorRegistryServiceObjectAddressNotZero(info.objectType);
245
+ }
267
246
 
268
247
  if(info.objectType != expectedType) {// type is checked in registry anyway...but service logic may depend on expected value
269
- revert UnexpectedRegisterableType(expectedType, info.objectType);
248
+ revert ErrorRegistryServiceObjectTypeInvalid(expectedType, info.objectType);
270
249
  }
271
250
 
272
251
  address owner = info.initialOwner;
273
252
 
274
253
  if(owner == address(0)) {
275
- revert RegisterableOwnerIsZero();
254
+ revert ErrorRegistryServiceObjectOwnerZero(info.objectType);
276
255
  }
277
256
 
278
257
  if(getRegistry().isRegistered(owner)) {
279
- revert RegisterableOwnerIsRegistered();
258
+ revert ErrorRegistryServiceObjectOwnerRegistered(info.objectType, owner);
280
259
  }
281
260
  }
282
- }
261
+
262
+ // From IService
263
+ function _getDomain() internal override pure returns(ObjectType serviceDomain) {
264
+ return REGISTRY();
265
+ }
266
+ }