@etherisc/gif-next 0.0.2-b7cfc95-746 → 0.0.2-b7f4834-822

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 (610) hide show
  1. package/README.md +10 -14
  2. package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +4 -0
  3. package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +1416 -0
  4. package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +4 -0
  5. package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +1349 -0
  6. package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
  7. package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +818 -0
  8. package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +4 -0
  9. package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +975 -0
  10. package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +4 -0
  11. package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +814 -0
  12. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
  13. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +73 -83
  14. package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
  15. package/artifacts/contracts/instance/IInstance.sol/IInstance.json +279 -1408
  16. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
  17. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +296 -216
  18. package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
  19. package/artifacts/contracts/instance/Instance.sol/Instance.json +463 -2500
  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 +630 -351
  26. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
  27. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +457 -367
  28. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
  29. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +368 -94
  30. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +4 -0
  31. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +3642 -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 +6 -1
  36. package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +4 -0
  37. package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +10 -0
  38. package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +4 -0
  39. package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +256 -0
  40. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
  41. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +25 -150
  42. package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
  43. package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +4 -0
  44. package/artifacts/contracts/instance/module/{ITreasury.sol/ITreasury.json → IComponents.sol/IComponents.json} +2 -2
  45. package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
  46. package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
  47. package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
  48. package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +4 -0
  49. package/artifacts/contracts/mock/Dip.sol/Dip.json +376 -0
  50. package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +4 -0
  51. package/artifacts/contracts/{instance/module/ISetup.sol/ISetup.json → oracle/IOracle.sol/IOracle.json} +2 -2
  52. package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +4 -0
  53. package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +759 -0
  54. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +4 -0
  55. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +662 -0
  56. package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +4 -0
  57. package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +1146 -0
  58. package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +4 -0
  59. package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +997 -0
  60. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +4 -0
  61. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +718 -0
  62. package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +4 -0
  63. package/artifacts/contracts/pool/BundleService.sol/BundleService.json +1105 -0
  64. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
  65. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +746 -0
  66. package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +4 -0
  67. package/artifacts/contracts/{instance/service → pool}/IBundleService.sol/IBundleService.json +260 -290
  68. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
  69. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +1154 -0
  70. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +4 -0
  71. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +1065 -0
  72. package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +4 -0
  73. package/artifacts/contracts/pool/Pool.sol/Pool.json +1565 -0
  74. package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +4 -0
  75. package/artifacts/contracts/pool/PoolService.sol/PoolService.json +1432 -0
  76. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
  77. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +738 -0
  78. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +4 -0
  79. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +834 -0
  80. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
  81. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +722 -0
  82. package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +4 -0
  83. package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +1278 -0
  84. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
  85. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +810 -0
  86. package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +4 -0
  87. package/artifacts/contracts/{instance/service/IProductService.sol/IProductService.json → product/IApplicationService.sol/IApplicationService.json} +203 -240
  88. package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +4 -0
  89. package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +759 -0
  90. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +4 -0
  91. package/artifacts/contracts/{instance/service → product}/IPolicyService.sol/IPolicyService.json +244 -308
  92. package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +4 -0
  93. package/artifacts/contracts/{instance/service/IPoolService.sol/IPoolService.json → product/IPricingService.sol/IPricingService.json} +263 -226
  94. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +4 -0
  95. package/artifacts/contracts/{components/Product.sol/Product.json → product/IProductComponent.sol/IProductComponent.json} +433 -229
  96. package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +4 -0
  97. package/artifacts/contracts/{components/IComponent.sol/IComponent.json → product/IProductService.sol/IProductService.json} +124 -150
  98. package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +4 -0
  99. package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +1146 -0
  100. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
  101. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +754 -0
  102. package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +4 -0
  103. package/artifacts/contracts/product/PricingService.sol/PricingService.json +983 -0
  104. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +4 -0
  105. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +778 -0
  106. package/artifacts/contracts/product/Product.sol/Product.dbg.json +4 -0
  107. package/artifacts/contracts/product/Product.sol/Product.json +1397 -0
  108. package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +4 -0
  109. package/artifacts/contracts/product/ProductService.sol/ProductService.json +679 -0
  110. package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +4 -0
  111. package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +694 -0
  112. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
  113. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +15 -2
  114. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
  115. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +203 -21
  116. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
  117. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +352 -218
  118. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
  119. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +18 -0
  120. package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
  121. package/artifacts/contracts/registry/Registry.sol/Registry.json +440 -36
  122. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +4 -0
  123. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +407 -0
  124. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
  125. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +505 -285
  126. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
  127. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +340 -82
  128. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
  129. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +834 -89
  130. package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.dbg.json +4 -0
  131. package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.json +137 -0
  132. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
  133. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +360 -80
  134. package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.dbg.json +4 -0
  135. package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.json +1193 -0
  136. package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.dbg.json +4 -0
  137. package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.json +1715 -0
  138. package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.dbg.json +4 -0
  139. package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.json +1728 -0
  140. package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.dbg.json +4 -0
  141. package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.json +1806 -0
  142. package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.dbg.json +4 -0
  143. package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.json +1824 -0
  144. package/artifacts/contracts/shared/Component.sol/Component.dbg.json +4 -0
  145. package/artifacts/contracts/{components/Pool.sol/Pool.json → shared/Component.sol/Component.json} +424 -386
  146. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +4 -0
  147. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +1490 -0
  148. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +4 -0
  149. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +792 -0
  150. package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +4 -0
  151. package/artifacts/contracts/{components/Component.sol/Component.json → shared/ComponentVerifyingService.sol/ComponentVerifyingService.json} +207 -179
  152. package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
  153. package/artifacts/contracts/shared/ERC165.sol/ERC165.json +41 -3
  154. package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.dbg.json +4 -0
  155. package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.json +1562 -0
  156. package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.dbg.json +4 -0
  157. package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.json +1600 -0
  158. package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +4 -0
  159. package/artifacts/contracts/{instance/base/ComponentService.sol/ComponentService.json → shared/IComponent.sol/IComponent.json} +265 -229
  160. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +4 -0
  161. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +867 -0
  162. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +4 -0
  163. package/artifacts/contracts/{components/Distribution.sol/Distribution.json → shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json} +235 -221
  164. package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
  165. package/artifacts/contracts/{instance/IInstanceBase.sol/IInstanceBase.json → shared/IKeyValueStore.sol/IKeyValueStore.json} +51 -31
  166. package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +4 -0
  167. package/artifacts/contracts/{instance/base → shared}/ILifecycle.sol/ILifecycle.json +1 -1
  168. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
  169. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +34 -30
  170. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +4 -0
  171. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +207 -0
  172. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
  173. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +15 -35
  174. package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +4 -0
  175. package/artifacts/contracts/{experiment/inheritance/IA.sol/ISharedA.json → shared/IRegistryLinked.sol/IRegistryLinked.json} +15 -17
  176. package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
  177. package/artifacts/contracts/shared/IService.sol/IService.json +75 -163
  178. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
  179. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +2 -152
  180. package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.dbg.json +4 -0
  181. package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.json +39 -0
  182. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +4 -0
  183. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +1036 -0
  184. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +4 -0
  185. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +571 -0
  186. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +4 -0
  187. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +194 -0
  188. package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.dbg.json +4 -0
  189. package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.json +306 -0
  190. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
  191. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +115 -29
  192. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +4 -0
  193. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +320 -0
  194. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
  195. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +330 -62
  196. package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
  197. package/artifacts/contracts/shared/Registerable.sol/Registerable.json +132 -53
  198. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +4 -0
  199. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +71 -0
  200. package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
  201. package/artifacts/contracts/shared/Service.sol/Service.json +179 -153
  202. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
  203. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +60 -6
  204. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
  205. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +2 -2
  206. package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
  207. package/artifacts/contracts/shared/Versionable.sol/Versionable.json +2 -152
  208. package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +4 -0
  209. package/artifacts/contracts/staking/IStaking.sol/IStaking.json +1438 -0
  210. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +4 -0
  211. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +993 -0
  212. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +4 -0
  213. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +444 -0
  214. package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +4 -0
  215. package/artifacts/contracts/staking/Staking.sol/Staking.json +2045 -0
  216. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +4 -0
  217. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +777 -0
  218. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +4 -0
  219. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +592 -0
  220. package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +4 -0
  221. package/artifacts/contracts/staking/StakingService.sol/StakingService.json +1324 -0
  222. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +4 -0
  223. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +726 -0
  224. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +4 -0
  225. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +2189 -0
  226. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +4 -0
  227. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +571 -0
  228. package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +4 -0
  229. package/artifacts/contracts/{types → type}/AddressSet.sol/LibAddressSet.json +3 -3
  230. package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +4 -0
  231. package/artifacts/contracts/type/Amount.sol/AmountLib.json +345 -0
  232. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +4 -0
  233. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +225 -0
  234. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
  235. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +179 -0
  236. package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +4 -0
  237. package/artifacts/contracts/{types → type}/DistributorType.sol/DistributorTypeLib.json +5 -5
  238. package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +4 -0
  239. package/artifacts/contracts/type/Fee.sol/FeeLib.json +312 -0
  240. package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +4 -0
  241. package/artifacts/contracts/{types → type}/Key32.sol/Key32Lib.json +3 -3
  242. package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +4 -0
  243. package/artifacts/contracts/type/NftId.sol/NftIdLib.json +209 -0
  244. package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +4 -0
  245. package/artifacts/contracts/{types → type}/NftIdSet.sol/LibNftIdSet.json +3 -3
  246. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +4 -0
  247. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +105 -0
  248. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
  249. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +209 -0
  250. package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +4 -0
  251. package/artifacts/contracts/type/Referral.sol/ReferralLib.json +142 -0
  252. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +4 -0
  253. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +204 -0
  254. package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +4 -0
  255. package/artifacts/contracts/{types → type}/RiskId.sol/RiskIdLib.json +5 -5
  256. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +4 -0
  257. package/artifacts/contracts/{types → type}/RoleId.sol/RoleIdLib.json +5 -5
  258. package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +4 -0
  259. package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +198 -0
  260. package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +4 -0
  261. package/artifacts/contracts/{types → type}/StateId.sol/StateIdLib.json +3 -3
  262. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +4 -0
  263. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +293 -0
  264. package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +4 -0
  265. package/artifacts/contracts/{types → type}/UFixed.sol/MathLib.json +3 -3
  266. package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +4 -0
  267. package/artifacts/contracts/{types → type}/UFixed.sol/UFixedLib.json +3 -3
  268. package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +4 -0
  269. package/artifacts/contracts/{types → type}/Version.sol/VersionLib.json +3 -3
  270. package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +4 -0
  271. package/artifacts/contracts/{types → type}/Version.sol/VersionPartLib.json +3 -3
  272. package/contracts/distribution/Distribution.sol +261 -0
  273. package/contracts/distribution/DistributionService.sol +298 -0
  274. package/contracts/distribution/DistributionServiceManager.sol +42 -0
  275. package/contracts/distribution/IDistributionComponent.sol +66 -0
  276. package/contracts/distribution/IDistributionService.sol +81 -0
  277. package/contracts/instance/BundleManager.sol +22 -25
  278. package/contracts/instance/IInstance.sol +61 -39
  279. package/contracts/instance/IInstanceService.sol +58 -17
  280. package/contracts/instance/Instance.sol +155 -181
  281. package/contracts/instance/InstanceAdmin.sol +331 -0
  282. package/contracts/instance/InstanceAuthorizationsLib.sol +377 -0
  283. package/contracts/instance/InstanceReader.sol +160 -85
  284. package/contracts/instance/InstanceService.sol +259 -242
  285. package/contracts/instance/InstanceServiceManager.sol +12 -22
  286. package/contracts/instance/InstanceStore.sol +281 -0
  287. package/contracts/instance/base/BalanceStore.sol +118 -0
  288. package/contracts/instance/{Cloneable.sol → base/Cloneable.sol} +8 -3
  289. package/contracts/instance/base/ObjectCounter.sol +21 -0
  290. package/contracts/instance/{ObjectManager.sol → base/ObjectManager.sol} +16 -35
  291. package/contracts/instance/module/IAccess.sol +19 -21
  292. package/contracts/instance/module/IBundle.sol +8 -8
  293. package/contracts/instance/module/IComponents.sol +52 -0
  294. package/contracts/instance/module/IDistribution.sol +7 -4
  295. package/contracts/instance/module/IPolicy.sol +56 -17
  296. package/contracts/instance/module/IRisk.sol +1 -1
  297. package/contracts/{test/Usdc.sol → mock/Dip.sol} +5 -5
  298. package/contracts/oracle/IOracle.sol +20 -0
  299. package/contracts/oracle/IOracleComponent.sol +32 -0
  300. package/contracts/oracle/IOracleService.sol +65 -0
  301. package/contracts/oracle/Oracle.sol +145 -0
  302. package/contracts/oracle/OracleService.sol +277 -0
  303. package/contracts/oracle/OracleServiceManager.sol +42 -0
  304. package/contracts/pool/BundleService.sol +296 -0
  305. package/contracts/pool/BundleServiceManager.sol +42 -0
  306. package/contracts/pool/IBundleService.sol +106 -0
  307. package/contracts/pool/IPoolComponent.sol +112 -0
  308. package/contracts/pool/IPoolService.sol +150 -0
  309. package/contracts/pool/Pool.sol +299 -0
  310. package/contracts/pool/PoolService.sol +453 -0
  311. package/contracts/pool/PoolServiceManager.sol +42 -0
  312. package/contracts/product/ApplicationService.sol +254 -0
  313. package/contracts/product/ApplicationServiceManager.sol +38 -0
  314. package/contracts/product/ClaimService.sol +442 -0
  315. package/contracts/product/ClaimServiceManager.sol +38 -0
  316. package/contracts/product/IApplicationService.sol +62 -0
  317. package/contracts/product/IClaimService.sol +99 -0
  318. package/contracts/product/IPolicyService.sol +78 -0
  319. package/contracts/product/IPricingService.sol +39 -0
  320. package/contracts/product/IProductComponent.sol +42 -0
  321. package/contracts/product/IProductService.sol +33 -0
  322. package/contracts/product/PolicyService.sol +475 -0
  323. package/contracts/product/PolicyServiceManager.sol +42 -0
  324. package/contracts/product/PricingService.sol +301 -0
  325. package/contracts/product/PricingServiceManager.sol +42 -0
  326. package/contracts/product/Product.sol +377 -0
  327. package/contracts/product/ProductService.sol +124 -0
  328. package/contracts/product/ProductServiceManager.sol +42 -0
  329. package/contracts/registry/ChainNft.sol +16 -1
  330. package/contracts/registry/IRegistry.sol +47 -21
  331. package/contracts/registry/IRegistryService.sol +46 -35
  332. package/contracts/registry/ITransferInterceptor.sol +1 -0
  333. package/contracts/registry/Registry.sol +221 -97
  334. package/contracts/registry/RegistryAdmin.sol +237 -0
  335. package/contracts/registry/RegistryService.sol +115 -169
  336. package/contracts/registry/RegistryServiceManager.sol +22 -26
  337. package/contracts/registry/ReleaseManager.sol +459 -211
  338. package/contracts/registry/ServiceAuthorizationsLib.sol +173 -0
  339. package/contracts/registry/TokenRegistry.sol +263 -60
  340. package/contracts/shared/AccessManagerCustom.sol +736 -0
  341. package/contracts/shared/AccessManagerExtended.sol +470 -0
  342. package/contracts/shared/AccessManagerExtendedInitializeable.sol +13 -0
  343. package/contracts/shared/AccessManagerExtendedWithDisable.sol +137 -0
  344. package/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol +14 -0
  345. package/contracts/shared/Component.sol +281 -0
  346. package/contracts/shared/ComponentService.sol +618 -0
  347. package/contracts/shared/ComponentServiceManager.sol +35 -0
  348. package/contracts/shared/ComponentVerifyingService.sol +117 -0
  349. package/contracts/shared/ERC165.sol +15 -13
  350. package/contracts/shared/IAccessManagerExtended.sol +74 -0
  351. package/contracts/shared/IAccessManagerExtendedWithDisable.sol +18 -0
  352. package/contracts/shared/IComponent.sol +70 -0
  353. package/contracts/shared/IComponentService.sol +102 -0
  354. package/contracts/shared/IInstanceLinkedComponent.sol +46 -0
  355. package/contracts/{instance/base → shared}/IKeyValueStore.sol +15 -11
  356. package/contracts/{instance/base → shared}/ILifecycle.sol +3 -3
  357. package/contracts/shared/INftOwnable.sol +13 -12
  358. package/contracts/shared/IPolicyHolder.sol +45 -0
  359. package/contracts/shared/IRegisterable.sol +4 -4
  360. package/contracts/shared/IRegistryLinked.sol +11 -0
  361. package/contracts/shared/IService.sol +7 -5
  362. package/contracts/shared/IVersionable.sol +5 -48
  363. package/contracts/shared/InitializableCustom.sol +177 -0
  364. package/contracts/shared/InstanceLinkedComponent.sol +144 -0
  365. package/contracts/shared/KeyValueStore.sol +127 -0
  366. package/contracts/{instance/base → shared}/Lifecycle.sol +37 -7
  367. package/contracts/shared/NftIdSetManager.sol +65 -0
  368. package/contracts/shared/NftOwnable.sol +59 -88
  369. package/contracts/shared/PolicyHolder.sol +102 -0
  370. package/contracts/shared/ProxyManager.sol +131 -26
  371. package/contracts/shared/Registerable.sol +26 -41
  372. package/contracts/shared/RegistryLinked.sol +43 -0
  373. package/contracts/shared/Service.sol +38 -21
  374. package/contracts/shared/TokenHandler.sol +37 -6
  375. package/contracts/shared/Versionable.sol +4 -92
  376. package/contracts/staking/IStaking.sol +168 -0
  377. package/contracts/staking/IStakingService.sol +149 -0
  378. package/contracts/staking/StakeManagerLib.sol +179 -0
  379. package/contracts/staking/Staking.sol +551 -0
  380. package/contracts/staking/StakingManager.sol +54 -0
  381. package/contracts/staking/StakingReader.sol +187 -0
  382. package/contracts/staking/StakingService.sol +406 -0
  383. package/contracts/staking/StakingServiceManager.sol +45 -0
  384. package/contracts/staking/StakingStore.sol +572 -0
  385. package/contracts/staking/TargetManagerLib.sol +207 -0
  386. package/contracts/{types → type}/AddressSet.sol +1 -1
  387. package/contracts/type/Amount.sol +128 -0
  388. package/contracts/{types → type}/Blocknumber.sol +21 -3
  389. package/contracts/type/ClaimId.sol +75 -0
  390. package/contracts/{types → type}/DistributorType.sol +2 -2
  391. package/contracts/{types → type}/Fee.sol +33 -23
  392. package/contracts/{types → type}/NftId.sol +21 -15
  393. package/contracts/{types → type}/NftIdSet.sol +2 -2
  394. package/contracts/{types → type}/ObjectType.sol +32 -16
  395. package/contracts/type/PayoutId.sol +82 -0
  396. package/contracts/{types → type}/Referral.sol +5 -1
  397. package/contracts/type/RequestId.sol +75 -0
  398. package/contracts/{types → type}/RiskId.sol +1 -1
  399. package/contracts/type/RoleId.sol +146 -0
  400. package/contracts/type/Seconds.sol +81 -0
  401. package/contracts/{types → type}/StateId.sol +34 -4
  402. package/contracts/{types → type}/Timestamp.sol +23 -14
  403. package/contracts/{types → type}/UFixed.sol +1 -0
  404. package/contracts/{types → type}/Version.sol +2 -1
  405. package/package.json +5 -5
  406. package/artifacts/contracts/components/Component.sol/Component.dbg.json +0 -4
  407. package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +0 -4
  408. package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +0 -4
  409. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +0 -4
  410. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +0 -152
  411. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +0 -4
  412. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +0 -275
  413. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +0 -4
  414. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +0 -157
  415. package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +0 -4
  416. package/artifacts/contracts/components/Product.sol/Product.dbg.json +0 -4
  417. package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.dbg.json +0 -4
  418. package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.json +0 -66
  419. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.dbg.json +0 -4
  420. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.json +0 -24
  421. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.dbg.json +0 -4
  422. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.json +0 -42
  423. package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +0 -4
  424. package/artifacts/contracts/experiment/errors/Require.sol/Require.json +0 -105
  425. package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +0 -4
  426. package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +0 -105
  427. package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +0 -4
  428. package/artifacts/contracts/experiment/inheritance/A.sol/A.json +0 -128
  429. package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +0 -4
  430. package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +0 -42
  431. package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +0 -4
  432. package/artifacts/contracts/experiment/inheritance/B.sol/B.json +0 -76
  433. package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +0 -4
  434. package/artifacts/contracts/experiment/inheritance/C.sol/C.json +0 -89
  435. package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +0 -4
  436. package/artifacts/contracts/experiment/inheritance/IA.sol/IA.json +0 -128
  437. package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +0 -4
  438. package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +0 -4
  439. package/artifacts/contracts/experiment/inheritance/IB.sol/IB.json +0 -50
  440. package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +0 -4
  441. package/artifacts/contracts/experiment/inheritance/IC.sol/IC.json +0 -63
  442. package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.dbg.json +0 -4
  443. package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +0 -59
  444. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +0 -4
  445. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.json +0 -124
  446. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +0 -4
  447. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.json +0 -74
  448. package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +0 -4
  449. package/artifacts/contracts/experiment/statemachine/SM.sol/SM.json +0 -124
  450. package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +0 -4
  451. package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.json +0 -207
  452. package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +0 -4
  453. package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.json +0 -10
  454. package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +0 -4
  455. package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.json +0 -10
  456. package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +0 -4
  457. package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +0 -1206
  458. package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +0 -4
  459. package/artifacts/contracts/instance/IInstanceBase.sol/IInstanceBase.dbg.json +0 -4
  460. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +0 -4
  461. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +0 -1047
  462. package/artifacts/contracts/instance/InstanceBase.sol/InstanceBase.dbg.json +0 -4
  463. package/artifacts/contracts/instance/InstanceBase.sol/InstanceBase.json +0 -763
  464. package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +0 -4
  465. package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +0 -285
  466. package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.dbg.json +0 -4
  467. package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +0 -4
  468. package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.json +0 -100
  469. package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +0 -4
  470. package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.json +0 -429
  471. package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +0 -4
  472. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +0 -4
  473. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +0 -502
  474. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +0 -4
  475. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +0 -169
  476. package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +0 -4
  477. package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +0 -4
  478. package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +0 -4
  479. package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +0 -1094
  480. package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +0 -4
  481. package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +0 -436
  482. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +0 -4
  483. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +0 -764
  484. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +0 -4
  485. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +0 -424
  486. package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +0 -4
  487. package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +0 -4
  488. package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.json +0 -446
  489. package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +0 -4
  490. package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +0 -4
  491. package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +0 -4
  492. package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +0 -4
  493. package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +0 -1219
  494. package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +0 -4
  495. package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +0 -492
  496. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +0 -4
  497. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +0 -798
  498. package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +0 -4
  499. package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +0 -424
  500. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +0 -4
  501. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +0 -848
  502. package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
  503. package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +0 -424
  504. package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +0 -4
  505. package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +0 -285
  506. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +0 -4
  507. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +0 -107
  508. package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +0 -4
  509. package/artifacts/contracts/test/TestFee.sol/TestFee.json +0 -119
  510. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +0 -4
  511. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +0 -305
  512. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +0 -4
  513. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +0 -116
  514. package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +0 -4
  515. package/artifacts/contracts/test/TestService.sol/TestService.json +0 -600
  516. package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +0 -4
  517. package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +0 -376
  518. package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +0 -4
  519. package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +0 -218
  520. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +0 -4
  521. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +0 -286
  522. package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +0 -4
  523. package/artifacts/contracts/test/Usdc.sol/USDC.json +0 -376
  524. package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +0 -4
  525. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +0 -4
  526. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +0 -174
  527. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +0 -4
  528. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +0 -10
  529. package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +0 -4
  530. package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +0 -4
  531. package/artifacts/contracts/types/Fee.sol/FeeLib.json +0 -257
  532. package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +0 -4
  533. package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +0 -4
  534. package/artifacts/contracts/types/NftId.sol/NftIdLib.json +0 -153
  535. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +0 -4
  536. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +0 -4
  537. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.json +0 -100
  538. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +0 -4
  539. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +0 -92
  540. package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +0 -4
  541. package/artifacts/contracts/types/Referral.sol/ReferralLib.json +0 -123
  542. package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +0 -4
  543. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +0 -4
  544. package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +0 -4
  545. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +0 -4
  546. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +0 -249
  547. package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +0 -4
  548. package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +0 -4
  549. package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +0 -4
  550. package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +0 -4
  551. package/contracts/components/Component.sol +0 -177
  552. package/contracts/components/Distribution.sol +0 -154
  553. package/contracts/components/IComponent.sol +0 -37
  554. package/contracts/components/IDistributionComponent.sol +0 -44
  555. package/contracts/components/IPoolComponent.sol +0 -66
  556. package/contracts/components/IProductComponent.sol +0 -35
  557. package/contracts/components/Pool.sol +0 -258
  558. package/contracts/components/Product.sol +0 -295
  559. package/contracts/experiment/cloning/Cloner.sol +0 -47
  560. package/contracts/experiment/errors/Require.sol +0 -38
  561. package/contracts/experiment/errors/Revert.sol +0 -44
  562. package/contracts/experiment/inheritance/A.sol +0 -53
  563. package/contracts/experiment/inheritance/B.sol +0 -28
  564. package/contracts/experiment/inheritance/C.sol +0 -34
  565. package/contracts/experiment/inheritance/IA.sol +0 -13
  566. package/contracts/experiment/inheritance/IB.sol +0 -10
  567. package/contracts/experiment/inheritance/IC.sol +0 -12
  568. package/contracts/experiment/statemachine/Dummy.sol +0 -27
  569. package/contracts/experiment/statemachine/ISM.sol +0 -25
  570. package/contracts/experiment/statemachine/SM.sol +0 -57
  571. package/contracts/experiment/statemachine/SimpleStateMachine.sol +0 -31
  572. package/contracts/experiment/types/TypeA.sol +0 -47
  573. package/contracts/experiment/types/TypeB.sol +0 -29
  574. package/contracts/instance/AccessManagerUpgradeableInitializeable.sol +0 -23
  575. package/contracts/instance/IInstanceBase.sol +0 -25
  576. package/contracts/instance/InstanceAccessManager.sol +0 -303
  577. package/contracts/instance/InstanceBase.sol +0 -39
  578. package/contracts/instance/base/ComponentService.sol +0 -133
  579. package/contracts/instance/base/IInstanceBase.sol +0 -21
  580. package/contracts/instance/base/KeyValueStore.sol +0 -172
  581. package/contracts/instance/module/ISetup.sol +0 -46
  582. package/contracts/instance/module/ITreasury.sol +0 -23
  583. package/contracts/instance/service/BundleService.sol +0 -293
  584. package/contracts/instance/service/BundleServiceManager.sol +0 -51
  585. package/contracts/instance/service/DistributionService.sol +0 -115
  586. package/contracts/instance/service/DistributionServiceManager.sol +0 -51
  587. package/contracts/instance/service/IBundleService.sol +0 -44
  588. package/contracts/instance/service/IDistributionService.sol +0 -12
  589. package/contracts/instance/service/IPolicyService.sol +0 -94
  590. package/contracts/instance/service/IPoolService.sol +0 -20
  591. package/contracts/instance/service/IProductService.sol +0 -40
  592. package/contracts/instance/service/PolicyService.sol +0 -538
  593. package/contracts/instance/service/PolicyServiceManager.sol +0 -54
  594. package/contracts/instance/service/PoolService.sol +0 -142
  595. package/contracts/instance/service/PoolServiceManager.sol +0 -51
  596. package/contracts/instance/service/ProductService.sol +0 -241
  597. package/contracts/instance/service/ProductServiceManager.sol +0 -54
  598. package/contracts/registry/RegistryAccessManager.sol +0 -216
  599. package/contracts/shared/ContractDeployerLib.sol +0 -72
  600. package/contracts/test/TestFee.sol +0 -25
  601. package/contracts/test/TestRegisterable.sol +0 -18
  602. package/contracts/test/TestRoleId.sol +0 -14
  603. package/contracts/test/TestService.sol +0 -25
  604. package/contracts/test/TestToken.sol +0 -26
  605. package/contracts/test/TestVersion.sol +0 -44
  606. package/contracts/test/TestVersionable.sol +0 -17
  607. package/contracts/types/ChainId.sol +0 -38
  608. package/contracts/types/NumberId.sol +0 -52
  609. package/contracts/types/RoleId.sol +0 -90
  610. /package/contracts/{types → type}/Key32.sol +0 -0
@@ -0,0 +1,572 @@
1
+ // SPDX-License-Identifier: Apache-2.0
2
+ pragma solidity ^0.8.20;
3
+
4
+ import {AccessManaged} from "@openzeppelin/contracts/access/manager/AccessManaged.sol";
5
+
6
+ import {Amount, AmountLib} from "../type/Amount.sol";
7
+ import {Blocknumber, BlocknumberLib} from "../type/Blocknumber.sol";
8
+ import {ChainNft} from "../registry/ChainNft.sol";
9
+ import {Component} from "../shared/Component.sol";
10
+ import {IRegistry} from "../registry/IRegistry.sol";
11
+ import {IRegistryService} from "../registry/IRegistryService.sol";
12
+ import {IStaking} from "./IStaking.sol";
13
+ import {IVersionable} from "../shared/IVersionable.sol";
14
+ import {Key32} from "../type/Key32.sol";
15
+ import {KeyValueStore} from "../shared/KeyValueStore.sol";
16
+ import {KEEP_STATE} from "../type/StateId.sol";
17
+ import {LibNftIdSet} from "../type/NftIdSet.sol";
18
+ import {NftId, NftIdLib} from "../type/NftId.sol";
19
+ import {NftIdSetManager} from "../shared/NftIdSetManager.sol";
20
+ import {ObjectType, INSTANCE, PROTOCOL, STAKE, STAKING, TARGET} from "../type/ObjectType.sol";
21
+ import {Seconds, SecondsLib} from "../type/Seconds.sol";
22
+ import {StakingReader} from "./StakingReader.sol";
23
+ import {TargetManagerLib} from "./TargetManagerLib.sol";
24
+ import {Timestamp, TimestampLib} from "../type/Timestamp.sol";
25
+ import {TokenRegistry} from "../registry/TokenRegistry.sol";
26
+ import {UFixed, UFixedLib} from "../type/UFixed.sol";
27
+ import {Version, VersionLib} from "../type/Version.sol";
28
+ import {Versionable} from "../shared/Versionable.sol";
29
+
30
+ import {RegistryAdmin} from "../registry/RegistryAdmin.sol";
31
+
32
+
33
+ contract StakingStore is
34
+ AccessManaged,
35
+ KeyValueStore
36
+ {
37
+
38
+ event LogStakingStoreReserveBalanceIncreased(NftId targetNftId, Amount dipAmount, Amount reserveBalance, Blocknumber lastUpdatedIn);
39
+ event LogStakingStoreReserveBalanceDecreased(NftId targetNftId, Amount dipAmount, Amount reserveBalance, Blocknumber lastUpdatedIn);
40
+
41
+ event LogStakingStoreTotalValueLockedIncreased(NftId targetNftId, address token, Amount amount, Amount newBalance, Blocknumber lastUpdatedIn);
42
+ event LogStakingStoreTotalValueLockedDecreased(NftId targetNftId, address token, Amount amount, Amount newBalance, Blocknumber lastUpdatedIn);
43
+
44
+ event LogStakingStoreStakesIncreased(NftId nftId, Amount addedAmount, Amount newBalance, Blocknumber lastUpdatedIn);
45
+ event LogStakingStoreStakesDecreased(NftId nftId, Amount addedAmount, Amount newBalance, Blocknumber lastUpdatedIn);
46
+
47
+ event LogStakingStoreRewardsIncreased(NftId nftId, Amount addedAmount, Amount newBalance, Blocknumber lastUpdatedIn);
48
+ event LogStakingStoreRewardsDecreased(NftId nftId, Amount addedAmount, Amount newBalance, Blocknumber lastUpdatedIn);
49
+
50
+ event LogStakingStoreRewardsRestaked(NftId nftId, Amount amount, Amount rewardAmount, Amount rewardIncrementAmount, Amount newBalance, Blocknumber lastUpdatedIn);
51
+
52
+ // in/decreasing reward reserves
53
+ error ErrorStakingStoreNotTarget(NftId targetNftId);
54
+ error ErrorStakingStoreRewardReservesInsufficient(NftId targetNftId, Amount dipAmount, Amount reservesBalanceAmount);
55
+
56
+ // creating and updating of balance
57
+ error ErrorStakingStoreBalanceAlreadyInitialized(NftId nftId);
58
+ error ErrorStakingStoreBalanceNotInitialized(NftId nftId);
59
+
60
+ // update balance
61
+ error ErrorStakingStoreTvlBalanceNotInitialized(NftId nftId);
62
+
63
+ IRegistry private _registry;
64
+ NftIdSetManager private _targetManager;
65
+ StakingReader private _reader;
66
+
67
+ // staking rate
68
+ mapping(uint256 chainId => mapping(address token => UFixed stakingRate)) private _stakingRate;
69
+
70
+ // total, stake and reward balances
71
+ mapping(NftId nftId => Amount stakes) private _stakeBalance;
72
+ mapping(NftId nftId => Amount rewards) private _rewardBalance;
73
+ mapping(NftId nftId => Amount reserves) private _reserveBalance;
74
+
75
+ mapping(NftId nftId => Timestamp lastUpdatedAt) private _lastUpdatedAt;
76
+ mapping(NftId nftId => Blocknumber lastUpdatedIn) private _lastUpdatedIn;
77
+
78
+ // total value locked balance
79
+ mapping(NftId nftId => mapping(address token => Amount tvl)) private _tvlBalance;
80
+ mapping(NftId nftId => mapping(address token => Amount tvlInDip)) private _tvlInDip;
81
+ mapping(NftId nftId => Amount tvlRequiredDip) private _tvlRequiredDip;
82
+ mapping(NftId nftId => Blocknumber lastUpdatedIn) private _tvlLastUpdatedIn;
83
+
84
+
85
+ constructor(IRegistry registry, StakingReader reader)
86
+ AccessManaged(msg.sender)
87
+ {
88
+ _registry = registry; //TODO if keeps registry -> RegistryLinked and checks registry address
89
+ address authority = _registry.getAuthority();
90
+ setAuthority(authority);
91
+
92
+ _reader = reader;
93
+ _targetManager = new NftIdSetManager();
94
+ }
95
+
96
+
97
+ //--- staking rate specific functions -----------------------------------//
98
+
99
+ function setStakingRate(uint256 chainId, address token, UFixed stakingRate)
100
+ external
101
+ {
102
+ _stakingRate[chainId][token] = stakingRate;
103
+ }
104
+
105
+ //--- target specific functions -----------------------------------------//
106
+
107
+ function createTarget(
108
+ NftId targetNftId,
109
+ IStaking.TargetInfo memory targetInfo
110
+ )
111
+ external
112
+ {
113
+ _create(
114
+ targetNftId.toKey32(TARGET()),
115
+ abi.encode(targetInfo));
116
+
117
+ // initialize tvl and stake balance
118
+ _tvlLastUpdatedIn[targetNftId]= BlocknumberLib.currentBlocknumber();
119
+ _createTargetBalance(targetNftId);
120
+
121
+ _targetManager.add(targetNftId);
122
+ }
123
+
124
+
125
+ function updateTarget(
126
+ NftId targetNftId,
127
+ IStaking.TargetInfo memory targetInfo
128
+ )
129
+ external
130
+ {
131
+ _update(
132
+ targetNftId.toKey32(TARGET()),
133
+ abi.encode(targetInfo), KEEP_STATE());
134
+ }
135
+
136
+
137
+ function increaseReserves(
138
+ NftId targetNftId,
139
+ Amount dipAmount
140
+ )
141
+ external
142
+ returns (Amount newReserveBalance)
143
+ {
144
+ newReserveBalance = _reserveBalance[targetNftId] + dipAmount;
145
+ Blocknumber lastUpdatedIn = _updateReserves(targetNftId, newReserveBalance);
146
+
147
+ emit LogStakingStoreReserveBalanceIncreased(targetNftId, dipAmount, newReserveBalance, lastUpdatedIn);
148
+ }
149
+
150
+
151
+ function decreaseReserves(
152
+ NftId targetNftId,
153
+ Amount dipAmount
154
+ )
155
+ external
156
+ returns (Amount newReserveBalance)
157
+ {
158
+ Amount reserveAmount = _reserveBalance[targetNftId];
159
+ if (dipAmount > reserveAmount) {
160
+ revert ErrorStakingStoreRewardReservesInsufficient(
161
+ targetNftId,
162
+ dipAmount,
163
+ reserveAmount);
164
+ }
165
+
166
+ newReserveBalance = _reserveBalance[targetNftId] - dipAmount;
167
+ Blocknumber lastUpdatedIn = _updateReserves(targetNftId, newReserveBalance);
168
+
169
+ emit LogStakingStoreReserveBalanceDecreased(targetNftId, dipAmount, newReserveBalance, lastUpdatedIn);
170
+ }
171
+
172
+
173
+ function _updateReserves(
174
+ NftId targetNftId,
175
+ Amount newRewardBalance
176
+ )
177
+ internal
178
+ returns (Blocknumber lastUpdatedIn)
179
+ {
180
+ if (_lastUpdatedIn[targetNftId].eqz()) {
181
+ revert ErrorStakingStoreNotTarget(targetNftId);
182
+ }
183
+
184
+ lastUpdatedIn = _lastUpdatedIn[targetNftId];
185
+
186
+ _reserveBalance[targetNftId] = newRewardBalance;
187
+ _lastUpdatedIn[targetNftId] = BlocknumberLib.currentBlocknumber();
188
+ }
189
+
190
+
191
+ //--- tvl specific functions -------------------------------------//
192
+
193
+ function increaseTotalValueLocked(
194
+ NftId targetNftId,
195
+ UFixed stakingRate,
196
+ address token,
197
+ Amount amount
198
+ )
199
+ external
200
+ returns (Amount newBalance)
201
+ {
202
+ (
203
+ Blocknumber tvlLastUpdatedIn,
204
+ Amount oldBalance,
205
+ Amount oldDipBalance
206
+ ) = _getAndVerifyTvl(targetNftId, token);
207
+
208
+ newBalance = oldBalance + amount;
209
+ Amount newDipBalance = newBalance.multiplyWith(stakingRate);
210
+
211
+ // update new tvl balances
212
+ _tvlBalance[targetNftId][token] = newBalance;
213
+ _tvlInDip[targetNftId][token] = newDipBalance;
214
+
215
+ // update new amount of required dip
216
+ _tvlRequiredDip[targetNftId] = _tvlRequiredDip[targetNftId] - oldDipBalance + newDipBalance;
217
+
218
+ // update last updated in
219
+ _tvlLastUpdatedIn[targetNftId] = BlocknumberLib.currentBlocknumber();
220
+
221
+ emit LogStakingStoreTotalValueLockedIncreased(targetNftId, token, amount, newBalance, tvlLastUpdatedIn);
222
+ }
223
+
224
+
225
+ function decreaseTotalValueLocked(
226
+ NftId targetNftId,
227
+ UFixed stakingRate,
228
+ address token,
229
+ Amount amount
230
+ )
231
+ external
232
+ returns (Amount newBalance)
233
+ {
234
+ (
235
+ Blocknumber tvlLastUpdatedIn,
236
+ Amount oldBalance,
237
+ Amount oldDipBalance
238
+ ) = _getAndVerifyTvl(targetNftId, token);
239
+
240
+ newBalance = oldBalance - amount;
241
+ Amount newDipBalance = AmountLib.toAmount((
242
+ stakingRate * newBalance.toUFixed()).toInt());
243
+
244
+ // update new tvl balances
245
+ _tvlBalance[targetNftId][token] = newBalance;
246
+ _tvlInDip[targetNftId][token] = newDipBalance;
247
+
248
+ // update new amount of required dip
249
+ _tvlRequiredDip[targetNftId] = _tvlRequiredDip[targetNftId] - oldDipBalance + newDipBalance;
250
+
251
+ // update last updated in
252
+ _tvlLastUpdatedIn[targetNftId] = BlocknumberLib.currentBlocknumber();
253
+
254
+ emit LogStakingStoreTotalValueLockedDecreased(targetNftId, token, amount, newBalance, tvlLastUpdatedIn);
255
+ }
256
+
257
+ //--- stake specific functions -------------------------------------//
258
+
259
+ function create(
260
+ NftId stakeNftId,
261
+ IStaking.StakeInfo memory stakeInfo
262
+ )
263
+ external
264
+ {
265
+ _create(
266
+ stakeNftId.toKey32(STAKE()),
267
+ abi.encode(stakeInfo));
268
+
269
+ _createStakeBalance(stakeNftId);
270
+ }
271
+
272
+ function update(
273
+ NftId stakeNftId,
274
+ IStaking.StakeInfo memory stakeInfo
275
+ )
276
+ external
277
+ {
278
+ _update(
279
+ stakeNftId.toKey32(STAKE()),
280
+ abi.encode(stakeInfo),
281
+ KEEP_STATE());
282
+ }
283
+
284
+ //--- general functions --------------------------------------------//
285
+
286
+
287
+ function increaseStake(
288
+ NftId nftId,
289
+ NftId targetNftId,
290
+ Amount amount
291
+ )
292
+ public
293
+ {
294
+ Blocknumber lastUpdatedIn = _checkBalanceExists(nftId);
295
+
296
+ _updateStakeBalance(
297
+ nftId,
298
+ _stakeBalance[nftId] + amount, // new stake balance
299
+ _rewardBalance[nftId]); // unchanged reward balance
300
+
301
+ _updateTargetBalance(
302
+ targetNftId,
303
+ _stakeBalance[targetNftId] + amount,
304
+ _rewardBalance[targetNftId]);
305
+
306
+ emit LogStakingStoreStakesIncreased(nftId, amount, _stakeBalance[nftId], lastUpdatedIn);
307
+ }
308
+
309
+
310
+ function restakeRewards(
311
+ NftId nftId,
312
+ NftId targetNftId,
313
+ Amount rewardIncrementAmount
314
+ )
315
+ external
316
+ {
317
+ Blocknumber lastUpdatedIn = _checkBalanceExists(nftId);
318
+ Amount stakeAmount = _stakeBalance[nftId];
319
+ Amount rewardAmount = _rewardBalance[nftId];
320
+
321
+ // move all rewards to stake balance
322
+ _updateStakeBalance(
323
+ nftId,
324
+ stakeAmount + rewardAmount + rewardIncrementAmount, // new stake balance
325
+ AmountLib.zero()); // new reward balance
326
+
327
+ _updateTargetBalance(
328
+ targetNftId,
329
+ _stakeBalance[targetNftId] + rewardAmount + rewardIncrementAmount,
330
+ _rewardBalance[targetNftId] - rewardAmount);
331
+
332
+ emit LogStakingStoreRewardsRestaked(nftId, stakeAmount, rewardAmount, rewardIncrementAmount, _stakeBalance[nftId], lastUpdatedIn);
333
+ }
334
+
335
+
336
+ function updateRewards(
337
+ NftId nftId,
338
+ NftId targetNftId,
339
+ Amount rewardIncrementAmount
340
+ )
341
+ external
342
+ {
343
+ Blocknumber lastUpdatedIn = _checkBalanceExists(nftId);
344
+
345
+ // increse rewards by increment
346
+ _updateStakeBalance(
347
+ nftId,
348
+ _stakeBalance[nftId], // unchanged stake balance
349
+ _rewardBalance[nftId] + rewardIncrementAmount); // new reward balance
350
+
351
+ _updateTargetBalance(
352
+ targetNftId,
353
+ _stakeBalance[targetNftId],
354
+ _rewardBalance[targetNftId] + rewardIncrementAmount);
355
+
356
+ emit LogStakingStoreRewardsIncreased(nftId, rewardIncrementAmount, _rewardBalance[nftId], lastUpdatedIn);
357
+ }
358
+
359
+
360
+ function claimUpTo(
361
+ NftId nftId,
362
+ NftId targetNftId,
363
+ Amount maxClaimAmount
364
+ )
365
+ external
366
+ returns (Amount claimedAmount)
367
+ {
368
+ Blocknumber lastUpdatedIn = _checkBalanceExists(nftId);
369
+
370
+ // determine the claimable rewards amount
371
+ claimedAmount = AmountLib.min(maxClaimAmount, _rewardBalance[nftId]);
372
+
373
+ // decrease rewards by claimed amount
374
+ _updateStakeBalance(
375
+ nftId,
376
+ _stakeBalance[nftId], // unchanged stake balance
377
+ _rewardBalance[nftId] - claimedAmount); // new reward balance
378
+
379
+ _updateTargetBalance(
380
+ targetNftId,
381
+ _stakeBalance[targetNftId],
382
+ _rewardBalance[targetNftId] - claimedAmount);
383
+
384
+ emit LogStakingStoreRewardsDecreased(nftId, claimedAmount, _rewardBalance[nftId], lastUpdatedIn);
385
+ }
386
+
387
+
388
+ function unstakeUpTo(
389
+ NftId nftId,
390
+ NftId targetNftId,
391
+ Amount maxUnstakeAmount,
392
+ Amount maxClaimAmount
393
+ )
394
+ external
395
+ returns (
396
+ Amount unstakedAmount,
397
+ Amount claimedAmount
398
+ )
399
+ {
400
+ Blocknumber lastUpdatedIn = _checkBalanceExists(nftId);
401
+
402
+ // determine amounts
403
+ unstakedAmount = AmountLib.min(maxUnstakeAmount, _stakeBalance[nftId]);
404
+ claimedAmount = AmountLib.min(maxClaimAmount, _rewardBalance[nftId]);
405
+
406
+ // decrease stakes and rewards as determined
407
+ _updateStakeBalance(
408
+ nftId,
409
+ _stakeBalance[nftId] - unstakedAmount, // unchanged stake balance
410
+ _rewardBalance[nftId] - claimedAmount); // new reward balance
411
+
412
+ _updateTargetBalance(
413
+ targetNftId,
414
+ _stakeBalance[targetNftId] - unstakedAmount,
415
+ _rewardBalance[targetNftId] - claimedAmount);
416
+
417
+ emit LogStakingStoreStakesDecreased(nftId, unstakedAmount, _stakeBalance[nftId], lastUpdatedIn);
418
+ emit LogStakingStoreRewardsDecreased(nftId, claimedAmount, _rewardBalance[nftId], lastUpdatedIn);
419
+ }
420
+
421
+ //--- view functions -----------------------------------------------//
422
+
423
+ function getStakingReader() external view returns (StakingReader stakingReader){
424
+ return _reader;
425
+ }
426
+
427
+ function getTargetManager() external view returns (NftIdSetManager targetManager){
428
+ return _targetManager;
429
+ }
430
+
431
+ function getStakingRate(uint256 chainId, address token) external view returns (UFixed stakingRate) { return _stakingRate[chainId][token]; }
432
+
433
+ function exists(NftId stakeNftId) external view returns (bool) { return exists(stakeNftId.toKey32(STAKE())); }
434
+
435
+ function getTotalValueLocked(NftId nftId, address token) external view returns (Amount tvlBalanceAmount) { return _tvlBalance[nftId][token]; }
436
+ function getRequiredStakeBalance(NftId nftId) external view returns (Amount requiredAmount) { return _tvlRequiredDip[nftId]; }
437
+
438
+ function getReserveBalance(NftId nftId) external view returns (Amount balanceAmount) { return _reserveBalance[nftId]; }
439
+ function getStakeBalance(NftId nftId) external view returns (Amount balanceAmount) { return _stakeBalance[nftId]; }
440
+ function getRewardBalance(NftId nftId) external view returns (Amount rewardAmount) { return _rewardBalance[nftId]; }
441
+ function getBalanceUpdatedAt(NftId nftId) external view returns (Timestamp updatedAt) { return _lastUpdatedAt[nftId]; }
442
+ function getBalanceUpdatedIn(NftId nftId) external view returns (Blocknumber blocknumber) { return _lastUpdatedIn[nftId]; }
443
+
444
+
445
+ function getTargetBalances(NftId nftId)
446
+ external
447
+ view
448
+ returns (
449
+ Amount stakeBalance,
450
+ Amount rewardBalance,
451
+ Amount reserveBalance,
452
+ Blocknumber lastUpdatedIn
453
+ )
454
+ {
455
+ stakeBalance = _stakeBalance[nftId];
456
+ rewardBalance = _rewardBalance[nftId];
457
+ reserveBalance = _reserveBalance[nftId];
458
+ lastUpdatedIn = _lastUpdatedIn[nftId];
459
+ }
460
+
461
+
462
+ function getStakeBalances(NftId nftId)
463
+ external
464
+ view
465
+ returns (
466
+ Amount stakeBalance,
467
+ Amount rewardBalance,
468
+ Timestamp lastUpdatedAt
469
+ )
470
+ {
471
+ stakeBalance = _stakeBalance[nftId];
472
+ rewardBalance = _rewardBalance[nftId];
473
+ lastUpdatedAt = _lastUpdatedAt[nftId];
474
+ }
475
+
476
+ //--- private functions -------------------------------------------//
477
+
478
+
479
+ function _createTargetBalance(NftId nftId) private {
480
+ if (_lastUpdatedIn[nftId].gtz()) {
481
+ revert ErrorStakingStoreBalanceAlreadyInitialized(nftId);
482
+ }
483
+
484
+ // set target balances to 0
485
+ _stakeBalance[nftId] = AmountLib.zero();
486
+ _rewardBalance[nftId] = AmountLib.zero();
487
+ _reserveBalance[nftId] = AmountLib.zero();
488
+
489
+ // set last updated in to current block number
490
+ // we don't need last updated at timestamp for targets
491
+ _lastUpdatedIn[nftId] = BlocknumberLib.currentBlocknumber();
492
+ }
493
+
494
+
495
+ function _createStakeBalance(NftId nftId) private {
496
+ if (_lastUpdatedIn[nftId].gtz()) {
497
+ revert ErrorStakingStoreBalanceAlreadyInitialized(nftId);
498
+ }
499
+
500
+ // set stake balances to 0
501
+ _stakeBalance[nftId] = AmountLib.zero();
502
+ _rewardBalance[nftId] = AmountLib.zero();
503
+
504
+ // set last updated at/in to current timestamp/block number
505
+ _lastUpdatedAt[nftId] = TimestampLib.blockTimestamp();
506
+ _lastUpdatedIn[nftId] = BlocknumberLib.currentBlocknumber();
507
+ }
508
+
509
+
510
+ function _updateStakeBalance(
511
+ NftId stakeNftId,
512
+ Amount newStakeAmount,
513
+ Amount newRewardAmount
514
+ )
515
+ internal
516
+ {
517
+ _stakeBalance[stakeNftId] = newStakeAmount;
518
+ _rewardBalance[stakeNftId] = newRewardAmount;
519
+
520
+ _lastUpdatedAt[stakeNftId] = TimestampLib.blockTimestamp();
521
+ _lastUpdatedIn[stakeNftId] = BlocknumberLib.currentBlocknumber();
522
+ }
523
+
524
+
525
+ function _updateTargetBalance(
526
+ NftId targetNftId,
527
+ Amount newStakeAmount,
528
+ Amount newRewardAmount
529
+ )
530
+ internal
531
+ {
532
+ _stakeBalance[targetNftId] = newStakeAmount;
533
+ _rewardBalance[targetNftId] = newRewardAmount;
534
+
535
+ // for targets we don't need the timestamp, just the blocknumber
536
+ _lastUpdatedIn[targetNftId] = BlocknumberLib.currentBlocknumber();
537
+ }
538
+
539
+ function _checkBalanceExists(NftId nftId)
540
+ internal
541
+ returns (Blocknumber lastUpdatedIn)
542
+ {
543
+ lastUpdatedIn = _lastUpdatedIn[nftId];
544
+
545
+ if (lastUpdatedIn.eqz()) {
546
+ revert ErrorStakingStoreBalanceNotInitialized(nftId);
547
+ }
548
+ }
549
+
550
+
551
+ function _getAndVerifyTvl(
552
+ NftId targetNftId,
553
+ address token
554
+ )
555
+ internal
556
+ view
557
+ returns (
558
+ Blocknumber tvlLastUpdatedIn,
559
+ Amount oldBalance,
560
+ Amount oldDipBalance
561
+ )
562
+ {
563
+ tvlLastUpdatedIn = _tvlLastUpdatedIn[targetNftId];
564
+
565
+ if (tvlLastUpdatedIn.eqz()) {
566
+ revert ErrorStakingStoreTvlBalanceNotInitialized(targetNftId);
567
+ }
568
+
569
+ oldBalance = _tvlBalance[targetNftId][token];
570
+ oldDipBalance = _tvlInDip[targetNftId][token];
571
+ }
572
+ }