@etherisc/gif-next 0.0.2-ce87da3-250 → 0.0.2-ce8fb44-591

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 (606) hide show
  1. package/README.md +26 -86
  2. package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +4 -0
  3. package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +1248 -0
  4. package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.dbg.json +4 -0
  5. package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.json +1206 -0
  6. package/artifacts/contracts/authorization/Authorization.sol/Authorization.dbg.json +4 -0
  7. package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +358 -0
  8. package/artifacts/contracts/authorization/IAccess.sol/IAccess.dbg.json +4 -0
  9. package/artifacts/contracts/{instance/module/ISetup.sol/ISetup.json → authorization/IAccess.sol/IAccess.json} +2 -2
  10. package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.dbg.json +4 -0
  11. package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.json +1032 -0
  12. package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +4 -0
  13. package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +258 -0
  14. package/artifacts/contracts/authorization/IModuleAuthorization.sol/IModuleAuthorization.dbg.json +4 -0
  15. package/artifacts/contracts/authorization/IModuleAuthorization.sol/IModuleAuthorization.json +290 -0
  16. package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +4 -0
  17. package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.json +148 -0
  18. package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.dbg.json +4 -0
  19. package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.json +390 -0
  20. package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +4 -0
  21. package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +190 -0
  22. package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +4 -0
  23. package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +1505 -0
  24. package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +4 -0
  25. package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +410 -0
  26. package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +4 -0
  27. package/artifacts/contracts/{components → distribution}/Distribution.sol/Distribution.json +257 -412
  28. package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +4 -0
  29. package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +1394 -0
  30. package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
  31. package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +826 -0
  32. package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +4 -0
  33. package/artifacts/contracts/{components → distribution}/IDistributionComponent.sol/IDistributionComponent.json +286 -286
  34. package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +4 -0
  35. package/artifacts/contracts/{instance/service → distribution}/IDistributionService.sol/IDistributionService.json +287 -83
  36. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
  37. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +61 -122
  38. package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
  39. package/artifacts/contracts/instance/IInstance.sol/IInstance.json +292 -2124
  40. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
  41. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +315 -67
  42. package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
  43. package/artifacts/contracts/instance/Instance.sol/Instance.json +397 -2881
  44. package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +4 -0
  45. package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +1621 -0
  46. package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +4 -0
  47. package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +601 -0
  48. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
  49. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +663 -314
  50. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
  51. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +376 -262
  52. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
  53. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +115 -74
  54. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +4 -0
  55. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +3591 -0
  56. package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +4 -0
  57. package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +318 -0
  58. package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +4 -0
  59. package/artifacts/contracts/instance/{Cloneable.sol → base/Cloneable.sol}/Cloneable.json +1 -49
  60. package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +4 -0
  61. package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +10 -0
  62. package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.dbg.json +4 -0
  63. package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.json +182 -0
  64. package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +4 -0
  65. package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +181 -0
  66. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
  67. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +25 -150
  68. package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
  69. package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +4 -0
  70. package/artifacts/contracts/instance/module/{ITreasury.sol/ITreasury.json → IComponents.sol/IComponents.json} +2 -2
  71. package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
  72. package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
  73. package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
  74. package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +4 -0
  75. package/artifacts/contracts/mock/Dip.sol/Dip.json +376 -0
  76. package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.dbg.json +4 -0
  77. package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.json +1155 -0
  78. package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +4 -0
  79. package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +418 -0
  80. package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +4 -0
  81. package/artifacts/contracts/oracle/IOracle.sol/IOracle.json +52 -0
  82. package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +4 -0
  83. package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +772 -0
  84. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +4 -0
  85. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +675 -0
  86. package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +4 -0
  87. package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +1063 -0
  88. package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +4 -0
  89. package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +1034 -0
  90. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +4 -0
  91. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +730 -0
  92. package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +4 -0
  93. package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +1477 -0
  94. package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +4 -0
  95. package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +410 -0
  96. package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +4 -0
  97. package/artifacts/contracts/pool/BundleService.sol/BundleService.json +1134 -0
  98. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
  99. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +754 -0
  100. package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +4 -0
  101. package/artifacts/contracts/{instance/service → pool}/IBundleService.sol/IBundleService.json +283 -213
  102. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
  103. package/artifacts/contracts/{components → pool}/IPoolComponent.sol/IPoolComponent.json +398 -326
  104. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +4 -0
  105. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +1078 -0
  106. package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +4 -0
  107. package/artifacts/contracts/{components → pool}/Pool.sol/Pool.json +397 -450
  108. package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +4 -0
  109. package/artifacts/contracts/pool/PoolService.sol/PoolService.json +1453 -0
  110. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
  111. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +742 -0
  112. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +4 -0
  113. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +863 -0
  114. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
  115. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +730 -0
  116. package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +4 -0
  117. package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +1299 -0
  118. package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +4 -0
  119. package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +410 -0
  120. package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +4 -0
  121. package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +1315 -0
  122. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
  123. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +822 -0
  124. package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +4 -0
  125. package/artifacts/contracts/{instance/service → product}/IApplicationService.sol/IApplicationService.json +129 -90
  126. package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +4 -0
  127. package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +772 -0
  128. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +4 -0
  129. package/artifacts/contracts/{instance/service → product}/IPolicyService.sol/IPolicyService.json +271 -134
  130. package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +4 -0
  131. package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +549 -0
  132. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +4 -0
  133. package/artifacts/contracts/{components → product}/IProductComponent.sol/IProductComponent.json +401 -241
  134. package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +4 -0
  135. package/artifacts/contracts/{instance/service → product}/IProductService.sol/IProductService.json +80 -64
  136. package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +4 -0
  137. package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +1183 -0
  138. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
  139. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +766 -0
  140. package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +4 -0
  141. package/artifacts/contracts/product/PricingService.sol/PricingService.json +1012 -0
  142. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +4 -0
  143. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +786 -0
  144. package/artifacts/contracts/product/Product.sol/Product.dbg.json +4 -0
  145. package/artifacts/contracts/{components → product}/Product.sol/Product.json +378 -367
  146. package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +4 -0
  147. package/artifacts/contracts/product/ProductService.sol/ProductService.json +708 -0
  148. package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +4 -0
  149. package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +702 -0
  150. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
  151. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +15 -2
  152. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
  153. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +144 -19
  154. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
  155. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +310 -77
  156. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
  157. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +18 -0
  158. package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
  159. package/artifacts/contracts/registry/Registry.sol/Registry.json +381 -34
  160. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +4 -0
  161. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +1741 -0
  162. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
  163. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +373 -98
  164. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
  165. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +105 -54
  166. package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +4 -0
  167. package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +164 -0
  168. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
  169. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +703 -91
  170. package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +4 -0
  171. package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +214 -0
  172. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
  173. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +316 -153
  174. package/artifacts/contracts/shared/Component.sol/Component.dbg.json +4 -0
  175. package/artifacts/contracts/{components → shared}/Component.sol/Component.json +209 -166
  176. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +4 -0
  177. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +1487 -0
  178. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +4 -0
  179. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +784 -0
  180. package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +4 -0
  181. package/artifacts/contracts/{instance/base/ComponentService.sol/ComponentService.json → shared/ComponentVerifyingService.sol/ComponentVerifyingService.json} +101 -114
  182. package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
  183. package/artifacts/contracts/shared/ERC165.sol/ERC165.json +2 -2
  184. package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +4 -0
  185. package/artifacts/contracts/{components → shared}/IComponent.sol/IComponent.json +222 -104
  186. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +4 -0
  187. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +880 -0
  188. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +4 -0
  189. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +718 -0
  190. package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
  191. package/artifacts/contracts/{instance/base → shared}/IKeyValueStore.sol/IKeyValueStore.json +59 -14
  192. package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +4 -0
  193. package/artifacts/contracts/{instance/base → shared}/ILifecycle.sol/ILifecycle.json +1 -6
  194. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
  195. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +3 -10
  196. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
  197. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +87 -9
  198. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
  199. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +3 -10
  200. package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
  201. package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.json +0 -13
  202. package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
  203. package/artifacts/contracts/shared/IService.sol/IService.json +96 -19
  204. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
  205. package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.dbg.json +4 -0
  206. package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.json +39 -0
  207. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +4 -0
  208. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +996 -0
  209. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +4 -0
  210. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +497 -0
  211. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +4 -0
  212. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +133 -0
  213. package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.dbg.json +4 -0
  214. package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.json +306 -0
  215. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
  216. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +15 -22
  217. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
  218. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +98 -26
  219. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
  220. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +70 -35
  221. package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
  222. package/artifacts/contracts/shared/Registerable.sol/Registerable.json +24 -23
  223. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
  224. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -15
  225. package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
  226. package/artifacts/contracts/shared/Service.sol/Service.json +104 -22
  227. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
  228. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +60 -6
  229. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
  230. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +2 -2
  231. package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
  232. package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +4 -0
  233. package/artifacts/contracts/staking/IStaking.sol/IStaking.json +1438 -0
  234. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +4 -0
  235. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +1035 -0
  236. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +4 -0
  237. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +460 -0
  238. package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +4 -0
  239. package/artifacts/contracts/staking/Staking.sol/Staking.json +2005 -0
  240. package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.dbg.json +4 -0
  241. package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.json +164 -0
  242. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +4 -0
  243. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +761 -0
  244. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +4 -0
  245. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +592 -0
  246. package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +4 -0
  247. package/artifacts/contracts/staking/StakingService.sol/StakingService.json +1343 -0
  248. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +4 -0
  249. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +718 -0
  250. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +4 -0
  251. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +2237 -0
  252. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +4 -0
  253. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +571 -0
  254. package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +4 -0
  255. package/artifacts/contracts/{types → type}/AddressSet.sol/LibAddressSet.json +3 -3
  256. package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +4 -0
  257. package/artifacts/contracts/type/Amount.sol/AmountLib.json +345 -0
  258. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +4 -0
  259. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +225 -0
  260. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
  261. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +179 -0
  262. package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +4 -0
  263. package/artifacts/contracts/{types → type}/DistributorType.sol/DistributorTypeLib.json +5 -5
  264. package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +4 -0
  265. package/artifacts/contracts/type/Fee.sol/FeeLib.json +312 -0
  266. package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +4 -0
  267. package/artifacts/contracts/{types → type}/Key32.sol/Key32Lib.json +3 -3
  268. package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +4 -0
  269. package/artifacts/contracts/type/NftId.sol/NftIdLib.json +209 -0
  270. package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +4 -0
  271. package/artifacts/contracts/{types → type}/NftIdSet.sol/LibNftIdSet.json +3 -3
  272. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +4 -0
  273. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +239 -0
  274. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
  275. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +209 -0
  276. package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +4 -0
  277. package/artifacts/contracts/type/Referral.sol/ReferralLib.json +142 -0
  278. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +4 -0
  279. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +204 -0
  280. package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +4 -0
  281. package/artifacts/contracts/{types → type}/RiskId.sol/RiskIdLib.json +5 -5
  282. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +4 -0
  283. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +369 -0
  284. package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +4 -0
  285. package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +198 -0
  286. package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +4 -0
  287. package/artifacts/contracts/type/Selector.sol/SelectorLib.json +129 -0
  288. package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +4 -0
  289. package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +10 -0
  290. package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +4 -0
  291. package/artifacts/contracts/{types → type}/StateId.sol/StateIdLib.json +3 -3
  292. package/artifacts/contracts/type/String.sol/StrLib.dbg.json +4 -0
  293. package/artifacts/contracts/type/String.sol/StrLib.json +132 -0
  294. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +4 -0
  295. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +293 -0
  296. package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +4 -0
  297. package/artifacts/contracts/{types → type}/UFixed.sol/MathLib.json +3 -3
  298. package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +4 -0
  299. package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +498 -0
  300. package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +4 -0
  301. package/artifacts/contracts/{types → type}/Version.sol/VersionLib.json +3 -3
  302. package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +4 -0
  303. package/artifacts/contracts/{types → type}/Version.sol/VersionPartLib.json +3 -3
  304. package/contracts/authorization/AccessAdmin.sol +588 -0
  305. package/contracts/authorization/AccessManagerCloneable.sol +16 -0
  306. package/contracts/authorization/Authorization.sol +218 -0
  307. package/contracts/authorization/IAccess.sol +48 -0
  308. package/contracts/authorization/IAccessAdmin.sol +136 -0
  309. package/contracts/authorization/IAuthorization.sol +54 -0
  310. package/contracts/authorization/IModuleAuthorization.sol +21 -0
  311. package/contracts/authorization/IServiceAuthorization.sol +38 -0
  312. package/contracts/authorization/ModuleAuthorization.sol +78 -0
  313. package/contracts/authorization/ServiceAuthorization.sol +90 -0
  314. package/contracts/distribution/BasicDistribution.sol +149 -0
  315. package/contracts/distribution/BasicDistributionAuthorization.sol +43 -0
  316. package/contracts/{components → distribution}/Distribution.sol +163 -167
  317. package/contracts/distribution/DistributionService.sol +302 -0
  318. package/contracts/distribution/DistributionServiceManager.sol +42 -0
  319. package/contracts/distribution/IDistributionComponent.sol +48 -0
  320. package/contracts/{instance/service → distribution}/IDistributionService.sol +29 -25
  321. package/contracts/instance/BundleManager.sol +15 -14
  322. package/contracts/instance/IInstance.sol +58 -64
  323. package/contracts/instance/IInstanceService.sol +54 -21
  324. package/contracts/instance/Instance.sol +174 -211
  325. package/contracts/instance/InstanceAdmin.sol +266 -0
  326. package/contracts/instance/InstanceAuthorizationV3.sol +202 -0
  327. package/contracts/instance/InstanceReader.sol +173 -61
  328. package/contracts/instance/InstanceService.sol +304 -337
  329. package/contracts/instance/InstanceServiceManager.sol +11 -21
  330. package/contracts/instance/InstanceStore.sol +276 -0
  331. package/contracts/instance/base/BalanceStore.sol +123 -0
  332. package/contracts/instance/{Cloneable.sol → base/Cloneable.sol} +4 -22
  333. package/contracts/instance/base/ObjectCounter.sol +21 -0
  334. package/contracts/instance/base/ObjectLifecycle.sol +106 -0
  335. package/contracts/instance/{ObjectManager.sol → base/ObjectManager.sol} +13 -18
  336. package/contracts/instance/module/IAccess.sol +19 -20
  337. package/contracts/instance/module/IBundle.sol +8 -8
  338. package/contracts/instance/module/{ISetup.sol → IComponents.sol} +24 -20
  339. package/contracts/instance/module/IDistribution.sol +7 -5
  340. package/contracts/instance/module/IPolicy.sol +53 -16
  341. package/contracts/instance/module/IRisk.sol +1 -1
  342. package/contracts/{test/TestToken.sol → mock/Dip.sol} +5 -5
  343. package/contracts/oracle/BasicOracle.sol +48 -0
  344. package/contracts/oracle/BasicOracleAuthorization.sol +46 -0
  345. package/contracts/oracle/IOracle.sol +36 -0
  346. package/contracts/oracle/IOracleComponent.sol +32 -0
  347. package/contracts/oracle/IOracleService.sol +65 -0
  348. package/contracts/oracle/Oracle.sol +157 -0
  349. package/contracts/oracle/OracleService.sol +278 -0
  350. package/contracts/oracle/OracleServiceManager.sol +42 -0
  351. package/contracts/pool/BasicPool.sol +164 -0
  352. package/contracts/pool/BasicPoolAuthorization.sol +49 -0
  353. package/contracts/pool/BundleService.sol +296 -0
  354. package/contracts/pool/BundleServiceManager.sol +42 -0
  355. package/contracts/pool/IBundleService.sol +106 -0
  356. package/contracts/pool/IPoolComponent.sol +52 -0
  357. package/contracts/pool/IPoolService.sol +150 -0
  358. package/contracts/pool/Pool.sol +311 -0
  359. package/contracts/pool/PoolService.sol +452 -0
  360. package/contracts/pool/PoolServiceManager.sol +42 -0
  361. package/contracts/product/ApplicationService.sol +254 -0
  362. package/contracts/{instance/service → product}/ApplicationServiceManager.sol +11 -8
  363. package/contracts/product/BasicProduct.sol +82 -0
  364. package/contracts/product/BasicProductAuthorization.sol +40 -0
  365. package/contracts/product/ClaimService.sol +442 -0
  366. package/contracts/{instance/service → product}/ClaimServiceManager.sol +11 -8
  367. package/contracts/{instance/service → product}/IApplicationService.sol +16 -36
  368. package/contracts/product/IClaimService.sol +99 -0
  369. package/contracts/{instance/service → product}/IPolicyService.sol +37 -48
  370. package/contracts/product/IPricingService.sol +39 -0
  371. package/contracts/product/IProductComponent.sol +39 -0
  372. package/contracts/product/IProductService.sol +33 -0
  373. package/contracts/product/PolicyService.sol +475 -0
  374. package/contracts/product/PolicyServiceManager.sol +42 -0
  375. package/contracts/product/PricingService.sol +300 -0
  376. package/contracts/product/PricingServiceManager.sol +42 -0
  377. package/contracts/product/Product.sol +392 -0
  378. package/contracts/product/ProductService.sol +124 -0
  379. package/contracts/product/ProductServiceManager.sol +42 -0
  380. package/contracts/registry/ChainNft.sol +16 -1
  381. package/contracts/registry/IRegistry.sol +43 -21
  382. package/contracts/registry/IRegistryService.sol +39 -37
  383. package/contracts/registry/ITransferInterceptor.sol +1 -0
  384. package/contracts/registry/Registry.sol +211 -97
  385. package/contracts/registry/RegistryAdmin.sol +365 -0
  386. package/contracts/registry/RegistryService.sol +73 -90
  387. package/contracts/registry/RegistryServiceManager.sol +21 -30
  388. package/contracts/registry/ReleaseLifecycle.sol +27 -0
  389. package/contracts/registry/ReleaseManager.sol +356 -191
  390. package/contracts/registry/ServiceAuthorizationV3.sol +200 -0
  391. package/contracts/registry/TokenRegistry.sol +261 -62
  392. package/contracts/shared/Component.sol +281 -0
  393. package/contracts/shared/ComponentService.sol +581 -0
  394. package/contracts/shared/ComponentServiceManager.sol +35 -0
  395. package/contracts/shared/ComponentVerifyingService.sol +117 -0
  396. package/contracts/shared/ERC165.sol +1 -1
  397. package/contracts/shared/IComponent.sol +70 -0
  398. package/contracts/shared/IComponentService.sol +102 -0
  399. package/contracts/shared/IInstanceLinkedComponent.sol +50 -0
  400. package/contracts/{instance/base → shared}/IKeyValueStore.sol +16 -11
  401. package/contracts/{instance/base → shared}/ILifecycle.sol +3 -4
  402. package/contracts/shared/INftOwnable.sol +2 -2
  403. package/contracts/shared/IPolicyHolder.sol +29 -10
  404. package/contracts/shared/IRegistryLinked.sol +0 -1
  405. package/contracts/shared/IService.sol +14 -7
  406. package/contracts/shared/IVersionable.sol +1 -1
  407. package/contracts/shared/InitializableCustom.sol +177 -0
  408. package/contracts/shared/InstanceLinkedComponent.sol +151 -0
  409. package/contracts/shared/KeyValueStore.sol +131 -0
  410. package/contracts/shared/Lifecycle.sol +77 -0
  411. package/contracts/shared/NftIdSetManager.sol +65 -0
  412. package/contracts/shared/NftOwnable.sol +3 -16
  413. package/contracts/shared/PolicyHolder.sol +40 -19
  414. package/contracts/shared/ProxyManager.sol +34 -4
  415. package/contracts/shared/Registerable.sol +15 -14
  416. package/contracts/shared/RegistryLinked.sol +0 -5
  417. package/contracts/shared/Service.sol +47 -22
  418. package/contracts/shared/TokenHandler.sol +37 -6
  419. package/contracts/shared/Versionable.sol +1 -1
  420. package/contracts/staking/IStaking.sol +168 -0
  421. package/contracts/staking/IStakingService.sol +153 -0
  422. package/contracts/staking/StakeManagerLib.sol +231 -0
  423. package/contracts/staking/Staking.sol +513 -0
  424. package/contracts/staking/StakingLifecycle.sol +23 -0
  425. package/contracts/staking/StakingManager.sol +54 -0
  426. package/contracts/staking/StakingReader.sol +187 -0
  427. package/contracts/staking/StakingService.sol +411 -0
  428. package/contracts/staking/StakingServiceManager.sol +44 -0
  429. package/contracts/staking/StakingStore.sol +615 -0
  430. package/contracts/staking/TargetManagerLib.sol +207 -0
  431. package/contracts/{types → type}/AddressSet.sol +1 -1
  432. package/contracts/type/Amount.sol +128 -0
  433. package/contracts/{types → type}/Blocknumber.sol +21 -3
  434. package/contracts/{types → type}/ClaimId.sol +25 -2
  435. package/contracts/{types → type}/Fee.sol +33 -23
  436. package/contracts/{types → type}/NftId.sol +21 -15
  437. package/contracts/{types → type}/NftIdSet.sol +2 -2
  438. package/contracts/type/ObjectType.sol +275 -0
  439. package/contracts/{types → type}/PayoutId.sol +33 -5
  440. package/contracts/{types → type}/Referral.sol +5 -1
  441. package/contracts/type/RequestId.sol +75 -0
  442. package/contracts/{types → type}/RiskId.sol +1 -1
  443. package/contracts/type/RoleId.sol +174 -0
  444. package/contracts/type/Seconds.sol +81 -0
  445. package/contracts/type/Selector.sol +102 -0
  446. package/contracts/{types → type}/StateId.sol +34 -4
  447. package/contracts/type/String.sol +53 -0
  448. package/contracts/{types → type}/Timestamp.sol +23 -14
  449. package/contracts/{types → type}/UFixed.sol +7 -0
  450. package/contracts/{types → type}/Version.sol +2 -1
  451. package/package.json +6 -3
  452. package/artifacts/contracts/components/Component.sol/Component.dbg.json +0 -4
  453. package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +0 -4
  454. package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +0 -4
  455. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +0 -4
  456. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +0 -4
  457. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +0 -4
  458. package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +0 -4
  459. package/artifacts/contracts/components/Product.sol/Product.dbg.json +0 -4
  460. package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +0 -4
  461. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +0 -4
  462. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +0 -984
  463. package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +0 -4
  464. package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +0 -261
  465. package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.dbg.json +0 -4
  466. package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +0 -4
  467. package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +0 -4
  468. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +0 -4
  469. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +0 -502
  470. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +0 -4
  471. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +0 -169
  472. package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +0 -4
  473. package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +0 -4
  474. package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.dbg.json +0 -4
  475. package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.json +0 -869
  476. package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +0 -4
  477. package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.json +0 -657
  478. package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +0 -4
  479. package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +0 -1096
  480. package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +0 -4
  481. package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +0 -661
  482. package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.dbg.json +0 -4
  483. package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.json +0 -754
  484. package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +0 -4
  485. package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.json +0 -637
  486. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +0 -4
  487. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +0 -1254
  488. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +0 -4
  489. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +0 -753
  490. package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.dbg.json +0 -4
  491. package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +0 -4
  492. package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.dbg.json +0 -4
  493. package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.json +0 -409
  494. package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +0 -4
  495. package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +0 -4
  496. package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +0 -4
  497. package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +0 -347
  498. package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +0 -4
  499. package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +0 -4
  500. package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +0 -1120
  501. package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +0 -4
  502. package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +0 -717
  503. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +0 -4
  504. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +0 -727
  505. package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +0 -4
  506. package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +0 -649
  507. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +0 -4
  508. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +0 -777
  509. package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
  510. package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +0 -649
  511. package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +0 -4
  512. package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +0 -285
  513. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +0 -4
  514. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +0 -107
  515. package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +0 -4
  516. package/artifacts/contracts/test/TestFee.sol/TestFee.json +0 -119
  517. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +0 -4
  518. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +0 -383
  519. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +0 -4
  520. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +0 -116
  521. package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +0 -4
  522. package/artifacts/contracts/test/TestService.sol/TestService.json +0 -521
  523. package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +0 -4
  524. package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +0 -376
  525. package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +0 -4
  526. package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +0 -218
  527. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +0 -4
  528. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +0 -104
  529. package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +0 -4
  530. package/artifacts/contracts/test/Usdc.sol/USDC.json +0 -376
  531. package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +0 -4
  532. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +0 -4
  533. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +0 -174
  534. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +0 -4
  535. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +0 -10
  536. package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.dbg.json +0 -4
  537. package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.json +0 -100
  538. package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +0 -4
  539. package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +0 -4
  540. package/artifacts/contracts/types/Fee.sol/FeeLib.json +0 -257
  541. package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +0 -4
  542. package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +0 -4
  543. package/artifacts/contracts/types/NftId.sol/NftIdLib.json +0 -153
  544. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +0 -4
  545. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +0 -4
  546. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.json +0 -100
  547. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +0 -4
  548. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +0 -92
  549. package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.dbg.json +0 -4
  550. package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.json +0 -100
  551. package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +0 -4
  552. package/artifacts/contracts/types/Referral.sol/ReferralLib.json +0 -123
  553. package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +0 -4
  554. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +0 -4
  555. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +0 -156
  556. package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +0 -4
  557. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +0 -4
  558. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +0 -249
  559. package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +0 -4
  560. package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +0 -4
  561. package/artifacts/contracts/types/UFixed.sol/UFixedLib.json +0 -479
  562. package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +0 -4
  563. package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +0 -4
  564. package/contracts/components/Component.sol +0 -241
  565. package/contracts/components/IComponent.sol +0 -54
  566. package/contracts/components/IDistributionComponent.sol +0 -92
  567. package/contracts/components/IPoolComponent.sol +0 -87
  568. package/contracts/components/IProductComponent.sol +0 -39
  569. package/contracts/components/Pool.sol +0 -254
  570. package/contracts/components/Product.sol +0 -285
  571. package/contracts/instance/InstanceAccessManager.sol +0 -297
  572. package/contracts/instance/base/ComponentService.sol +0 -134
  573. package/contracts/instance/base/KeyValueStore.sol +0 -172
  574. package/contracts/instance/base/Lifecycle.sol +0 -100
  575. package/contracts/instance/module/ITreasury.sol +0 -23
  576. package/contracts/instance/service/ApplicationService.sol +0 -268
  577. package/contracts/instance/service/BundleService.sol +0 -298
  578. package/contracts/instance/service/BundleServiceManager.sol +0 -51
  579. package/contracts/instance/service/ClaimService.sol +0 -151
  580. package/contracts/instance/service/DistributionService.sol +0 -366
  581. package/contracts/instance/service/DistributionServiceManager.sol +0 -51
  582. package/contracts/instance/service/IBundleService.sol +0 -54
  583. package/contracts/instance/service/IClaimService.sol +0 -61
  584. package/contracts/instance/service/IPoolService.sol +0 -20
  585. package/contracts/instance/service/IProductService.sol +0 -40
  586. package/contracts/instance/service/PolicyService.sol +0 -476
  587. package/contracts/instance/service/PolicyServiceManager.sol +0 -54
  588. package/contracts/instance/service/PoolService.sol +0 -109
  589. package/contracts/instance/service/PoolServiceManager.sol +0 -51
  590. package/contracts/instance/service/ProductService.sol +0 -233
  591. package/contracts/instance/service/ProductServiceManager.sol +0 -54
  592. package/contracts/registry/RegistryAccessManager.sol +0 -216
  593. package/contracts/shared/ContractDeployerLib.sol +0 -72
  594. package/contracts/test/TestFee.sol +0 -25
  595. package/contracts/test/TestRegisterable.sol +0 -18
  596. package/contracts/test/TestRoleId.sol +0 -14
  597. package/contracts/test/TestService.sol +0 -25
  598. package/contracts/test/TestVersion.sol +0 -44
  599. package/contracts/test/TestVersionable.sol +0 -17
  600. package/contracts/test/Usdc.sol +0 -26
  601. package/contracts/types/ChainId.sol +0 -38
  602. package/contracts/types/NumberId.sol +0 -52
  603. package/contracts/types/ObjectType.sol +0 -156
  604. package/contracts/types/RoleId.sol +0 -90
  605. /package/contracts/{types → type}/DistributorType.sol +0 -0
  606. /package/contracts/{types → type}/Key32.sol +0 -0
@@ -0,0 +1,365 @@
1
+ // SPDX-License-Identifier: UNLICENSED
2
+ pragma solidity ^0.8.20;
3
+
4
+ import {AccessAdmin} from "../authorization/AccessAdmin.sol";
5
+ import {IAccess} from "../authorization/IAccess.sol";
6
+ import {IRegistry} from "./IRegistry.sol";
7
+ import {IService} from "../shared/IService.sol";
8
+ import {IServiceAuthorization} from "../authorization/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 POOL_SERVICE_ROLE_NAME = "PoolServiceRole";
42
+ string public constant RELEASE_MANAGER_ROLE_NAME = "ReleaseManagerRole";
43
+ string public constant STAKING_SERVICE_ROLE_NAME = "StakingServiceRole";
44
+ string public constant STAKING_ROLE_NAME = "StakingRole";
45
+
46
+ string public constant RELEASE_MANAGER_TARGET_NAME = "ReleaseManager";
47
+ string public constant TOKEN_REGISTRY_TARGET_NAME = "TokenRegistry";
48
+ string public constant STAKING_TARGET_NAME = "Staking";
49
+ string public constant STAKING_STORE_TARGET_NAME = "StakingStore";
50
+
51
+ uint8 public constant MAX_NUM_RELEASES = 99;
52
+
53
+ mapping(address service => VersionPart majorVersion) private _ServiceRelease;
54
+
55
+ address private _releaseManager;
56
+ address private _tokenRegistry;
57
+ address private _staking;
58
+ address private _stakingStore;
59
+ bool private _setupCompleted;
60
+
61
+ constructor() AccessAdmin() { }
62
+
63
+ function completeSetup(
64
+ IRegistry registry,
65
+ address gifAdmin,
66
+ address gifManager
67
+ )
68
+ external
69
+ onlyDeployer()
70
+ {
71
+ if (_setupCompleted) { revert ErrorRegistryAdminIsAlreadySetUp(); }
72
+ else { _setupCompleted = true; }
73
+
74
+ _releaseManager = registry.getReleaseManagerAddress();
75
+ _tokenRegistry = registry.getTokenRegistryAddress();
76
+ _staking = registry.getStakingAddress();
77
+ _stakingStore = address(
78
+ IStaking(_staking).getStakingStore());
79
+
80
+ // at this moment all registry contracts are deployed and fully intialized
81
+ _createTarget(_tokenRegistry, TOKEN_REGISTRY_TARGET_NAME, true, false);
82
+
83
+ _setupGifAdminRole(gifAdmin);
84
+ _setupGifManagerRole(gifManager);
85
+
86
+ _setupReleaseManager();
87
+ _setupStaking();
88
+ }
89
+
90
+
91
+ /// @dev Sets up authorizaion for specified service.
92
+ /// For all authorized services its authorized functions are enabled.
93
+ /// Permissioned function: Access is restricted to release manager.
94
+ function authorizeService(
95
+ IServiceAuthorization serviceAuthorization,
96
+ IService service
97
+ )
98
+ external
99
+ restricted()
100
+ {
101
+ _createServiceTargetAndRole(service);
102
+ _authorizeServiceFunctions(serviceAuthorization, service);
103
+ }
104
+
105
+
106
+ function grantServiceRoleForAllVersions(IService service, ObjectType domain)
107
+ external
108
+ restricted()
109
+ {
110
+ _grantRoleToAccount(
111
+ RoleIdLib.roleForTypeAndAllVersions(domain),
112
+ address(service));
113
+ }
114
+
115
+
116
+ function _createServiceTargetAndRole(IService service)
117
+ private
118
+ {
119
+ ObjectType serviceDomain = service.getDomain();
120
+ string memory baseName = ObjectTypeLib.toName(serviceDomain);
121
+ VersionPart version = service.getVersion().toMajorPart();
122
+ uint256 versionInt = version.toInt();
123
+
124
+ // create service target
125
+ string memory serviceTargetName = ObjectTypeLib.toVersionedName(
126
+ baseName, "Service", versionInt);
127
+
128
+ _createTarget(
129
+ address(service),
130
+ serviceTargetName,
131
+ true,
132
+ false);
133
+
134
+ // create service role
135
+ RoleId serviceRoleId = RoleIdLib.roleForTypeAndVersion(
136
+ serviceDomain,
137
+ version);
138
+
139
+ _createRole(
140
+ serviceRoleId,
141
+ toRole({
142
+ adminRoleId: ADMIN_ROLE(),
143
+ roleType: RoleType.Contract,
144
+ maxMemberCount: 1,
145
+ name: ObjectTypeLib.toVersionedName(
146
+ baseName,
147
+ "ServiceRole",
148
+ versionInt)}));
149
+
150
+ _grantRoleToAccount(
151
+ serviceRoleId,
152
+ address(service));
153
+ }
154
+
155
+
156
+ function _authorizeServiceFunctions(
157
+ IServiceAuthorization serviceAuthorization,
158
+ IService service
159
+ )
160
+ private
161
+ {
162
+ ObjectType serviceDomain = service.getDomain();
163
+ ObjectType authorizedDomain;
164
+ RoleId authorizedRoleId;
165
+
166
+ VersionPart release = service.getVersion().toMajorPart();
167
+ ObjectType[] memory authorizedDomains = serviceAuthorization.getAuthorizedDomains(serviceDomain);
168
+
169
+ for (uint256 i = 0; i < authorizedDomains.length; i++) {
170
+ authorizedDomain = authorizedDomains[i];
171
+
172
+ // derive authorized role from authorized domain
173
+ if (authorizedDomain == ALL()) {
174
+ authorizedRoleId = PUBLIC_ROLE();
175
+ } else {
176
+ authorizedRoleId = RoleIdLib.roleForTypeAndVersion(
177
+ authorizedDomain,
178
+ release);
179
+ }
180
+
181
+ // get authorized functions for authorized domain
182
+ IAccess.FunctionInfo[] memory authorizatedFunctions = serviceAuthorization.getAuthorizedFunctions(
183
+ serviceDomain,
184
+ authorizedDomain);
185
+
186
+ _authorizeTargetFunctions(
187
+ address(service),
188
+ authorizedRoleId,
189
+ authorizatedFunctions);
190
+ }
191
+ }
192
+
193
+ /*function transferAdmin(address to)
194
+ external
195
+ restricted // only with GIF_ADMIN_ROLE or nft owner
196
+ {
197
+ _accessManager.revoke(GIF_ADMIN_ROLE, );
198
+ _accesssManager.grant(GIF_ADMIN_ROLE, to, 0);
199
+ }*/
200
+
201
+ //--- view functions ----------------------------------------------------//
202
+
203
+ function getGifAdminRole() external view returns (RoleId) {
204
+ return GIF_ADMIN_ROLE();
205
+ }
206
+
207
+ function getGifManagerRole() external view returns (RoleId) {
208
+ return GIF_MANAGER_ROLE();
209
+ }
210
+
211
+ //--- private functions -------------------------------------------------//
212
+
213
+ function _setupGifAdminRole(address gifAdmin) private {
214
+
215
+ _createRole(
216
+ GIF_ADMIN_ROLE(),
217
+ toRole({
218
+ adminRoleId: ADMIN_ROLE(),
219
+ roleType: RoleType.Gif,
220
+ maxMemberCount: 2, // TODO decide on max member count
221
+ name: GIF_ADMIN_ROLE_NAME}));
222
+
223
+ // for ReleaseManager
224
+ FunctionInfo[] memory functions;
225
+ functions = new FunctionInfo[](4);
226
+ functions[0] = toFunction(ReleaseManager.createNextRelease.selector, "createNextRelease");
227
+ functions[1] = toFunction(ReleaseManager.activateNextRelease.selector, "activateNextRelease");
228
+ functions[2] = toFunction(ReleaseManager.pauseRelease.selector, "pauseRelease");
229
+ functions[3] = toFunction(ReleaseManager.unpauseRelease.selector, "unpauseRelease");
230
+ _authorizeTargetFunctions(_releaseManager, GIF_ADMIN_ROLE(), functions);
231
+
232
+ _grantRoleToAccount(GIF_ADMIN_ROLE(), gifAdmin);
233
+ }
234
+
235
+ function _setupGifManagerRole(address gifManager) private {
236
+
237
+ _createRole(
238
+ GIF_MANAGER_ROLE(),
239
+ toRole({
240
+ adminRoleId: ADMIN_ROLE(),
241
+ roleType: RoleType.Gif,
242
+ maxMemberCount: 1,
243
+ name: GIF_MANAGER_ROLE_NAME}));
244
+
245
+ // for TokenRegistry
246
+ FunctionInfo[] memory functions;
247
+ functions = new FunctionInfo[](5);
248
+ functions[0] = toFunction(TokenRegistry.registerToken.selector, "registerToken");
249
+ functions[1] = toFunction(TokenRegistry.registerRemoteToken.selector, "registerRemoteToken");
250
+ functions[2] = toFunction(TokenRegistry.setActive.selector, "setActive");
251
+ functions[3] = toFunction(TokenRegistry.setActiveForVersion.selector, "setActiveForVersion");
252
+ // TODO find a better way (only needed for testing)
253
+ functions[4] = toFunction(TokenRegistry.setActiveWithVersionCheck.selector, "setActiveWithVersionCheck");
254
+ _authorizeTargetFunctions(_tokenRegistry, GIF_MANAGER_ROLE(), functions);
255
+
256
+ // for ReleaseManager
257
+ functions = new FunctionInfo[](2);
258
+ functions[0] = toFunction(ReleaseManager.prepareNextRelease.selector, "prepareNextRelease");
259
+ functions[1] = toFunction(ReleaseManager.registerService.selector, "registerService");
260
+ _authorizeTargetFunctions(_releaseManager, GIF_MANAGER_ROLE(), functions);
261
+
262
+ _grantRoleToAccount(GIF_MANAGER_ROLE(), gifManager);
263
+ }
264
+
265
+
266
+ function _setupReleaseManager() private {
267
+
268
+ _createTarget(_releaseManager, RELEASE_MANAGER_TARGET_NAME, true, false);
269
+
270
+ RoleId releaseManagerRoleId = RoleIdLib.roleForType(RELEASE());
271
+ _createRole(
272
+ releaseManagerRoleId,
273
+ toRole({
274
+ adminRoleId: ADMIN_ROLE(),
275
+ roleType: RoleType.Contract,
276
+ maxMemberCount: 1,
277
+ name: RELEASE_MANAGER_ROLE_NAME}));
278
+
279
+ FunctionInfo[] memory functions;
280
+ functions = new FunctionInfo[](2);
281
+ functions[0] = toFunction(RegistryAdmin.authorizeService.selector, "authorizeService");
282
+ functions[1] = toFunction(RegistryAdmin.grantServiceRoleForAllVersions.selector, "grantServiceRoleForAllVersions");
283
+ _authorizeTargetFunctions(address(this), releaseManagerRoleId, functions);
284
+
285
+ _grantRoleToAccount(releaseManagerRoleId, _releaseManager);
286
+ }
287
+
288
+
289
+ function _setupStaking() private {
290
+ _createTarget(_staking, STAKING_TARGET_NAME, true, false);
291
+ _createTarget(_stakingStore, STAKING_STORE_TARGET_NAME, true, false);
292
+
293
+ // staking function authorization for staking service
294
+ RoleId stakingServiceRoleId = RoleIdLib.roleForTypeAndAllVersions(STAKING());
295
+ _createRole(
296
+ stakingServiceRoleId,
297
+ toRole({
298
+ adminRoleId: ADMIN_ROLE(),
299
+ roleType: RoleType.Contract,
300
+ maxMemberCount: MAX_NUM_RELEASES,
301
+ name: STAKING_SERVICE_ROLE_NAME}));
302
+
303
+ FunctionInfo[] memory functions;
304
+ functions = new FunctionInfo[](13);
305
+ functions[0] = toFunction(IStaking.registerTarget.selector, "registerTarget");
306
+ functions[1] = toFunction(IStaking.setLockingPeriod.selector, "setLockingPeriod");
307
+ functions[2] = toFunction(IStaking.setRewardRate.selector, "setRewardRate");
308
+ functions[3] = toFunction(IStaking.refillRewardReserves.selector, "refillRewardReserves");
309
+ functions[4] = toFunction(IStaking.withdrawRewardReserves.selector, "withdrawRewardReserves");
310
+ functions[5] = toFunction(IStaking.createStake.selector, "createStake");
311
+ functions[6] = toFunction(IStaking.stake.selector, "stake");
312
+ functions[7] = toFunction(IStaking.unstake.selector, "unstake");
313
+ functions[8] = toFunction(IStaking.restake.selector, "restake");
314
+ functions[9] = toFunction(IStaking.updateRewards.selector, "updateRewards");
315
+ functions[10] = toFunction(IStaking.claimRewards.selector, "claimRewards");
316
+ functions[11] = toFunction(IStaking.collectDipAmount.selector, "collectDipAmount");
317
+ functions[12] = toFunction(IStaking.transferDipAmount.selector, "transferDipAmount");
318
+ _authorizeTargetFunctions(_staking, stakingServiceRoleId, functions);
319
+
320
+ // staking function authorization for pool service
321
+ RoleId poolServiceRoleId = RoleIdLib.roleForTypeAndAllVersions(POOL());
322
+ _createRole(
323
+ poolServiceRoleId,
324
+ toRole({
325
+ adminRoleId: ADMIN_ROLE(),
326
+ roleType: RoleType.Contract,
327
+ maxMemberCount: MAX_NUM_RELEASES,
328
+ name: POOL_SERVICE_ROLE_NAME}));
329
+
330
+ // staking function authorizations
331
+ functions = new FunctionInfo[](2);
332
+ functions[0] = toFunction(IStaking.increaseTotalValueLocked.selector, "increaseTotalValueLocked");
333
+ functions[1] = toFunction(IStaking.decreaseTotalValueLocked.selector, "decreaseTotalValueLocked");
334
+ _authorizeTargetFunctions(_staking, poolServiceRoleId, functions);
335
+
336
+ // staking store function authorizations
337
+ RoleId stakingRoleId = RoleIdLib.roleForType(STAKING());
338
+ _createRole(
339
+ stakingRoleId,
340
+ toRole({
341
+ adminRoleId: ADMIN_ROLE(),
342
+ roleType: RoleType.Contract,
343
+ maxMemberCount: 1,
344
+ name: STAKING_ROLE_NAME}));
345
+
346
+ functions = new FunctionInfo[](14);
347
+ functions[0] = toFunction(StakingStore.setStakingRate.selector, "setStakingRate");
348
+ functions[1] = toFunction(StakingStore.createTarget.selector, "createTarget");
349
+ functions[2] = toFunction(StakingStore.updateTarget.selector, "updateTarget");
350
+ functions[3] = toFunction(StakingStore.increaseReserves.selector, "increaseReserves");
351
+ functions[4] = toFunction(StakingStore.decreaseReserves.selector, "decreaseReserves");
352
+ functions[5] = toFunction(StakingStore.increaseTotalValueLocked.selector, "increaseTotalValueLocked");
353
+ functions[6] = toFunction(StakingStore.decreaseTotalValueLocked.selector, "decreaseTotalValueLocked");
354
+ functions[7] = toFunction(StakingStore.create.selector, "create");
355
+ functions[8] = toFunction(StakingStore.update.selector, "update");
356
+ functions[9] = toFunction(StakingStore.increaseStake.selector, "increaseStake");
357
+ functions[10] = toFunction(StakingStore.restakeRewards.selector, "restakeRewards");
358
+ functions[11] = toFunction(StakingStore.updateRewards.selector, "updateRewards");
359
+ functions[12] = toFunction(StakingStore.claimUpTo.selector, "claimUpTo");
360
+ functions[13] = toFunction(StakingStore.unstakeUpTo.selector, "unstakeUpTo");
361
+ _authorizeTargetFunctions(_stakingStore, stakingRoleId, functions);
362
+
363
+ _grantRoleToAccount(stakingRoleId, _staking);
364
+ }
365
+ }
@@ -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 = APPLICATION();
188
- config[0].selectors = new bytes4[](1);
189
- config[0].selectors[0] = RegistryService.registerPolicy.selector;
190
-
191
- config[1].serviceDomain = POLICY();
192
- config[1].selectors = new bytes4[](0);
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
+ }