@etherisc/gif-next 0.0.2-a1053ad-624 → 0.0.2-a105567-464

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (564) hide show
  1. package/README.md +76 -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 +4 -0
  13. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +778 -0
  14. package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
  15. package/artifacts/contracts/instance/IInstance.sol/IInstance.json +567 -246
  16. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
  17. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +384 -155
  18. package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
  19. package/artifacts/contracts/instance/Instance.sol/Instance.json +431 -2918
  20. package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +4 -0
  21. package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +692 -0
  22. package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +4 -0
  23. package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +204 -0
  24. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
  25. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +719 -406
  26. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
  27. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +585 -243
  28. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
  29. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +382 -76
  30. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +4 -0
  31. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +3468 -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/{AccessManagedSimple.sol/AccessManagedSimple.json → base/Cloneable.sol/Cloneable.json} +91 -2
  36. package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +4 -0
  37. package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +256 -0
  38. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
  39. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +30 -112
  40. package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
  41. package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +4 -0
  42. package/artifacts/contracts/instance/module/{ISetup.sol/ISetup.json → IComponents.sol/IComponents.json} +2 -2
  43. package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
  44. package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
  45. package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
  46. package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +4 -0
  47. package/artifacts/contracts/mock/Dip.sol/Dip.json +376 -0
  48. package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +4 -0
  49. package/artifacts/contracts/pool/BundleService.sol/BundleService.json +1097 -0
  50. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
  51. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +742 -0
  52. package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +4 -0
  53. package/artifacts/contracts/{instance/service/IProductService.sol/IProductService.json → pool/IBundleService.sol/IBundleService.json} +297 -358
  54. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
  55. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +1154 -0
  56. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +4 -0
  57. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +1050 -0
  58. package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +4 -0
  59. package/artifacts/contracts/pool/Pool.sol/Pool.json +1565 -0
  60. package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +4 -0
  61. package/artifacts/contracts/pool/PoolService.sol/PoolService.json +1417 -0
  62. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
  63. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +738 -0
  64. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +4 -0
  65. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +826 -0
  66. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
  67. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +718 -0
  68. package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +4 -0
  69. package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +1270 -0
  70. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
  71. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +806 -0
  72. package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +4 -0
  73. package/artifacts/contracts/{instance/service/IComponentOwnerService.sol/IComponentOwnerService.json → product/IApplicationService.sol/IApplicationService.json} +233 -200
  74. package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +4 -0
  75. package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +759 -0
  76. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +4 -0
  77. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +707 -0
  78. package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +4 -0
  79. package/artifacts/contracts/{instance/service/IPoolService.sol/IPoolService.json → product/IPricingService.sol/IPricingService.json} +259 -284
  80. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +4 -0
  81. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +995 -0
  82. package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +4 -0
  83. package/artifacts/contracts/{instance/base/IService.sol/IService.json → product/IProductService.sol/IProductService.json} +132 -166
  84. package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +4 -0
  85. package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +1138 -0
  86. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
  87. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +750 -0
  88. package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +4 -0
  89. package/artifacts/contracts/product/PricingService.sol/PricingService.json +975 -0
  90. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +4 -0
  91. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +774 -0
  92. package/artifacts/contracts/product/Product.sol/Product.dbg.json +4 -0
  93. package/artifacts/contracts/product/Product.sol/Product.json +1397 -0
  94. package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +4 -0
  95. package/artifacts/contracts/product/ProductService.sol/ProductService.json +679 -0
  96. package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +4 -0
  97. package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +694 -0
  98. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
  99. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +15 -2
  100. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
  101. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +534 -59
  102. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
  103. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +438 -200
  104. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
  105. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +18 -0
  106. package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
  107. package/artifacts/contracts/registry/Registry.sol/Registry.json +857 -309
  108. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +4 -0
  109. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +407 -0
  110. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
  111. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +506 -352
  112. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
  113. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +339 -134
  114. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +4 -0
  115. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +1292 -0
  116. package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.dbg.json +4 -0
  117. package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.json +137 -0
  118. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +4 -0
  119. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +643 -0
  120. package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.dbg.json +4 -0
  121. package/artifacts/contracts/{instance/IAccessManagerSimple.sol/IAccessManagerSimple.json → shared/AccessManagerCustom.sol/AccessManagerCustom.json} +122 -11
  122. package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.dbg.json +4 -0
  123. package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.json +1715 -0
  124. package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.dbg.json +4 -0
  125. package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.json +1728 -0
  126. package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.dbg.json +4 -0
  127. package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.json +1806 -0
  128. package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.dbg.json +4 -0
  129. package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.json +1824 -0
  130. package/artifacts/contracts/shared/Component.sol/Component.dbg.json +4 -0
  131. package/artifacts/contracts/shared/Component.sol/Component.json +896 -0
  132. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +4 -0
  133. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +1475 -0
  134. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +4 -0
  135. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +788 -0
  136. package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +4 -0
  137. package/artifacts/contracts/{instance/base/ServiceBase.sol/ServiceBase.json → shared/ComponentVerifyingService.sol/ComponentVerifyingService.json} +225 -167
  138. package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
  139. package/artifacts/contracts/shared/ERC165.sol/ERC165.json +41 -3
  140. package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.dbg.json +4 -0
  141. package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.json +1562 -0
  142. package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.dbg.json +4 -0
  143. package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.json +1600 -0
  144. package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +4 -0
  145. package/artifacts/contracts/shared/IComponent.sol/IComponent.json +631 -0
  146. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +4 -0
  147. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +860 -0
  148. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +4 -0
  149. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +705 -0
  150. package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
  151. package/artifacts/contracts/{instance/base → shared}/IKeyValueStore.sol/IKeyValueStore.json +50 -1
  152. package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +4 -0
  153. package/artifacts/contracts/{instance/base → shared}/ILifecycle.sol/ILifecycle.json +1 -1
  154. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
  155. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +34 -30
  156. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +4 -0
  157. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +207 -0
  158. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
  159. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +15 -35
  160. package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +4 -0
  161. package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.json +35 -0
  162. package/artifacts/contracts/shared/IService.sol/IService.dbg.json +4 -0
  163. package/artifacts/contracts/{components/BaseComponent.sol/BaseComponent.json → shared/IService.sol/IService.json} +97 -78
  164. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
  165. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +2 -152
  166. package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.dbg.json +4 -0
  167. package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.json +39 -0
  168. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +4 -0
  169. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +1036 -0
  170. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +4 -0
  171. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +581 -0
  172. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +4 -0
  173. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +194 -0
  174. package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.dbg.json +4 -0
  175. package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.json +306 -0
  176. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
  177. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +115 -29
  178. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +4 -0
  179. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +320 -0
  180. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
  181. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +330 -62
  182. package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
  183. package/artifacts/contracts/shared/Registerable.sol/Registerable.json +132 -53
  184. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +4 -0
  185. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +71 -0
  186. package/artifacts/contracts/shared/Service.sol/Service.dbg.json +4 -0
  187. package/artifacts/contracts/{instance/base/ComponentServiceBase.sol/ComponentServiceBase.json → shared/Service.sol/Service.json} +193 -180
  188. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
  189. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +60 -6
  190. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
  191. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +2 -2
  192. package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
  193. package/artifacts/contracts/shared/Versionable.sol/Versionable.json +2 -152
  194. package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +4 -0
  195. package/artifacts/contracts/staking/IStaking.sol/IStaking.json +1441 -0
  196. package/artifacts/contracts/staking/IStakingManager.sol/IStakingManager.dbg.json +4 -0
  197. package/artifacts/contracts/{experiment/inheritance/IA.sol/ISharedA.json → staking/IStakingManager.sol/IStakingManager.json} +10 -10
  198. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +4 -0
  199. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +890 -0
  200. package/artifacts/contracts/staking/IStakingStore.sol/IStakingStore.dbg.json +4 -0
  201. package/artifacts/contracts/staking/IStakingStore.sol/IStakingStore.json +357 -0
  202. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +4 -0
  203. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +402 -0
  204. package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +4 -0
  205. package/artifacts/contracts/staking/Staking.sol/Staking.json +2008 -0
  206. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +4 -0
  207. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +761 -0
  208. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +4 -0
  209. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +390 -0
  210. package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +4 -0
  211. package/artifacts/contracts/staking/StakingService.sol/StakingService.json +1213 -0
  212. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +4 -0
  213. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +722 -0
  214. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +4 -0
  215. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +1682 -0
  216. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +4 -0
  217. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +494 -0
  218. package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +4 -0
  219. package/artifacts/contracts/{types → type}/AddressSet.sol/LibAddressSet.json +3 -3
  220. package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +4 -0
  221. package/artifacts/contracts/type/Amount.sol/AmountLib.json +281 -0
  222. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +4 -0
  223. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +225 -0
  224. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
  225. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +179 -0
  226. package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +4 -0
  227. package/artifacts/contracts/{types → type}/DistributorType.sol/DistributorTypeLib.json +5 -5
  228. package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +4 -0
  229. package/artifacts/contracts/type/Fee.sol/FeeLib.json +312 -0
  230. package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +4 -0
  231. package/artifacts/contracts/{types → type}/Key32.sol/Key32Lib.json +3 -3
  232. package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +4 -0
  233. package/artifacts/contracts/type/NftId.sol/NftIdLib.json +185 -0
  234. package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +4 -0
  235. package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +33 -0
  236. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +4 -0
  237. package/artifacts/contracts/{types → type}/ObjectType.sol/ObjectTypeLib.json +3 -3
  238. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
  239. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +209 -0
  240. package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +4 -0
  241. package/artifacts/contracts/type/Referral.sol/ReferralLib.json +142 -0
  242. package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +4 -0
  243. package/artifacts/contracts/{types → type}/RiskId.sol/RiskIdLib.json +5 -5
  244. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +4 -0
  245. package/artifacts/contracts/{types → type}/RoleId.sol/RoleIdLib.json +5 -5
  246. package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +4 -0
  247. package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +174 -0
  248. package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +4 -0
  249. package/artifacts/contracts/{types → type}/StateId.sol/StateIdLib.json +3 -3
  250. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +4 -0
  251. package/artifacts/contracts/{types → type}/Timestamp.sol/TimestampLib.json +39 -8
  252. package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +4 -0
  253. package/artifacts/contracts/{types → type}/UFixed.sol/MathLib.json +3 -3
  254. package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +4 -0
  255. package/artifacts/contracts/{types → type}/UFixed.sol/UFixedLib.json +3 -3
  256. package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +4 -0
  257. package/artifacts/contracts/{types → type}/Version.sol/VersionLib.json +3 -3
  258. package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +4 -0
  259. package/artifacts/contracts/type/Version.sol/VersionPartLib.json +49 -0
  260. package/contracts/distribution/Distribution.sol +261 -0
  261. package/contracts/distribution/DistributionService.sol +298 -0
  262. package/contracts/distribution/DistributionServiceManager.sol +42 -0
  263. package/contracts/distribution/IDistributionComponent.sol +66 -0
  264. package/contracts/distribution/IDistributionService.sol +81 -0
  265. package/contracts/instance/BundleManager.sol +126 -0
  266. package/contracts/instance/IInstance.sol +67 -16
  267. package/contracts/instance/IInstanceService.sol +72 -8
  268. package/contracts/instance/Instance.sol +158 -359
  269. package/contracts/instance/InstanceAdmin.sol +331 -0
  270. package/contracts/instance/InstanceAuthorizationsLib.sol +349 -0
  271. package/contracts/instance/InstanceReader.sol +151 -66
  272. package/contracts/instance/InstanceService.sol +318 -58
  273. package/contracts/instance/InstanceServiceManager.sol +12 -24
  274. package/contracts/instance/InstanceStore.sol +260 -0
  275. package/contracts/instance/base/BalanceStore.sol +118 -0
  276. package/contracts/instance/base/Cloneable.sol +51 -0
  277. package/contracts/instance/base/ObjectManager.sol +82 -0
  278. package/contracts/instance/module/IAccess.sol +29 -21
  279. package/contracts/instance/module/IBundle.sol +8 -7
  280. package/contracts/instance/module/IComponents.sol +52 -0
  281. package/contracts/instance/module/IDistribution.sol +7 -4
  282. package/contracts/instance/module/IPolicy.sol +56 -17
  283. package/contracts/instance/module/IRisk.sol +1 -1
  284. package/contracts/{test/Usdc.sol → mock/Dip.sol} +5 -5
  285. package/contracts/pool/BundleService.sol +296 -0
  286. package/contracts/pool/BundleServiceManager.sol +42 -0
  287. package/contracts/pool/IBundleService.sol +106 -0
  288. package/contracts/pool/IPoolComponent.sol +112 -0
  289. package/contracts/pool/IPoolService.sol +147 -0
  290. package/contracts/pool/Pool.sol +299 -0
  291. package/contracts/pool/PoolService.sol +424 -0
  292. package/contracts/pool/PoolServiceManager.sol +42 -0
  293. package/contracts/product/ApplicationService.sol +254 -0
  294. package/contracts/product/ApplicationServiceManager.sol +38 -0
  295. package/contracts/product/ClaimService.sol +437 -0
  296. package/contracts/product/ClaimServiceManager.sol +38 -0
  297. package/contracts/product/IApplicationService.sol +62 -0
  298. package/contracts/product/IClaimService.sol +93 -0
  299. package/contracts/product/IPolicyService.sol +78 -0
  300. package/contracts/product/IPricingService.sol +39 -0
  301. package/contracts/product/IProductComponent.sol +42 -0
  302. package/contracts/product/IProductService.sol +33 -0
  303. package/contracts/product/PolicyService.sol +473 -0
  304. package/contracts/product/PolicyServiceManager.sol +42 -0
  305. package/contracts/product/PricingService.sol +301 -0
  306. package/contracts/product/PricingServiceManager.sol +42 -0
  307. package/contracts/product/Product.sol +377 -0
  308. package/contracts/product/ProductService.sol +124 -0
  309. package/contracts/product/ProductServiceManager.sol +42 -0
  310. package/contracts/registry/ChainNft.sol +14 -0
  311. package/contracts/registry/IRegistry.sol +81 -12
  312. package/contracts/registry/IRegistryService.sol +54 -20
  313. package/contracts/registry/ITransferInterceptor.sol +1 -0
  314. package/contracts/registry/Registry.sol +405 -243
  315. package/contracts/registry/RegistryAdmin.sol +237 -0
  316. package/contracts/registry/RegistryService.sol +124 -297
  317. package/contracts/registry/RegistryServiceManager.sol +26 -32
  318. package/contracts/registry/ReleaseManager.sol +599 -0
  319. package/contracts/registry/ServiceAuthorizationsLib.sol +173 -0
  320. package/contracts/registry/TokenRegistry.sol +358 -0
  321. package/contracts/{instance/AccessManagerSimple.sol → shared/AccessManagerCustom.sol} +277 -223
  322. package/contracts/shared/AccessManagerExtended.sol +470 -0
  323. package/contracts/shared/AccessManagerExtendedInitializeable.sol +13 -0
  324. package/contracts/shared/AccessManagerExtendedWithDisable.sol +137 -0
  325. package/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol +14 -0
  326. package/contracts/shared/Component.sol +286 -0
  327. package/contracts/shared/ComponentService.sol +596 -0
  328. package/contracts/shared/ComponentServiceManager.sol +35 -0
  329. package/contracts/shared/ComponentVerifyingService.sol +111 -0
  330. package/contracts/shared/ERC165.sol +15 -9
  331. package/contracts/shared/IAccessManagerExtended.sol +74 -0
  332. package/contracts/shared/IAccessManagerExtendedWithDisable.sol +18 -0
  333. package/contracts/shared/IComponent.sol +74 -0
  334. package/contracts/shared/IComponentService.sol +91 -0
  335. package/contracts/shared/IInstanceLinkedComponent.sol +46 -0
  336. package/contracts/{instance/base → shared}/IKeyValueStore.sol +14 -10
  337. package/contracts/{instance/base → shared}/ILifecycle.sol +3 -3
  338. package/contracts/shared/INftOwnable.sol +13 -12
  339. package/contracts/shared/IPolicyHolder.sol +45 -0
  340. package/contracts/shared/IRegisterable.sol +4 -6
  341. package/contracts/shared/IRegistryLinked.sol +11 -0
  342. package/contracts/shared/IService.sol +18 -0
  343. package/contracts/shared/IVersionable.sol +5 -48
  344. package/contracts/shared/InitializableCustom.sol +177 -0
  345. package/contracts/shared/InstanceLinkedComponent.sol +144 -0
  346. package/contracts/shared/KeyValueStore.sol +130 -0
  347. package/contracts/{instance/base → shared}/Lifecycle.sol +28 -7
  348. package/contracts/shared/NftIdSetManager.sol +65 -0
  349. package/contracts/shared/NftOwnable.sol +60 -89
  350. package/contracts/shared/PolicyHolder.sol +102 -0
  351. package/contracts/shared/ProxyManager.sol +131 -26
  352. package/contracts/shared/Registerable.sol +26 -40
  353. package/contracts/shared/RegistryLinked.sol +43 -0
  354. package/contracts/shared/Service.sol +77 -0
  355. package/contracts/shared/TokenHandler.sol +37 -6
  356. package/contracts/shared/Versionable.sol +4 -92
  357. package/contracts/staking/IStaking.sol +152 -0
  358. package/contracts/staking/IStakingManager.sol +15 -0
  359. package/contracts/staking/IStakingService.sol +162 -0
  360. package/contracts/staking/IStakingStore.sol +130 -0
  361. package/contracts/staking/StakeManagerLib.sol +156 -0
  362. package/contracts/staking/Staking.sol +496 -0
  363. package/contracts/staking/StakingManager.sol +54 -0
  364. package/contracts/staking/StakingReader.sol +146 -0
  365. package/contracts/staking/StakingService.sol +376 -0
  366. package/contracts/staking/StakingServiceManager.sol +45 -0
  367. package/contracts/staking/StakingStore.sol +331 -0
  368. package/contracts/staking/TargetManagerLib.sol +179 -0
  369. package/contracts/{types → type}/AddressSet.sol +1 -1
  370. package/contracts/type/Amount.sol +114 -0
  371. package/contracts/{types → type}/Blocknumber.sol +21 -3
  372. package/contracts/type/ClaimId.sol +75 -0
  373. package/contracts/{types → type}/DistributorType.sol +2 -2
  374. package/contracts/{types → type}/Fee.sol +33 -23
  375. package/contracts/{types → type}/NftId.sol +18 -12
  376. package/contracts/type/NftIdSet.sol +62 -0
  377. package/contracts/{types → type}/ObjectType.sol +26 -9
  378. package/contracts/type/PayoutId.sol +82 -0
  379. package/contracts/{types → type}/Referral.sol +5 -1
  380. package/contracts/{types → type}/RiskId.sol +1 -1
  381. package/contracts/type/RoleId.sol +143 -0
  382. package/contracts/type/Seconds.sol +71 -0
  383. package/contracts/{types → type}/StateId.sol +28 -6
  384. package/contracts/{types → type}/Timestamp.sol +18 -13
  385. package/contracts/{types → type}/UFixed.sol +1 -0
  386. package/contracts/{types → type}/Version.sol +6 -2
  387. package/package.json +3 -3
  388. package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +0 -4
  389. package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +0 -4
  390. package/artifacts/contracts/components/Distribution.sol/Distribution.json +0 -610
  391. package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +0 -4
  392. package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.json +0 -267
  393. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +0 -4
  394. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +0 -152
  395. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +0 -4
  396. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +0 -249
  397. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +0 -4
  398. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +0 -157
  399. package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +0 -4
  400. package/artifacts/contracts/components/Pool.sol/Pool.json +0 -774
  401. package/artifacts/contracts/components/Product.sol/Product.dbg.json +0 -4
  402. package/artifacts/contracts/components/Product.sol/Product.json +0 -754
  403. package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.dbg.json +0 -4
  404. package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.json +0 -66
  405. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.dbg.json +0 -4
  406. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.json +0 -24
  407. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.dbg.json +0 -4
  408. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.json +0 -42
  409. package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +0 -4
  410. package/artifacts/contracts/experiment/errors/Require.sol/Require.json +0 -105
  411. package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +0 -4
  412. package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +0 -105
  413. package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +0 -4
  414. package/artifacts/contracts/experiment/inheritance/A.sol/A.json +0 -128
  415. package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +0 -4
  416. package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +0 -42
  417. package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +0 -4
  418. package/artifacts/contracts/experiment/inheritance/B.sol/B.json +0 -76
  419. package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +0 -4
  420. package/artifacts/contracts/experiment/inheritance/C.sol/C.json +0 -89
  421. package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +0 -4
  422. package/artifacts/contracts/experiment/inheritance/IA.sol/IA.json +0 -128
  423. package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +0 -4
  424. package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +0 -4
  425. package/artifacts/contracts/experiment/inheritance/IB.sol/IB.json +0 -50
  426. package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +0 -4
  427. package/artifacts/contracts/experiment/inheritance/IC.sol/IC.json +0 -63
  428. package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.dbg.json +0 -4
  429. package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +0 -59
  430. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +0 -4
  431. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.json +0 -124
  432. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +0 -4
  433. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.json +0 -74
  434. package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +0 -4
  435. package/artifacts/contracts/experiment/statemachine/SM.sol/SM.json +0 -124
  436. package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +0 -4
  437. package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.json +0 -207
  438. package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +0 -4
  439. package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.json +0 -10
  440. package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +0 -4
  441. package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.json +0 -10
  442. package/artifacts/contracts/instance/AccessManagedSimple.sol/AccessManagedSimple.dbg.json +0 -4
  443. package/artifacts/contracts/instance/AccessManagerSimple.sol/AccessManagerSimple.dbg.json +0 -4
  444. package/artifacts/contracts/instance/AccessManagerSimple.sol/AccessManagerSimple.json +0 -1119
  445. package/artifacts/contracts/instance/IAccessManagerSimple.sol/IAccessManagerSimple.dbg.json +0 -4
  446. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +0 -4
  447. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +0 -917
  448. package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +0 -4
  449. package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +0 -4
  450. package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.json +0 -113
  451. package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +0 -4
  452. package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +0 -4
  453. package/artifacts/contracts/instance/base/IService.sol/IService.dbg.json +0 -4
  454. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +0 -4
  455. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +0 -502
  456. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +0 -4
  457. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +0 -169
  458. package/artifacts/contracts/instance/base/ServiceBase.sol/ServiceBase.dbg.json +0 -4
  459. package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +0 -4
  460. package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +0 -4
  461. package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.json +0 -10
  462. package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +0 -4
  463. package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +0 -827
  464. package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +0 -4
  465. package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +0 -4
  466. package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.json +0 -446
  467. package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +0 -4
  468. package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +0 -4
  469. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +0 -4
  470. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +0 -107
  471. package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +0 -4
  472. package/artifacts/contracts/test/TestFee.sol/TestFee.json +0 -119
  473. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +0 -4
  474. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +0 -305
  475. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +0 -4
  476. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +0 -116
  477. package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +0 -4
  478. package/artifacts/contracts/test/TestService.sol/TestService.json +0 -600
  479. package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +0 -4
  480. package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +0 -376
  481. package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +0 -4
  482. package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +0 -218
  483. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +0 -4
  484. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +0 -286
  485. package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +0 -4
  486. package/artifacts/contracts/test/Usdc.sol/USDC.json +0 -376
  487. package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +0 -4
  488. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +0 -4
  489. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +0 -174
  490. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +0 -4
  491. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +0 -10
  492. package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +0 -4
  493. package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +0 -4
  494. package/artifacts/contracts/types/Fee.sol/FeeLib.json +0 -257
  495. package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +0 -4
  496. package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +0 -4
  497. package/artifacts/contracts/types/NftId.sol/NftIdLib.json +0 -153
  498. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +0 -4
  499. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.json +0 -10
  500. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +0 -4
  501. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.json +0 -100
  502. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +0 -4
  503. package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +0 -4
  504. package/artifacts/contracts/types/Referral.sol/ReferralLib.json +0 -123
  505. package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +0 -4
  506. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +0 -4
  507. package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +0 -4
  508. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +0 -4
  509. package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +0 -4
  510. package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +0 -4
  511. package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +0 -4
  512. package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +0 -4
  513. package/artifacts/contracts/types/Version.sol/VersionPartLib.json +0 -30
  514. package/contracts/components/BaseComponent.sol +0 -86
  515. package/contracts/components/Distribution.sol +0 -166
  516. package/contracts/components/IBaseComponent.sol +0 -24
  517. package/contracts/components/IDistributionComponent.sol +0 -43
  518. package/contracts/components/IPoolComponent.sol +0 -62
  519. package/contracts/components/IProductComponent.sol +0 -35
  520. package/contracts/components/Pool.sol +0 -259
  521. package/contracts/components/Product.sol +0 -297
  522. package/contracts/experiment/cloning/Cloner.sol +0 -47
  523. package/contracts/experiment/errors/Require.sol +0 -38
  524. package/contracts/experiment/errors/Revert.sol +0 -44
  525. package/contracts/experiment/inheritance/A.sol +0 -53
  526. package/contracts/experiment/inheritance/B.sol +0 -28
  527. package/contracts/experiment/inheritance/C.sol +0 -34
  528. package/contracts/experiment/inheritance/IA.sol +0 -13
  529. package/contracts/experiment/inheritance/IB.sol +0 -10
  530. package/contracts/experiment/inheritance/IC.sol +0 -12
  531. package/contracts/experiment/statemachine/Dummy.sol +0 -27
  532. package/contracts/experiment/statemachine/ISM.sol +0 -25
  533. package/contracts/experiment/statemachine/SM.sol +0 -57
  534. package/contracts/experiment/statemachine/SimpleStateMachine.sol +0 -31
  535. package/contracts/experiment/types/TypeA.sol +0 -47
  536. package/contracts/experiment/types/TypeB.sol +0 -29
  537. package/contracts/instance/AccessManagedSimple.sol +0 -114
  538. package/contracts/instance/IAccessManagerSimple.sol +0 -391
  539. package/contracts/instance/InstanceAccessManager.sol +0 -288
  540. package/contracts/instance/base/ComponentServiceBase.sol +0 -49
  541. package/contracts/instance/base/IInstanceBase.sol +0 -23
  542. package/contracts/instance/base/IService.sol +0 -15
  543. package/contracts/instance/base/KeyValueStore.sol +0 -172
  544. package/contracts/instance/base/ServiceBase.sol +0 -44
  545. package/contracts/instance/module/ISetup.sol +0 -43
  546. package/contracts/instance/module/ITreasury.sol +0 -23
  547. package/contracts/instance/service/ComponentOwnerService.sol +0 -317
  548. package/contracts/instance/service/IComponentOwnerService.sol +0 -20
  549. package/contracts/instance/service/IDistributionService.sol +0 -12
  550. package/contracts/instance/service/IPoolService.sol +0 -37
  551. package/contracts/instance/service/IProductService.sol +0 -107
  552. package/contracts/shared/ContractDeployerLib.sol +0 -72
  553. package/contracts/test/TestFee.sol +0 -25
  554. package/contracts/test/TestRegisterable.sol +0 -18
  555. package/contracts/test/TestRoleId.sol +0 -14
  556. package/contracts/test/TestService.sol +0 -26
  557. package/contracts/test/TestToken.sol +0 -26
  558. package/contracts/test/TestVersion.sol +0 -44
  559. package/contracts/test/TestVersionable.sol +0 -17
  560. package/contracts/types/ChainId.sol +0 -38
  561. package/contracts/types/NftIdSet.sol +0 -60
  562. package/contracts/types/NumberId.sol +0 -52
  563. package/contracts/types/RoleId.sol +0 -82
  564. /package/contracts/{types → type}/Key32.sol +0 -0
@@ -0,0 +1,331 @@
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 LogStakingStoreStakesIncreased(NftId nftId, Amount addedAmount, Amount newBalance, Blocknumber lastUpdatedIn);
39
+ event LogStakingStoreStakesDecreased(NftId nftId, Amount addedAmount, Amount newBalance, Blocknumber lastUpdatedIn);
40
+
41
+ event LogStakingStoreRewardsIncreased(NftId nftId, Amount addedAmount, Amount newBalance, Blocknumber lastUpdatedIn);
42
+ event LogStakingStoreRewardsDecreased(NftId nftId, Amount addedAmount, Amount newBalance, Blocknumber lastUpdatedIn);
43
+
44
+ event LogStakingStoreRewardsRestaked(NftId nftId, Amount amount, Amount rewardAmount, Amount rewardIncrementAmount, Amount newBalance, Blocknumber lastUpdatedIn);
45
+
46
+ // creating and updating of balance
47
+ error ErrorStakingStoreBalanceAlreadyInitialized(NftId nftId);
48
+ error ErrorStakingStoreBalanceNotInitialized(NftId nftId);
49
+
50
+ // update balance
51
+ // TODO _registry is not used
52
+ IRegistry private _registry;
53
+ NftIdSetManager private _targetManager;
54
+ StakingReader private _reader;
55
+
56
+ mapping(NftId nftId => Amount stakes) private _stakeBalance;
57
+ mapping(NftId nftId => Amount rewards) private _rewardBalance;
58
+
59
+ // TODO check if this is made redundant by *Info struct updates
60
+ mapping(NftId nftId => Timestamp lastUpdatedAt) private _lastUpdatedAt;
61
+ mapping(NftId nftId => Blocknumber lastUpdatedIn) private _lastUpdatedIn;
62
+
63
+
64
+ constructor(IRegistry registry, StakingReader reader)
65
+ AccessManaged(msg.sender)
66
+ {
67
+ _registry = registry; //TODO if keeps registry -> RegistryLinked and checks registry address
68
+ address authority = _registry.getAuthority();
69
+ setAuthority(authority);
70
+
71
+ _reader = reader;
72
+ _targetManager = new NftIdSetManager();
73
+ }
74
+
75
+
76
+ //--- target specific functions ------------------------------------//
77
+
78
+ function createTarget(
79
+ NftId targetNftId,
80
+ IStaking.TargetInfo memory targetInfo
81
+ )
82
+ external
83
+ {
84
+ _create(
85
+ targetNftId.toKey32(TARGET()),
86
+ abi.encode(targetInfo));
87
+
88
+ _createBalance(targetNftId, AmountLib.zero());
89
+ _targetManager.add(targetNftId);
90
+ }
91
+
92
+
93
+ function updateTarget(
94
+ NftId targetNftId,
95
+ IStaking.TargetInfo memory targetInfo
96
+ )
97
+ external
98
+ {
99
+ _update(
100
+ targetNftId.toKey32(TARGET()),
101
+ abi.encode(targetInfo), KEEP_STATE());
102
+ }
103
+
104
+ //--- stake specific functions -------------------------------------//
105
+
106
+ function create(
107
+ NftId stakeNftId,
108
+ IStaking.StakeInfo memory stakeInfo,
109
+ Amount stakeAmount
110
+ )
111
+ external
112
+ {
113
+ _create(
114
+ stakeNftId.toKey32(STAKE()),
115
+ abi.encode(stakeInfo));
116
+
117
+ _createBalance(stakeNftId, stakeAmount);
118
+ }
119
+
120
+ function update(
121
+ NftId stakeNftId,
122
+ IStaking.StakeInfo memory stakeInfo
123
+ )
124
+ external
125
+ {
126
+ _update(
127
+ stakeNftId.toKey32(STAKE()),
128
+ abi.encode(stakeInfo),
129
+ KEEP_STATE());
130
+ }
131
+
132
+ //--- general functions --------------------------------------------//
133
+
134
+
135
+ function increaseBalance(NftId nftId, Amount amount, Amount rewardIncrementAmount)
136
+ external
137
+ {
138
+ Blocknumber lastUpdatedIn = _lastUpdatedIn[nftId];
139
+ bool updated = false;
140
+
141
+ if (lastUpdatedIn.eqz()) {
142
+ revert ErrorStakingStoreBalanceNotInitialized(nftId);
143
+ }
144
+
145
+ // update stake balance with amount
146
+ if(amount.gtz()) {
147
+ updated = true;
148
+ _stakeBalance[nftId] = _stakeBalance[nftId] + amount;
149
+ emit LogStakingStoreStakesIncreased(nftId, amount, _stakeBalance[nftId], lastUpdatedIn);
150
+ }
151
+
152
+ // update reward balance with amount
153
+ if(rewardIncrementAmount.gtz()) {
154
+ updated = true;
155
+ _rewardBalance[nftId] = _rewardBalance[nftId] + rewardIncrementAmount;
156
+ emit LogStakingStoreRewardsIncreased(nftId, rewardIncrementAmount, _rewardBalance[nftId], lastUpdatedIn);
157
+ }
158
+
159
+ if (updated) {
160
+ _lastUpdatedAt[nftId] = TimestampLib.blockTimestamp();
161
+ _lastUpdatedIn[nftId] = BlocknumberLib.currentBlocknumber();
162
+ }
163
+ }
164
+
165
+
166
+ function restakeRewards(
167
+ NftId nftId,
168
+ Amount rewardIncrementAmount
169
+ )
170
+ external
171
+ {
172
+ Blocknumber lastUpdatedIn = _lastUpdatedIn[nftId];
173
+ Amount stakeAmount = _stakeBalance[nftId];
174
+ Amount rewardAmount = _rewardBalance[nftId];
175
+
176
+ if (lastUpdatedIn.eqz()) {
177
+ revert ErrorStakingStoreBalanceNotInitialized(nftId);
178
+ }
179
+
180
+ // move all rewards to stake balance
181
+ _stakeBalance[nftId] = stakeAmount + rewardAmount + rewardIncrementAmount;
182
+ _rewardBalance[nftId] = AmountLib.zero();
183
+
184
+ _lastUpdatedAt[nftId] = TimestampLib.blockTimestamp();
185
+ _lastUpdatedIn[nftId] = BlocknumberLib.currentBlocknumber();
186
+
187
+ emit LogStakingStoreRewardsRestaked(nftId, stakeAmount, rewardAmount, rewardIncrementAmount, _stakeBalance[nftId], lastUpdatedIn);
188
+ }
189
+
190
+
191
+ function updateRewards(
192
+ NftId nftId,
193
+ Amount rewardIncrementAmount
194
+ )
195
+ external
196
+ {
197
+ Blocknumber lastUpdatedIn = _lastUpdatedIn[nftId];
198
+ Amount rewardAmount = _rewardBalance[nftId];
199
+
200
+ if (lastUpdatedIn.eqz()) {
201
+ revert ErrorStakingStoreBalanceNotInitialized(nftId);
202
+ }
203
+
204
+ // move all rewards to stake balance
205
+ _rewardBalance[nftId] = rewardAmount + rewardIncrementAmount;
206
+
207
+ _lastUpdatedAt[nftId] = TimestampLib.blockTimestamp();
208
+ _lastUpdatedIn[nftId] = BlocknumberLib.currentBlocknumber();
209
+
210
+ emit LogStakingStoreRewardsIncreased(nftId, rewardIncrementAmount, _rewardBalance[nftId], lastUpdatedIn);
211
+ }
212
+
213
+
214
+ function claimUpTo(
215
+ NftId nftId,
216
+ Amount maxRewardAmount
217
+ )
218
+ external
219
+ returns (Amount rewardsClaimedAmount)
220
+ {
221
+ Blocknumber lastUpdatedIn = _lastUpdatedIn[nftId];
222
+ bool updated = false;
223
+
224
+ if (lastUpdatedIn.eqz()) {
225
+ revert ErrorStakingStoreBalanceNotInitialized(nftId);
226
+ }
227
+
228
+ // determine the claimable rewards amount
229
+ if (maxRewardAmount > _rewardBalance[nftId]) {
230
+ rewardsClaimedAmount = _rewardBalance[nftId];
231
+ } else {
232
+ rewardsClaimedAmount = maxRewardAmount;
233
+ }
234
+
235
+ // decrease reward amount
236
+ _rewardBalance[nftId] = _rewardBalance[nftId] - rewardsClaimedAmount;
237
+
238
+ _lastUpdatedAt[nftId] = TimestampLib.blockTimestamp();
239
+ _lastUpdatedIn[nftId] = BlocknumberLib.currentBlocknumber();
240
+
241
+ emit LogStakingStoreRewardsDecreased(nftId, rewardsClaimedAmount, _rewardBalance[nftId], lastUpdatedIn);
242
+ }
243
+
244
+
245
+ function unstakeUpTo(
246
+ NftId nftId,
247
+ Amount maxUnstakeAmount,
248
+ Amount maxClaimAmount
249
+ )
250
+ external
251
+ returns (
252
+ Amount unstakedAmount,
253
+ Amount claimedAmount
254
+ )
255
+ {
256
+ Blocknumber lastUpdatedIn = _lastUpdatedIn[nftId];
257
+ bool updated = false;
258
+
259
+ if (lastUpdatedIn.eqz()) {
260
+ revert ErrorStakingStoreBalanceNotInitialized(nftId);
261
+ }
262
+
263
+ // determine the unstakeable amount
264
+ if (maxUnstakeAmount > _rewardBalance[nftId]) {
265
+ unstakedAmount = _rewardBalance[nftId];
266
+ } else {
267
+ unstakedAmount = maxUnstakeAmount;
268
+ }
269
+
270
+ // determine the claimable rewards amount
271
+ if (maxClaimAmount > _rewardBalance[nftId]) {
272
+ claimedAmount = _rewardBalance[nftId];
273
+ } else {
274
+ claimedAmount = maxClaimAmount;
275
+ }
276
+
277
+ // decrease amounts
278
+ _stakeBalance[nftId] = _stakeBalance[nftId] - unstakedAmount;
279
+ _rewardBalance[nftId] = _rewardBalance[nftId] - claimedAmount;
280
+
281
+ _lastUpdatedAt[nftId] = TimestampLib.blockTimestamp();
282
+ _lastUpdatedIn[nftId] = BlocknumberLib.currentBlocknumber();
283
+
284
+ emit LogStakingStoreStakesDecreased(nftId, unstakedAmount, _stakeBalance[nftId], lastUpdatedIn);
285
+ emit LogStakingStoreRewardsDecreased(nftId, claimedAmount, _rewardBalance[nftId], lastUpdatedIn);
286
+ }
287
+
288
+ //--- view functions -----------------------------------------------//
289
+
290
+ function getStakingReader() external view returns (StakingReader stakingReader){
291
+ return _reader;
292
+ }
293
+
294
+ function getTargetManager() external view returns (NftIdSetManager targetManager){
295
+ return _targetManager;
296
+ }
297
+
298
+ function exists(NftId stakeNftId) external view returns (bool) {
299
+ return exists(stakeNftId.toKey32(STAKE()));
300
+ }
301
+
302
+ function getStakeBalance(NftId nftId) external view returns (Amount balanceAmount) { return _stakeBalance[nftId]; }
303
+ function getRewardBalance(NftId nftId) external view returns (Amount rewardAmount) { return _rewardBalance[nftId]; }
304
+ function getBalanceUpdatedAt(NftId nftId) external view returns (Timestamp updatedAt) { return _lastUpdatedAt[nftId]; }
305
+
306
+ function getBalanceAndLastUpdatedAt(NftId nftId)
307
+ external
308
+ view
309
+ returns (
310
+ Amount stakeBalance,
311
+ Timestamp lastUpdatedAt
312
+ )
313
+ {
314
+ stakeBalance = _stakeBalance[nftId];
315
+ lastUpdatedAt = _lastUpdatedAt[nftId];
316
+ }
317
+
318
+ //--- private functions -------------------------------------------//
319
+
320
+ function _createBalance(NftId nftId, Amount amount) private {
321
+ if (_lastUpdatedIn[nftId].gtz()) {
322
+ revert ErrorStakingStoreBalanceAlreadyInitialized(nftId);
323
+ }
324
+
325
+ _stakeBalance[nftId] = amount;
326
+ _rewardBalance[nftId] = AmountLib.zero();
327
+
328
+ _lastUpdatedAt[nftId] = TimestampLib.blockTimestamp();
329
+ _lastUpdatedIn[nftId] = BlocknumberLib.currentBlocknumber();
330
+ }
331
+ }
@@ -0,0 +1,179 @@
1
+ // SPDX-License-Identifier: Apache-2.0
2
+ pragma solidity ^0.8.20;
3
+
4
+ import {Amount, AmountLib} from "../type/Amount.sol";
5
+ import {Component} from "../shared/Component.sol";
6
+ import {IRegistry} from "../registry/IRegistry.sol";
7
+ import {IRegistryService} from "../registry/IRegistryService.sol";
8
+ import {IStaking} from "./IStaking.sol";
9
+ import {Key32} from "../type/Key32.sol";
10
+ import {NftId} from "../type/NftId.sol";
11
+ import {ObjectType, INSTANCE, PROTOCOL, TARGET} from "../type/ObjectType.sol";
12
+ import {Seconds, SecondsLib} from "../type/Seconds.sol";
13
+ import {StakingReader} from "./StakingReader.sol";
14
+ import {UFixed, UFixedLib} from "../type/UFixed.sol";
15
+
16
+
17
+ library TargetManagerLib {
18
+
19
+ function updateLockingPeriod(
20
+ IStaking staking,
21
+ NftId targetNftId,
22
+ Seconds lockingPeriod
23
+ )
24
+ external
25
+ view
26
+ returns (
27
+ Seconds oldLockingPeriod,
28
+ IStaking.TargetInfo memory targetInfo
29
+ )
30
+ {
31
+ StakingReader reader = staking.getStakingReader();
32
+
33
+ // check target exists
34
+ if(!reader.isTarget(targetNftId)) {
35
+ revert IStaking.ErrorStakingTargetNotFound(targetNftId);
36
+ }
37
+
38
+ checkLockingPeriod(targetNftId, lockingPeriod);
39
+
40
+ targetInfo = reader.getTargetInfo(targetNftId);
41
+ oldLockingPeriod = targetInfo.lockingPeriod;
42
+
43
+ targetInfo.lockingPeriod = lockingPeriod;
44
+ }
45
+
46
+
47
+ function updateRewardRate(
48
+ IStaking staking,
49
+ NftId targetNftId,
50
+ UFixed rewardRate
51
+ )
52
+ external
53
+ view
54
+ returns (
55
+ UFixed oldRewardRate,
56
+ IStaking.TargetInfo memory targetInfo
57
+ )
58
+ {
59
+ StakingReader reader = staking.getStakingReader();
60
+
61
+ // check target exists
62
+ if(!reader.isTarget(targetNftId)) {
63
+ revert IStaking.ErrorStakingTargetNotFound(targetNftId);
64
+ }
65
+
66
+ checkRewardRate(targetNftId, rewardRate);
67
+
68
+ targetInfo = reader.getTargetInfo(targetNftId);
69
+ oldRewardRate = targetInfo.rewardRate;
70
+
71
+ targetInfo.rewardRate = rewardRate;
72
+ }
73
+
74
+
75
+ function checkTargetParameters(
76
+ IRegistry registry,
77
+ StakingReader stakingReader,
78
+ NftId targetNftId,
79
+ ObjectType expectedObjectType,
80
+ Seconds initialLockingPeriod,
81
+ UFixed initialRewardRate
82
+ )
83
+ external
84
+ view
85
+ {
86
+ // target nft id must not be zero
87
+ if (targetNftId.eqz()) {
88
+ revert IStaking.ErrorStakingTargetNftIdZero();
89
+ }
90
+
91
+ // only accept "new" targets to be registered
92
+ if (stakingReader.isTarget(targetNftId)) {
93
+ revert IStaking.ErrorStakingTargetAlreadyRegistered(targetNftId);
94
+ }
95
+
96
+ // target object type must be allowed
97
+ if (!isTargetTypeSupported(expectedObjectType)) {
98
+ revert IStaking.ErrorStakingTargetTypeNotSupported(targetNftId, expectedObjectType);
99
+ }
100
+
101
+ checkLockingPeriod(targetNftId, initialLockingPeriod);
102
+ checkRewardRate(targetNftId, initialRewardRate);
103
+
104
+ // target nft id must be known and registered with the expected object type
105
+ if (!registry.isRegistered(targetNftId)) {
106
+ revert IStaking.ErrorStakingTargetNotFound(targetNftId);
107
+ } else {
108
+ // check that expected object type matches with registered object type
109
+ ObjectType actualObjectType = registry.getObjectInfo(targetNftId).objectType;
110
+ if (actualObjectType != expectedObjectType) {
111
+ revert IStaking.ErrorStakingTargetUnexpectedObjectType(targetNftId, expectedObjectType, actualObjectType);
112
+ }
113
+ }
114
+ }
115
+
116
+
117
+ function isTargetTypeSupported(ObjectType objectType)
118
+ public
119
+ pure
120
+ returns (bool isSupported)
121
+ {
122
+ if(objectType == PROTOCOL()) { return true; }
123
+ if(objectType == INSTANCE()) { return true; }
124
+
125
+ return false;
126
+ }
127
+
128
+
129
+ function checkLockingPeriod(NftId targetNftId, Seconds lockingPeriod)
130
+ public
131
+ pure
132
+ {
133
+ // check locking period is > 0
134
+ if (lockingPeriod.eqz()) {
135
+ revert IStaking.ErrorStakingLockingPeriodZero(targetNftId);
136
+ }
137
+
138
+ // check locking period <= max locking period
139
+ if (lockingPeriod > getMaxLockingPeriod()) {
140
+ revert IStaking.ErrorStakingLockingPeriodTooLong(targetNftId, getMaxLockingPeriod(), lockingPeriod);
141
+ }
142
+ }
143
+
144
+
145
+ function checkRewardRate(NftId targetNftId, UFixed rewardRate)
146
+ public
147
+ pure
148
+ {
149
+ // check reward rate <= max reward rate
150
+ if (rewardRate > getMaxRewardRate()) {
151
+ revert IStaking.ErrorStakingRewardRateTooHigh(targetNftId, getMaxRewardRate(), rewardRate);
152
+ }
153
+ }
154
+
155
+
156
+ function getMaxLockingPeriod() public pure returns (Seconds maxLockingPeriod) {
157
+ return SecondsLib.toSeconds(5 * 365 * 24 * 3600);
158
+ }
159
+
160
+
161
+ function getDefaultLockingPeriod() public pure returns (Seconds maxLockingPeriod) {
162
+ return SecondsLib.toSeconds(365 * 24 * 3600 / 2);
163
+ }
164
+
165
+
166
+ function getMaxRewardRate() public pure returns (UFixed maxRewardRate) {
167
+ return UFixedLib.toUFixed(33, -2);
168
+ }
169
+
170
+
171
+ function getDefaultRewardRate() public pure returns (UFixed defaultRewardRate) {
172
+ return UFixedLib.toUFixed(5, -2);
173
+ }
174
+
175
+
176
+ function toTargetKey(NftId targetNftId) public pure returns (Key32 targetKey) {
177
+ return targetNftId.toKey32(TARGET());
178
+ }
179
+ }
@@ -1,5 +1,5 @@
1
1
  // SPDX-License-Identifier: Apache-2.0
2
- pragma solidity ^0.8.19;
2
+ pragma solidity ^0.8.20;
3
3
 
4
4
  // based on https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/utils/structs/EnumerableSet.sol
5
5
  library LibAddressSet {
@@ -0,0 +1,114 @@
1
+ // SPDX-License-Identifier: Apache-2.0
2
+ pragma solidity ^0.8.20;
3
+
4
+ import {UFixed, UFixedLib} from "./UFixed.sol";
5
+
6
+ type Amount is uint96;
7
+
8
+ using {
9
+ addAmount as +,
10
+ subAmount as -,
11
+ eqAmount as ==,
12
+ nqAmount as !=,
13
+ ltAmount as <,
14
+ gtAmount as >,
15
+ AmountLib.eq,
16
+ AmountLib.eqz,
17
+ AmountLib.gtz,
18
+ AmountLib.toInt,
19
+ AmountLib.add,
20
+ AmountLib.toUFixed
21
+ } for Amount global;
22
+
23
+ function addAmount(Amount a, Amount b) pure returns (Amount) {
24
+ return AmountLib.add(a, b);
25
+ }
26
+
27
+ function subAmount(Amount a, Amount b) pure returns (Amount) {
28
+ return AmountLib.sub(a, b);
29
+ }
30
+
31
+ function eqAmount(Amount a, Amount b) pure returns (bool) {
32
+ return AmountLib.eq(a, b);
33
+ }
34
+
35
+ function nqAmount(Amount a, Amount b) pure returns (bool) {
36
+ return !AmountLib.eq(a, b);
37
+ }
38
+
39
+ function ltAmount(Amount a, Amount b) pure returns (bool) {
40
+ return AmountLib.lt(a, b);
41
+ }
42
+
43
+ function gtAmount(Amount a, Amount b) pure returns (bool) {
44
+ return AmountLib.gt(a, b);
45
+ }
46
+
47
+ library AmountLib {
48
+
49
+ error ErrorAmountLibValueTooBig(uint256 amount);
50
+
51
+ function zero() public pure returns (Amount) {
52
+ return Amount.wrap(0);
53
+ }
54
+
55
+ function max() public pure returns (Amount) {
56
+ return Amount.wrap(_max());
57
+ }
58
+
59
+ /// @dev converts the uint amount into Amount
60
+ /// function reverts if value is exceeding max Amount value
61
+ function toAmount(uint256 amount) public pure returns (Amount) {
62
+ if(amount > _max()) {
63
+ revert ErrorAmountLibValueTooBig(amount);
64
+ }
65
+
66
+ return Amount.wrap(uint96(amount));
67
+ }
68
+
69
+ /// @dev return true if amount equals 0
70
+ function eqz(Amount amount) public pure returns (bool) {
71
+ return Amount.unwrap(amount) == 0;
72
+ }
73
+
74
+ /// @dev return true if amount1 equals amount2
75
+ function eq(Amount amount1, Amount amount2) public pure returns (bool) {
76
+ return Amount.unwrap(amount1) == Amount.unwrap(amount2);
77
+ }
78
+
79
+ /// @dev return true if amount a1 is smaller than a2
80
+ function lt(Amount a1, Amount a2) public pure returns (bool) {
81
+ return Amount.unwrap(a1) < Amount.unwrap(a2);
82
+ }
83
+
84
+ /// @dev return true if amount a1 is larger than a2
85
+ function gt(Amount a1, Amount a2) public pure returns (bool) {
86
+ return Amount.unwrap(a1) > Amount.unwrap(a2);
87
+ }
88
+
89
+ /// @dev return true if amount is larger than 0
90
+ function gtz(Amount amount) public pure returns (bool) {
91
+ return Amount.unwrap(amount) > 0;
92
+ }
93
+
94
+ function add(Amount a1, Amount a2) public pure returns (Amount) {
95
+ return Amount.wrap(Amount.unwrap(a1) + Amount.unwrap(a2));
96
+ }
97
+
98
+ function sub(Amount a1, Amount a2) public pure returns (Amount) {
99
+ return Amount.wrap(Amount.unwrap(a1) - Amount.unwrap(a2));
100
+ }
101
+
102
+ function toInt(Amount amount) public pure returns (uint256) {
103
+ return uint256(uint96(Amount.unwrap(amount)));
104
+ }
105
+
106
+ function toUFixed(Amount amount) public pure returns (UFixed) {
107
+ return UFixedLib.toUFixed(Amount.unwrap(amount));
108
+ }
109
+
110
+ function _max() internal pure returns (uint96) {
111
+ // IMPORTANT: type nees to match with actual definition for Amount
112
+ return type(uint96).max;
113
+ }
114
+ }
@@ -1,5 +1,5 @@
1
1
  // SPDX-License-Identifier: Apache-2.0
2
- pragma solidity ^0.8.19;
2
+ pragma solidity ^0.8.20;
3
3
 
4
4
  type Blocknumber is uint32;
5
5
 
@@ -10,7 +10,9 @@ using {
10
10
  lteBlocknumber as <=,
11
11
  eqBlocknumber as ==,
12
12
  neBlocknumber as !=,
13
- BlocknumberLib.toInt
13
+ BlocknumberLib.toInt,
14
+ BlocknumberLib.eqz,
15
+ BlocknumberLib.gtz
14
16
  } for Blocknumber global;
15
17
 
16
18
  /// @dev return true if Blocknumber a is greater than Blocknumber b
@@ -49,9 +51,10 @@ function toBlocknumber(uint256 blocknum) pure returns (Blocknumber) {
49
51
  }
50
52
 
51
53
  function blockBlocknumber() view returns (Blocknumber) {
52
- return toBlocknumber(block.number);
54
+ return BlocknumberLib.currentBlocknumber();
53
55
  }
54
56
 
57
+ // TODO move to BlocknumberLib and rename to zero()
55
58
  /// @dev Return the Blocknumber zero (0)
56
59
  function zeroBlocknumber() pure returns (Blocknumber) {
57
60
  return toBlocknumber(0);
@@ -63,6 +66,21 @@ function blockNumber() view returns (Blocknumber) {
63
66
  }
64
67
 
65
68
  library BlocknumberLib {
69
+ /// @dev returns the current Blocknumber
70
+ function currentBlocknumber() public view returns (Blocknumber) {
71
+ return Blocknumber.wrap(uint32(block.number));
72
+ }
73
+
74
+ /// @dev return true iff blocknumber is 0
75
+ function eqz(Blocknumber blocknumber) public pure returns (bool) {
76
+ return Blocknumber.unwrap(blocknumber) == 0;
77
+ }
78
+
79
+ /// @dev return true iff blocknumber is 0
80
+ function gtz(Blocknumber blocknumber) public pure returns (bool) {
81
+ return Blocknumber.unwrap(blocknumber) > 0;
82
+ }
83
+
66
84
  /// @dev return true if Blocknumber a is greater than Blocknumber b
67
85
  function gt(
68
86
  Blocknumber a,