@etherisc/gif-next 0.0.2-b13fcec-949 → 0.0.2-b147315-239

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 (583) hide show
  1. package/README.md +17 -86
  2. package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +4 -0
  3. package/artifacts/contracts/{components → distribution}/Distribution.sol/Distribution.json +254 -157
  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 +202 -96
  10. package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +4 -0
  11. package/artifacts/contracts/{instance/service → distribution}/IDistributionService.sol/IDistributionService.json +126 -312
  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 +279 -1961
  16. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
  17. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +257 -55
  18. package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
  19. package/artifacts/contracts/instance/Instance.sol/Instance.json +431 -2735
  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 +762 -340
  26. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
  27. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +358 -171
  28. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
  29. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +128 -71
  30. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +4 -0
  31. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +3597 -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/ObjectLifecycle.sol/ObjectLifecycle.dbg.json +4 -0
  39. package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.json +182 -0
  40. package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +4 -0
  41. package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +187 -0
  42. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
  43. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +10 -118
  44. package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
  45. package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +1 -1
  46. package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
  47. package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
  48. package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
  49. package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +4 -0
  50. package/artifacts/contracts/mock/Dip.sol/Dip.json +376 -0
  51. package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +4 -0
  52. package/artifacts/contracts/{instance/module/ISetup.sol/ISetup.json → oracle/IOracle.sol/IOracle.json} +2 -2
  53. package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +4 -0
  54. package/artifacts/contracts/{components/IProductComponent.sol/IProductComponent.json → oracle/IOracleComponent.sol/IOracleComponent.json} +221 -192
  55. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +4 -0
  56. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +675 -0
  57. package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +4 -0
  58. package/artifacts/contracts/{components/Product.sol/Product.json → oracle/Oracle.sol/Oracle.json} +255 -266
  59. package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +4 -0
  60. package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +1034 -0
  61. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +4 -0
  62. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +730 -0
  63. package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +4 -0
  64. package/artifacts/contracts/pool/BundleService.sol/BundleService.json +1134 -0
  65. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
  66. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +754 -0
  67. package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +4 -0
  68. package/artifacts/contracts/{instance/service → pool}/IBundleService.sol/IBundleService.json +218 -145
  69. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
  70. package/artifacts/contracts/{components → pool}/IPoolComponent.sol/IPoolComponent.json +288 -88
  71. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +4 -0
  72. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +1078 -0
  73. package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +4 -0
  74. package/artifacts/contracts/{components → pool}/Pool.sol/Pool.json +298 -89
  75. package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +4 -0
  76. package/artifacts/contracts/pool/PoolService.sol/PoolService.json +1453 -0
  77. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
  78. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +742 -0
  79. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +4 -0
  80. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +863 -0
  81. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
  82. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +730 -0
  83. package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +4 -0
  84. package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +1315 -0
  85. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
  86. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +822 -0
  87. package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +4 -0
  88. package/artifacts/contracts/{instance/service/IPolicyService.sol/IPolicyService.json → product/IApplicationService.sol/IApplicationService.json} +174 -202
  89. package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +4 -0
  90. package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +772 -0
  91. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +4 -0
  92. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +720 -0
  93. package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +4 -0
  94. package/artifacts/contracts/{instance/service/IApplicationService.sol/IApplicationService.json → product/IPricingService.sol/IPricingService.json} +146 -153
  95. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +4 -0
  96. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +995 -0
  97. package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +4 -0
  98. package/artifacts/contracts/{instance/service → product}/IProductService.sol/IProductService.json +80 -64
  99. package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +4 -0
  100. package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +1183 -0
  101. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
  102. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +766 -0
  103. package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +4 -0
  104. package/artifacts/contracts/product/PricingService.sol/PricingService.json +1012 -0
  105. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +4 -0
  106. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +786 -0
  107. package/artifacts/contracts/product/Product.sol/Product.dbg.json +4 -0
  108. package/artifacts/contracts/product/Product.sol/Product.json +1397 -0
  109. package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +4 -0
  110. package/artifacts/contracts/product/ProductService.sol/ProductService.json +708 -0
  111. package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +4 -0
  112. package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +702 -0
  113. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
  114. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +2 -2
  115. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
  116. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +179 -29
  117. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
  118. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +310 -77
  119. package/artifacts/contracts/registry/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +4 -0
  120. package/artifacts/contracts/registry/IServiceAuthorization.sol/IServiceAuthorization.json +148 -0
  121. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
  122. package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
  123. package/artifacts/contracts/registry/Registry.sol/Registry.json +415 -43
  124. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +4 -0
  125. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +1901 -0
  126. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
  127. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +372 -97
  128. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
  129. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +105 -54
  130. package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +4 -0
  131. package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +187 -0
  132. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
  133. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +790 -102
  134. package/artifacts/contracts/registry/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +4 -0
  135. package/artifacts/contracts/registry/ServiceAuthorization.sol/ServiceAuthorization.json +190 -0
  136. package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +4 -0
  137. package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +206 -0
  138. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
  139. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +316 -153
  140. package/artifacts/contracts/shared/AccessAdmin.sol/AccessAdmin.dbg.json +4 -0
  141. package/artifacts/contracts/shared/AccessAdmin.sol/AccessAdmin.json +1559 -0
  142. package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.dbg.json +4 -0
  143. package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.json +1193 -0
  144. package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.dbg.json +4 -0
  145. package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.json +1747 -0
  146. package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.dbg.json +4 -0
  147. package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.json +1760 -0
  148. package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.dbg.json +4 -0
  149. package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.json +1838 -0
  150. package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.dbg.json +4 -0
  151. package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.json +1856 -0
  152. package/artifacts/contracts/shared/Component.sol/Component.dbg.json +4 -0
  153. package/artifacts/contracts/{components → shared}/Component.sol/Component.json +144 -80
  154. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +4 -0
  155. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +1511 -0
  156. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +4 -0
  157. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +796 -0
  158. package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +4 -0
  159. package/artifacts/contracts/{instance/base/ComponentService.sol/ComponentService.json → shared/ComponentVerifyingService.sol/ComponentVerifyingService.json} +100 -113
  160. package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
  161. package/artifacts/contracts/shared/ERC165.sol/ERC165.json +2 -2
  162. package/artifacts/contracts/shared/IAccessAdmin.sol/IAccessAdmin.dbg.json +4 -0
  163. package/artifacts/contracts/shared/IAccessAdmin.sol/IAccessAdmin.json +1189 -0
  164. package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.dbg.json +4 -0
  165. package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.json +1562 -0
  166. package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.dbg.json +4 -0
  167. package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.json +1600 -0
  168. package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +4 -0
  169. package/artifacts/contracts/{components → shared}/IComponent.sol/IComponent.json +180 -54
  170. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +4 -0
  171. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +880 -0
  172. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +4 -0
  173. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +705 -0
  174. package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
  175. package/artifacts/contracts/{instance/base → shared}/IKeyValueStore.sol/IKeyValueStore.json +59 -14
  176. package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +4 -0
  177. package/artifacts/contracts/{instance/base → shared}/ILifecycle.sol/ILifecycle.json +1 -6
  178. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
  179. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +3 -10
  180. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
  181. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +87 -9
  182. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
  183. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +3 -10
  184. package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
  185. package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.json +0 -13
  186. package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
  187. package/artifacts/contracts/shared/IService.sol/IService.json +96 -19
  188. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
  189. package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.dbg.json +4 -0
  190. package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.json +39 -0
  191. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +4 -0
  192. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +1036 -0
  193. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +4 -0
  194. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +570 -0
  195. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +4 -0
  196. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +156 -0
  197. package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.dbg.json +4 -0
  198. package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.json +306 -0
  199. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
  200. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +15 -22
  201. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
  202. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +98 -26
  203. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
  204. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +70 -35
  205. package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
  206. package/artifacts/contracts/shared/Registerable.sol/Registerable.json +23 -22
  207. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
  208. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -15
  209. package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
  210. package/artifacts/contracts/shared/Service.sol/Service.json +103 -21
  211. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
  212. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +60 -6
  213. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
  214. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +2 -2
  215. package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
  216. package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +4 -0
  217. package/artifacts/contracts/staking/IStaking.sol/IStaking.json +1438 -0
  218. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +4 -0
  219. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +1035 -0
  220. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +4 -0
  221. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +460 -0
  222. package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +4 -0
  223. package/artifacts/contracts/staking/Staking.sol/Staking.json +2005 -0
  224. package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.dbg.json +4 -0
  225. package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.json +187 -0
  226. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +4 -0
  227. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +761 -0
  228. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +4 -0
  229. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +592 -0
  230. package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +4 -0
  231. package/artifacts/contracts/staking/StakingService.sol/StakingService.json +1343 -0
  232. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +4 -0
  233. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +718 -0
  234. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +4 -0
  235. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +2260 -0
  236. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +4 -0
  237. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +571 -0
  238. package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +4 -0
  239. package/artifacts/contracts/{types → type}/AddressSet.sol/LibAddressSet.json +3 -3
  240. package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +4 -0
  241. package/artifacts/contracts/type/Amount.sol/AmountLib.json +345 -0
  242. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +4 -0
  243. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +225 -0
  244. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
  245. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +179 -0
  246. package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +4 -0
  247. package/artifacts/contracts/{types → type}/DistributorType.sol/DistributorTypeLib.json +5 -5
  248. package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +4 -0
  249. package/artifacts/contracts/type/Fee.sol/FeeLib.json +312 -0
  250. package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +4 -0
  251. package/artifacts/contracts/{types → type}/Key32.sol/Key32Lib.json +3 -3
  252. package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +4 -0
  253. package/artifacts/contracts/type/NftId.sol/NftIdLib.json +209 -0
  254. package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +4 -0
  255. package/artifacts/contracts/{types → type}/NftIdSet.sol/LibNftIdSet.json +3 -3
  256. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +4 -0
  257. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +186 -0
  258. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
  259. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +209 -0
  260. package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +4 -0
  261. package/artifacts/contracts/type/Referral.sol/ReferralLib.json +142 -0
  262. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +4 -0
  263. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +204 -0
  264. package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +4 -0
  265. package/artifacts/contracts/{types → type}/RiskId.sol/RiskIdLib.json +5 -5
  266. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +4 -0
  267. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +266 -0
  268. package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +4 -0
  269. package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +198 -0
  270. package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +4 -0
  271. package/artifacts/contracts/type/Selector.sol/SelectorLib.json +129 -0
  272. package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +4 -0
  273. package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +10 -0
  274. package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +4 -0
  275. package/artifacts/contracts/{types → type}/StateId.sol/StateIdLib.json +3 -3
  276. package/artifacts/contracts/type/String.sol/StrLib.dbg.json +4 -0
  277. package/artifacts/contracts/type/String.sol/StrLib.json +132 -0
  278. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +4 -0
  279. package/artifacts/contracts/{types → type}/Timestamp.sol/TimestampLib.json +33 -7
  280. package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +4 -0
  281. package/artifacts/contracts/{types → type}/UFixed.sol/MathLib.json +3 -3
  282. package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +4 -0
  283. package/artifacts/contracts/{types → type}/UFixed.sol/UFixedLib.json +3 -3
  284. package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +4 -0
  285. package/artifacts/contracts/{types → type}/Version.sol/VersionLib.json +3 -3
  286. package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +4 -0
  287. package/artifacts/contracts/{types → type}/Version.sol/VersionPartLib.json +3 -3
  288. package/contracts/{components → distribution}/Distribution.sol +47 -66
  289. package/contracts/distribution/DistributionService.sol +297 -0
  290. package/contracts/distribution/DistributionServiceManager.sol +42 -0
  291. package/contracts/{components → distribution}/IDistributionComponent.sol +11 -16
  292. package/contracts/{instance/service → distribution}/IDistributionService.sol +20 -37
  293. package/contracts/instance/BundleManager.sol +8 -9
  294. package/contracts/instance/IInstance.sol +55 -66
  295. package/contracts/instance/IInstanceService.sol +50 -25
  296. package/contracts/instance/Instance.sol +160 -224
  297. package/contracts/instance/InstanceAdmin.sol +331 -0
  298. package/contracts/instance/InstanceAuthorizationsLib.sol +377 -0
  299. package/contracts/instance/InstanceReader.sol +157 -55
  300. package/contracts/instance/InstanceService.sol +259 -315
  301. package/contracts/instance/InstanceServiceManager.sol +11 -21
  302. package/contracts/instance/InstanceStore.sol +272 -0
  303. package/contracts/instance/base/BalanceStore.sol +123 -0
  304. package/contracts/instance/base/Cloneable.sol +28 -0
  305. package/contracts/instance/base/ObjectCounter.sol +21 -0
  306. package/contracts/instance/base/ObjectLifecycle.sol +96 -0
  307. package/contracts/instance/{ObjectManager.sol → base/ObjectManager.sol} +7 -9
  308. package/contracts/instance/module/IAccess.sol +5 -13
  309. package/contracts/instance/module/IBundle.sol +8 -9
  310. package/contracts/instance/module/IComponents.sol +22 -5
  311. package/contracts/instance/module/IDistribution.sol +7 -6
  312. package/contracts/instance/module/IPolicy.sol +28 -16
  313. package/contracts/instance/module/IRisk.sol +1 -1
  314. package/contracts/{test/TestToken.sol → mock/Dip.sol} +5 -5
  315. package/contracts/oracle/IOracle.sol +20 -0
  316. package/contracts/oracle/IOracleComponent.sol +32 -0
  317. package/contracts/oracle/IOracleService.sol +65 -0
  318. package/contracts/oracle/Oracle.sol +145 -0
  319. package/contracts/oracle/OracleService.sol +278 -0
  320. package/contracts/oracle/OracleServiceManager.sol +42 -0
  321. package/contracts/pool/BundleService.sol +296 -0
  322. package/contracts/pool/BundleServiceManager.sol +42 -0
  323. package/contracts/pool/IBundleService.sol +106 -0
  324. package/contracts/{components → pool}/IPoolComponent.sol +17 -18
  325. package/contracts/pool/IPoolService.sol +150 -0
  326. package/contracts/{components → pool}/Pool.sol +57 -57
  327. package/contracts/pool/PoolService.sol +452 -0
  328. package/contracts/pool/PoolServiceManager.sol +42 -0
  329. package/contracts/product/ApplicationService.sol +254 -0
  330. package/contracts/{instance/service → product}/ApplicationServiceManager.sol +11 -8
  331. package/contracts/product/ClaimService.sol +442 -0
  332. package/contracts/{instance/service → product}/ClaimServiceManager.sol +11 -8
  333. package/contracts/{instance/service → product}/IApplicationService.sol +15 -35
  334. package/contracts/product/IClaimService.sol +99 -0
  335. package/contracts/{instance/service → product}/IPolicyService.sol +37 -31
  336. package/contracts/product/IPricingService.sol +39 -0
  337. package/contracts/product/IProductComponent.sol +42 -0
  338. package/contracts/product/IProductService.sol +33 -0
  339. package/contracts/product/PolicyService.sol +475 -0
  340. package/contracts/product/PolicyServiceManager.sol +42 -0
  341. package/contracts/product/PricingService.sol +300 -0
  342. package/contracts/product/PricingServiceManager.sol +42 -0
  343. package/contracts/{components → product}/Product.sol +191 -107
  344. package/contracts/product/ProductService.sol +124 -0
  345. package/contracts/product/ProductServiceManager.sol +42 -0
  346. package/contracts/registry/ChainNft.sol +8 -1
  347. package/contracts/registry/IRegistry.sol +44 -21
  348. package/contracts/registry/IRegistryService.sol +39 -37
  349. package/contracts/registry/IServiceAuthorization.sol +38 -0
  350. package/contracts/registry/Registry.sol +198 -83
  351. package/contracts/registry/RegistryAdmin.sol +333 -0
  352. package/contracts/registry/RegistryService.sol +73 -90
  353. package/contracts/registry/RegistryServiceManager.sol +21 -30
  354. package/contracts/registry/ReleaseLifecycle.sol +28 -0
  355. package/contracts/registry/ReleaseManager.sol +371 -192
  356. package/contracts/registry/ServiceAuthorization.sol +90 -0
  357. package/contracts/registry/ServiceAuthorizationV3.sol +200 -0
  358. package/contracts/registry/TokenRegistry.sol +261 -62
  359. package/contracts/shared/AccessAdmin.sol +759 -0
  360. package/contracts/shared/AccessManagerCustom.sol +741 -0
  361. package/contracts/shared/AccessManagerExtended.sol +481 -0
  362. package/contracts/shared/AccessManagerExtendedInitializeable.sol +13 -0
  363. package/contracts/shared/AccessManagerExtendedWithDisable.sol +137 -0
  364. package/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol +14 -0
  365. package/contracts/shared/Component.sol +281 -0
  366. package/contracts/shared/ComponentService.sol +620 -0
  367. package/contracts/shared/ComponentServiceManager.sol +35 -0
  368. package/contracts/shared/ComponentVerifyingService.sol +117 -0
  369. package/contracts/shared/ERC165.sol +1 -1
  370. package/contracts/shared/IAccessAdmin.sol +168 -0
  371. package/contracts/shared/IAccessManagerExtended.sol +74 -0
  372. package/contracts/shared/IAccessManagerExtendedWithDisable.sol +18 -0
  373. package/contracts/{components → shared}/IComponent.sol +23 -27
  374. package/contracts/shared/IComponentService.sol +102 -0
  375. package/contracts/shared/IInstanceLinkedComponent.sol +46 -0
  376. package/contracts/{instance/base → shared}/IKeyValueStore.sol +16 -11
  377. package/contracts/{instance/base → shared}/ILifecycle.sol +3 -4
  378. package/contracts/shared/INftOwnable.sol +2 -2
  379. package/contracts/shared/IPolicyHolder.sol +29 -10
  380. package/contracts/shared/IRegistryLinked.sol +0 -1
  381. package/contracts/shared/IService.sol +14 -7
  382. package/contracts/shared/IVersionable.sol +1 -1
  383. package/contracts/shared/InitializableCustom.sol +177 -0
  384. package/contracts/shared/InstanceLinkedComponent.sol +144 -0
  385. package/contracts/shared/KeyValueStore.sol +131 -0
  386. package/contracts/shared/Lifecycle.sol +71 -0
  387. package/contracts/shared/NftIdSetManager.sol +65 -0
  388. package/contracts/shared/NftOwnable.sol +3 -16
  389. package/contracts/shared/PolicyHolder.sol +40 -19
  390. package/contracts/shared/ProxyManager.sol +34 -4
  391. package/contracts/shared/Registerable.sol +13 -12
  392. package/contracts/shared/RegistryLinked.sol +0 -5
  393. package/contracts/shared/Service.sol +47 -22
  394. package/contracts/shared/TokenHandler.sol +27 -2
  395. package/contracts/shared/Versionable.sol +1 -1
  396. package/contracts/staking/IStaking.sol +168 -0
  397. package/contracts/staking/IStakingService.sol +153 -0
  398. package/contracts/staking/StakeManagerLib.sol +231 -0
  399. package/contracts/staking/Staking.sol +513 -0
  400. package/contracts/staking/StakingLifecycle.sol +24 -0
  401. package/contracts/staking/StakingManager.sol +54 -0
  402. package/contracts/staking/StakingReader.sol +187 -0
  403. package/contracts/staking/StakingService.sol +411 -0
  404. package/contracts/staking/StakingServiceManager.sol +44 -0
  405. package/contracts/staking/StakingStore.sol +615 -0
  406. package/contracts/staking/TargetManagerLib.sol +207 -0
  407. package/contracts/{types → type}/AddressSet.sol +1 -1
  408. package/contracts/type/Amount.sol +128 -0
  409. package/contracts/{types → type}/Blocknumber.sol +20 -3
  410. package/contracts/{types → type}/ClaimId.sol +25 -2
  411. package/contracts/{types → type}/Fee.sol +33 -24
  412. package/contracts/{types → type}/NftId.sol +14 -16
  413. package/contracts/{types → type}/NftIdSet.sol +2 -2
  414. package/contracts/type/ObjectType.sol +241 -0
  415. package/contracts/{types → type}/PayoutId.sol +33 -5
  416. package/contracts/{types → type}/Referral.sol +1 -1
  417. package/contracts/type/RequestId.sol +75 -0
  418. package/contracts/{types → type}/RiskId.sol +1 -1
  419. package/contracts/type/RoleId.sol +201 -0
  420. package/contracts/{types → type}/Seconds.sol +27 -0
  421. package/contracts/type/Selector.sol +102 -0
  422. package/contracts/{types → type}/StateId.sol +33 -4
  423. package/contracts/type/String.sol +53 -0
  424. package/contracts/{types → type}/Timestamp.sol +10 -1
  425. package/contracts/{types → type}/Version.sol +1 -1
  426. package/package.json +4 -3
  427. package/artifacts/contracts/components/Component.sol/Component.dbg.json +0 -4
  428. package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +0 -4
  429. package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +0 -4
  430. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +0 -4
  431. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +0 -4
  432. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +0 -4
  433. package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +0 -4
  434. package/artifacts/contracts/components/Product.sol/Product.dbg.json +0 -4
  435. package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +0 -4
  436. package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +0 -1206
  437. package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +0 -4
  438. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +0 -4
  439. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +0 -1311
  440. package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +0 -4
  441. package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +0 -256
  442. package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.dbg.json +0 -4
  443. package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +0 -4
  444. package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +0 -4
  445. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +0 -4
  446. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +0 -532
  447. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +0 -4
  448. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +0 -194
  449. package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +0 -4
  450. package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +0 -4
  451. package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.json +0 -10
  452. package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.dbg.json +0 -4
  453. package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.json +0 -968
  454. package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +0 -4
  455. package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.json +0 -665
  456. package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +0 -4
  457. package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +0 -1093
  458. package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +0 -4
  459. package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +0 -661
  460. package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.dbg.json +0 -4
  461. package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.json +0 -754
  462. package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +0 -4
  463. package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.json +0 -637
  464. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +0 -4
  465. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +0 -1732
  466. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +0 -4
  467. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +0 -805
  468. package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.dbg.json +0 -4
  469. package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +0 -4
  470. package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.dbg.json +0 -4
  471. package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.json +0 -409
  472. package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +0 -4
  473. package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +0 -4
  474. package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +0 -4
  475. package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +0 -428
  476. package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +0 -4
  477. package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +0 -4
  478. package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +0 -1021
  479. package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +0 -4
  480. package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +0 -689
  481. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +0 -4
  482. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +0 -824
  483. package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +0 -4
  484. package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +0 -657
  485. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +0 -4
  486. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +0 -777
  487. package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
  488. package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +0 -649
  489. package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +0 -4
  490. package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +0 -285
  491. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +0 -4
  492. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +0 -107
  493. package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +0 -4
  494. package/artifacts/contracts/test/TestFee.sol/TestFee.json +0 -119
  495. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +0 -4
  496. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +0 -383
  497. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +0 -4
  498. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +0 -116
  499. package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +0 -4
  500. package/artifacts/contracts/test/TestService.sol/TestService.json +0 -521
  501. package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +0 -4
  502. package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +0 -376
  503. package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +0 -4
  504. package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +0 -218
  505. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +0 -4
  506. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +0 -104
  507. package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +0 -4
  508. package/artifacts/contracts/test/Usdc.sol/USDC.json +0 -376
  509. package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +0 -4
  510. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +0 -4
  511. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +0 -174
  512. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +0 -4
  513. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +0 -10
  514. package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.dbg.json +0 -4
  515. package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.json +0 -100
  516. package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +0 -4
  517. package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +0 -4
  518. package/artifacts/contracts/types/Fee.sol/FeeLib.json +0 -257
  519. package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +0 -4
  520. package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +0 -4
  521. package/artifacts/contracts/types/NftId.sol/NftIdLib.json +0 -166
  522. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +0 -4
  523. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +0 -4
  524. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.json +0 -100
  525. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +0 -4
  526. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +0 -92
  527. package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.dbg.json +0 -4
  528. package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.json +0 -100
  529. package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +0 -4
  530. package/artifacts/contracts/types/Referral.sol/ReferralLib.json +0 -142
  531. package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +0 -4
  532. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +0 -4
  533. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +0 -156
  534. package/artifacts/contracts/types/Seconds.sol/SecondsLib.dbg.json +0 -4
  535. package/artifacts/contracts/types/Seconds.sol/SecondsLib.json +0 -124
  536. package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +0 -4
  537. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +0 -4
  538. package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +0 -4
  539. package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +0 -4
  540. package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +0 -4
  541. package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +0 -4
  542. package/contracts/components/Component.sol +0 -251
  543. package/contracts/components/IProductComponent.sol +0 -40
  544. package/contracts/instance/AccessManagerUpgradeableInitializeable.sol +0 -13
  545. package/contracts/instance/Cloneable.sol +0 -51
  546. package/contracts/instance/InstanceAccessManager.sol +0 -522
  547. package/contracts/instance/base/ComponentService.sol +0 -134
  548. package/contracts/instance/base/KeyValueStore.sol +0 -175
  549. package/contracts/instance/base/Lifecycle.sol +0 -109
  550. package/contracts/instance/module/ISetup.sol +0 -33
  551. package/contracts/instance/module/ITreasury.sol +0 -23
  552. package/contracts/instance/service/ApplicationService.sol +0 -350
  553. package/contracts/instance/service/BundleService.sol +0 -336
  554. package/contracts/instance/service/BundleServiceManager.sol +0 -51
  555. package/contracts/instance/service/ClaimService.sol +0 -151
  556. package/contracts/instance/service/DistributionService.sol +0 -467
  557. package/contracts/instance/service/DistributionServiceManager.sol +0 -51
  558. package/contracts/instance/service/IBundleService.sol +0 -62
  559. package/contracts/instance/service/IClaimService.sol +0 -61
  560. package/contracts/instance/service/IPoolService.sol +0 -35
  561. package/contracts/instance/service/IProductService.sol +0 -40
  562. package/contracts/instance/service/PolicyService.sol +0 -403
  563. package/contracts/instance/service/PolicyServiceManager.sol +0 -54
  564. package/contracts/instance/service/PoolService.sol +0 -220
  565. package/contracts/instance/service/PoolServiceManager.sol +0 -51
  566. package/contracts/instance/service/ProductService.sol +0 -241
  567. package/contracts/instance/service/ProductServiceManager.sol +0 -54
  568. package/contracts/registry/RegistryAccessManager.sol +0 -216
  569. package/contracts/shared/ContractDeployerLib.sol +0 -72
  570. package/contracts/test/TestFee.sol +0 -25
  571. package/contracts/test/TestRegisterable.sol +0 -18
  572. package/contracts/test/TestRoleId.sol +0 -14
  573. package/contracts/test/TestService.sol +0 -25
  574. package/contracts/test/TestVersion.sol +0 -44
  575. package/contracts/test/TestVersionable.sol +0 -17
  576. package/contracts/test/Usdc.sol +0 -26
  577. package/contracts/types/ChainId.sol +0 -38
  578. package/contracts/types/NumberId.sol +0 -52
  579. package/contracts/types/ObjectType.sol +0 -157
  580. package/contracts/types/RoleId.sol +0 -97
  581. /package/contracts/{types → type}/DistributorType.sol +0 -0
  582. /package/contracts/{types → type}/Key32.sol +0 -0
  583. /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
+ }
@@ -2,28 +2,26 @@
2
2
  pragma solidity ^0.8.20;
3
3
 
4
4
  import {ERC165Checker} from "@openzeppelin/contracts/utils/introspection/ERC165Checker.sol";
5
- import {AccessManagedUpgradeable} from "@openzeppelin/contracts-upgradeable/access/manager/AccessManagedUpgradeable.sol";
5
+ // import {AccessManagedUpgradeable} from "@openzeppelin/contracts-upgradeable/access/manager/AccessManagedUpgradeable.sol";
6
6
 
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";
@@ -31,7 +29,6 @@ import {IRegistryService} from "./IRegistryService.sol";
31
29
  import {Registry} from "./Registry.sol";
32
30
 
33
31
  contract RegistryService is
34
- AccessManagedUpgradeable,
35
32
  Service,
36
33
  IRegistryService
37
34
  {
@@ -40,11 +37,6 @@ contract RegistryService is
40
37
  // TODO update to real hash when registry is stable
41
38
  bytes32 public constant REGISTRY_CREATION_CODE_HASH = bytes32(0);
42
39
 
43
- // From IService
44
- function getDomain() public pure override(IService, Service) returns(ObjectType serviceDomain) {
45
- return REGISTRY();
46
- }
47
-
48
40
  // from Versionable
49
41
 
50
42
  /// @dev top level initializer
@@ -61,21 +53,34 @@ contract RegistryService is
61
53
  address initialAuthority
62
54
  ) = abi.decode(data, (address, address));
63
55
 
64
- __AccessManaged_init(initialAuthority);
65
-
66
- initializeService(registryAddress, owner);
56
+ initializeService(registryAddress, initialAuthority, owner);
67
57
  registerInterface(type(IRegistryService).interfaceId);
68
58
  }
69
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
+
70
74
  function registerInstance(IRegisterable instance, address owner)
71
75
  external
76
+ virtual
72
77
  restricted
73
78
  returns(
74
79
  IRegistry.ObjectInfo memory info
75
80
  )
76
81
  {
77
82
  if(!instance.supportsInterface(type(IInstance).interfaceId)) {
78
- revert NotInstance();
83
+ revert ErrorRegistryServiceNotInstance(address(instance));
79
84
  }
80
85
 
81
86
  info = _getAndVerifyContractInfo(instance, INSTANCE(), owner);
@@ -93,13 +98,33 @@ contract RegistryService is
93
98
  {
94
99
  // CAN revert if no ERC165 support -> will revert with empty message
95
100
  if(!product.supportsInterface(type(IProductComponent).interfaceId)) {
96
- revert NotProduct();
101
+ revert ErrorRegistryServiceNotProduct(address(product));
97
102
  }
98
103
 
99
104
  info = _getAndVerifyContractInfo(product, PRODUCT(), owner);
100
105
  info.nftId = getRegistry().register(info);
101
106
  }
102
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
+
103
128
  function registerPool(IComponent pool, address owner)
104
129
  external
105
130
  restricted
@@ -108,7 +133,7 @@ contract RegistryService is
108
133
  )
109
134
  {
110
135
  if(!pool.supportsInterface(type(IPoolComponent).interfaceId)) {
111
- revert NotPool();
136
+ revert ErrorRegistryServiceNotPool(address(pool));
112
137
  }
113
138
 
114
139
  info = _getAndVerifyContractInfo(pool, POOL(), owner);
@@ -123,7 +148,7 @@ contract RegistryService is
123
148
  )
124
149
  {
125
150
  if(!distribution.supportsInterface(type(IDistributionComponent).interfaceId)) {
126
- revert NotDistribution();
151
+ revert ErrorRegistryServiceNotDistribution(address(distribution));
127
152
  }
128
153
 
129
154
  info = _getAndVerifyContractInfo(distribution, DISTRIBUTION(), owner);
@@ -145,7 +170,6 @@ contract RegistryService is
145
170
  returns(NftId nftId)
146
171
  {
147
172
  _verifyObjectInfo(info, POLICY());
148
-
149
173
  nftId = getRegistry().register(info);
150
174
  }
151
175
 
@@ -155,7 +179,6 @@ contract RegistryService is
155
179
  returns(NftId nftId)
156
180
  {
157
181
  _verifyObjectInfo(info, BUNDLE());
158
-
159
182
  nftId = getRegistry().register(info);
160
183
  }
161
184
 
@@ -165,58 +188,9 @@ contract RegistryService is
165
188
  returns(NftId nftId)
166
189
  {
167
190
  _verifyObjectInfo(info, STAKE());
168
-
169
191
  nftId = getRegistry().register(info);
170
192
  }
171
193
 
172
- // from IRegisterable
173
-
174
- function getFunctionConfigs()
175
- external
176
- pure
177
- returns(
178
- FunctionConfig[] memory config
179
- )
180
- {
181
- config = new FunctionConfig[](8);
182
-
183
- // order of service registrations MUST be reverse to this array
184
- /*config[-1].serviceDomain = STAKE();
185
- config[-1].selector = RegistryService.registerStake.selector;*/
186
-
187
- config[0].serviceDomain = POLICY();
188
- config[0].selectors = new bytes4[](0);
189
-
190
- config[1].serviceDomain = APPLICATION();
191
- config[1].selectors = new bytes4[](1);
192
- config[1].selectors[0] = RegistryService.registerPolicy.selector;
193
-
194
- config[2].serviceDomain = CLAIM();
195
- config[2].selectors = new bytes4[](0);
196
-
197
- config[3].serviceDomain = BUNDLE();
198
- config[3].selectors = new bytes4[](1);
199
- config[3].selectors[0] = RegistryService.registerBundle.selector;
200
-
201
- config[4].serviceDomain = PRODUCT();
202
- config[4].selectors = new bytes4[](1);
203
- config[4].selectors[0] = RegistryService.registerProduct.selector;
204
-
205
- config[5].serviceDomain = POOL();
206
- config[5].selectors = new bytes4[](1);
207
- config[5].selectors[0] = RegistryService.registerPool.selector;
208
-
209
- config[6].serviceDomain = DISTRIBUTION();
210
- config[6].selectors = new bytes4[](2);
211
- config[6].selectors[0] = RegistryService.registerDistribution.selector;
212
- config[6].selectors[1] = RegistryService.registerDistributor.selector;
213
-
214
- // registerInstance() have no restriction
215
- config[7].serviceDomain = INSTANCE();
216
- config[7].selectors = new bytes4[](1);
217
- config[7].selectors[0] = RegistryService.registerInstance.selector;
218
- }
219
-
220
194
  // Internal
221
195
 
222
196
  function _getAndVerifyContractInfo(
@@ -225,34 +199,37 @@ contract RegistryService is
225
199
  address expectedOwner // assume can be 0 when given by other service
226
200
  )
227
201
  internal
228
- // view
202
+ view
229
203
  returns(
230
204
  IRegistry.ObjectInfo memory info
231
205
  )
232
206
  {
233
207
  info = registerable.getInitialInfo();
234
- info.objectAddress = address(registerable);
208
+
209
+ if(info.objectAddress != address(registerable)) {
210
+ revert ErrorRegistryServiceRegisterableAddressInvalid(registerable, info.objectAddress);
211
+ }
235
212
 
236
213
  if(info.objectType != expectedType) {// type is checked in registry anyway...but service logic may depend on expected value
237
- revert UnexpectedRegisterableType(expectedType, info.objectType);
214
+ revert ErrorRegistryServiceRegisterableTypeInvalid(registerable, expectedType, info.objectType);
238
215
  }
239
216
 
240
217
  address owner = info.initialOwner;
241
218
 
242
219
  if(owner != expectedOwner) { // registerable owner protection
243
- revert NotRegisterableOwner(expectedOwner);
220
+ revert ErrorRegistryServiceRegisterableOwnerInvalid(registerable, expectedOwner, owner);
244
221
  }
245
222
 
246
223
  if(owner == address(registerable)) {
247
- revert SelfRegistration();
224
+ revert ErrorRegistryServiceRegisterableSelfRegistration(registerable);
248
225
  }
249
226
 
250
227
  if(owner == address(0)) {
251
- revert RegisterableOwnerIsZero();
228
+ revert ErrorRegistryServiceRegisterableOwnerZero(registerable);
252
229
  }
253
230
 
254
231
  if(getRegistry().isRegistered(owner)) {
255
- revert RegisterableOwnerIsRegistered();
232
+ revert ErrorRegistryServiceRegisterableOwnerRegistered(registerable, owner);
256
233
  }
257
234
  }
258
235
 
@@ -263,21 +240,27 @@ contract RegistryService is
263
240
  internal
264
241
  view
265
242
  {
266
- // enforce instead of check
267
- info.objectAddress = address(0);
243
+ if(info.objectAddress > address(0)) {
244
+ revert ErrorRegistryServiceObjectAddressNotZero(info.objectType);
245
+ }
268
246
 
269
247
  if(info.objectType != expectedType) {// type is checked in registry anyway...but service logic may depend on expected value
270
- revert UnexpectedRegisterableType(expectedType, info.objectType);
248
+ revert ErrorRegistryServiceObjectTypeInvalid(expectedType, info.objectType);
271
249
  }
272
250
 
273
251
  address owner = info.initialOwner;
274
252
 
275
253
  if(owner == address(0)) {
276
- revert RegisterableOwnerIsZero();
254
+ revert ErrorRegistryServiceObjectOwnerZero(info.objectType);
277
255
  }
278
256
 
279
257
  if(getRegistry().isRegistered(owner)) {
280
- revert RegisterableOwnerIsRegistered();
258
+ revert ErrorRegistryServiceObjectOwnerRegistered(info.objectType, owner);
281
259
  }
282
260
  }
283
- }
261
+
262
+ // From IService
263
+ function _getDomain() internal override pure returns(ObjectType serviceDomain) {
264
+ return REGISTRY();
265
+ }
266
+ }