@etherisc/gif-next 0.0.2-7f39e38-904 → 0.0.2-7fe9ae1-227

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 (598) hide show
  1. package/README.md +136 -318
  2. package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.dbg.json +4 -0
  3. package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.json +1075 -0
  4. package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.dbg.json +4 -0
  5. package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.json +810 -0
  6. package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.dbg.json +4 -0
  7. package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.json +843 -0
  8. package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +4 -0
  9. package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +1735 -0
  10. package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.dbg.json +4 -0
  11. package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.json +2008 -0
  12. package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.dbg.json +4 -0
  13. package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.json +1403 -0
  14. package/artifacts/contracts/authorization/Authorization.sol/Authorization.dbg.json +4 -0
  15. package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +817 -0
  16. package/artifacts/contracts/authorization/IAccess.sol/IAccess.dbg.json +4 -0
  17. package/artifacts/contracts/authorization/IAccess.sol/IAccess.json +10 -0
  18. package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.dbg.json +4 -0
  19. package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.json +1400 -0
  20. package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +4 -0
  21. package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +465 -0
  22. package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +4 -0
  23. package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.json +407 -0
  24. package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +4 -0
  25. package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +652 -0
  26. package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +4 -0
  27. package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +1234 -0
  28. package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +4 -0
  29. package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +844 -0
  30. package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
  31. package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +146 -617
  32. package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
  33. package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +767 -301
  34. package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
  35. package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +267 -116
  36. package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
  37. package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +152 -283
  38. package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
  39. package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +553 -77
  40. package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.dbg.json +4 -0
  41. package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.json +22 -0
  42. package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.dbg.json +4 -0
  43. package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.json +1474 -0
  44. package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +4 -0
  45. package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +844 -0
  46. package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +4 -0
  47. package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +2043 -0
  48. package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +4 -0
  49. package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +844 -0
  50. package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.dbg.json +4 -0
  51. package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.json +376 -0
  52. package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.dbg.json +4 -0
  53. package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.json +1429 -0
  54. package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.dbg.json +4 -0
  55. package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.json +844 -0
  56. package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +4 -0
  57. package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +1161 -0
  58. package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +4 -0
  59. package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +1637 -0
  60. package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.dbg.json +4 -0
  61. package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.json +844 -0
  62. package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +4 -0
  63. package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +2575 -0
  64. package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.dbg.json +4 -0
  65. package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.json +844 -0
  66. package/artifacts/contracts/instance/BaseStore.sol/BaseStore.dbg.json +4 -0
  67. package/artifacts/contracts/{shared/IKeyValueStore.sol/IKeyValueStore.json → instance/BaseStore.sol/BaseStore.json} +59 -205
  68. package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +4 -0
  69. package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +851 -0
  70. package/artifacts/contracts/instance/IBaseStore.sol/IBaseStore.dbg.json +4 -0
  71. package/artifacts/contracts/instance/IBaseStore.sol/IBaseStore.json +304 -0
  72. package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
  73. package/artifacts/contracts/instance/IInstance.sol/IInstance.json +614 -92
  74. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
  75. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +517 -75
  76. package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
  77. package/artifacts/contracts/instance/Instance.sol/Instance.json +639 -237
  78. package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +4 -0
  79. package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +2400 -0
  80. package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +4 -0
  81. package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +872 -0
  82. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
  83. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +1711 -755
  84. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
  85. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +509 -224
  86. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
  87. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +175 -98
  88. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
  89. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +1482 -1911
  90. package/artifacts/contracts/instance/ProductStore.sol/ProductStore.dbg.json +4 -0
  91. package/artifacts/contracts/instance/ProductStore.sol/ProductStore.json +3427 -0
  92. package/artifacts/contracts/instance/RiskSet.sol/RiskSet.dbg.json +4 -0
  93. package/artifacts/contracts/instance/RiskSet.sol/RiskSet.json +866 -0
  94. package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +1 -1
  95. package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +8 -8
  96. package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +1 -1
  97. package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.json +0 -53
  98. package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +4 -0
  99. package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +10 -0
  100. package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.dbg.json +4 -0
  101. package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.json +223 -0
  102. package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.dbg.json +4 -0
  103. package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.json +192 -0
  104. package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.dbg.json +4 -0
  105. package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.json +168 -0
  106. package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
  107. package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +1 -1
  108. package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
  109. package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
  110. package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
  111. package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +1 -1
  112. package/artifacts/contracts/mock/Dip.sol/Dip.json +2 -2
  113. package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.dbg.json +4 -0
  114. package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.json +947 -0
  115. package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +4 -0
  116. package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +849 -0
  117. package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +4 -0
  118. package/artifacts/contracts/oracle/IOracle.sol/IOracle.json +52 -0
  119. package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +4 -0
  120. package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +762 -0
  121. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +4 -0
  122. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +762 -0
  123. package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +4 -0
  124. package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +863 -0
  125. package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +4 -0
  126. package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +1042 -0
  127. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +4 -0
  128. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +830 -0
  129. package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +4 -0
  130. package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +1232 -0
  131. package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +4 -0
  132. package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +844 -0
  133. package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
  134. package/artifacts/contracts/pool/BundleService.sol/BundleService.json +582 -235
  135. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
  136. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +257 -94
  137. package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
  138. package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +398 -49
  139. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
  140. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +151 -404
  141. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
  142. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +770 -365
  143. package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
  144. package/artifacts/contracts/pool/Pool.sol/Pool.json +148 -692
  145. package/artifacts/contracts/pool/PoolLib.sol/PoolLib.dbg.json +4 -0
  146. package/artifacts/contracts/pool/PoolLib.sol/PoolLib.json +522 -0
  147. package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
  148. package/artifacts/contracts/pool/PoolService.sol/PoolService.json +947 -525
  149. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
  150. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +260 -93
  151. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
  152. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +382 -166
  153. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
  154. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +201 -90
  155. package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +4 -0
  156. package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +1149 -0
  157. package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +4 -0
  158. package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +844 -0
  159. package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
  160. package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +502 -230
  161. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
  162. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +229 -110
  163. package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
  164. package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +320 -9
  165. package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
  166. package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +369 -18
  167. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
  168. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +436 -101
  169. package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
  170. package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +202 -80
  171. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
  172. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +291 -274
  173. package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +4 -0
  174. package/artifacts/contracts/{shared/ComponentVerifyingService.sol/ComponentVerifyingService.json → product/IRiskService.sol/IRiskService.json} +295 -150
  175. package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
  176. package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +564 -292
  177. package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.dbg.json +4 -0
  178. package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.json +783 -0
  179. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
  180. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +239 -96
  181. package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
  182. package/artifacts/contracts/product/PricingService.sol/PricingService.json +262 -299
  183. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
  184. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +193 -114
  185. package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
  186. package/artifacts/contracts/product/Product.sol/Product.json +322 -606
  187. package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +4 -0
  188. package/artifacts/contracts/product/RiskService.sol/RiskService.json +873 -0
  189. package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +4 -0
  190. package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +794 -0
  191. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
  192. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +59 -16
  193. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
  194. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +402 -79
  195. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
  196. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +125 -146
  197. package/artifacts/contracts/registry/IRelease.sol/IRelease.dbg.json +4 -0
  198. package/artifacts/contracts/registry/IRelease.sol/IRelease.json +24 -0
  199. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
  200. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +5 -18
  201. package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
  202. package/artifacts/contracts/registry/Registry.sol/Registry.json +719 -120
  203. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +4 -0
  204. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +2255 -0
  205. package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.dbg.json +4 -0
  206. package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.json +1137 -0
  207. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
  208. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +174 -274
  209. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
  210. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +180 -92
  211. package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.dbg.json +4 -0
  212. package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.json +2271 -0
  213. package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +4 -0
  214. package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +205 -0
  215. package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +4 -0
  216. package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +1401 -0
  217. package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +4 -0
  218. package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +705 -0
  219. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
  220. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +135 -67
  221. package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
  222. package/artifacts/contracts/shared/Component.sol/Component.json +92 -287
  223. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
  224. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +632 -542
  225. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
  226. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +230 -113
  227. package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +4 -0
  228. package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +632 -0
  229. package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.dbg.json +4 -0
  230. package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.json +24 -0
  231. package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.dbg.json +4 -0
  232. package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.json +30 -0
  233. package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.dbg.json +4 -0
  234. package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.json +40 -0
  235. package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
  236. package/artifacts/contracts/shared/IComponent.sol/IComponent.json +99 -104
  237. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
  238. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +549 -228
  239. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
  240. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +138 -140
  241. package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +1 -1
  242. package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.json +34 -3
  243. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
  244. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +42 -1
  245. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
  246. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +15 -47
  247. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
  248. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +173 -0
  249. package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
  250. package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
  251. package/artifacts/contracts/shared/IService.sol/IService.json +103 -2
  252. package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.dbg.json +4 -0
  253. package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.json +53 -0
  254. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +1 -1
  255. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +131 -376
  256. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
  257. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +42 -62
  258. package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.dbg.json +4 -0
  259. package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.json +306 -0
  260. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
  261. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +45 -55
  262. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
  263. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +19 -141
  264. package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
  265. package/artifacts/contracts/shared/Registerable.sol/Registerable.json +148 -98
  266. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
  267. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -15
  268. package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
  269. package/artifacts/contracts/shared/Service.sol/Service.json +96 -102
  270. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
  271. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +585 -12
  272. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.dbg.json +4 -0
  273. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.json +484 -0
  274. package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +4 -0
  275. package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +172 -0
  276. package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
  277. package/artifacts/contracts/staking/IStaking.sol/IStaking.json +1558 -246
  278. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
  279. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +382 -119
  280. package/artifacts/contracts/staking/ITargetLimitHandler.sol/ITargetLimitHandler.dbg.json +4 -0
  281. package/artifacts/contracts/staking/ITargetLimitHandler.sol/ITargetLimitHandler.json +50 -0
  282. package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
  283. package/artifacts/contracts/staking/Staking.sol/Staking.json +1734 -561
  284. package/artifacts/contracts/staking/StakingLib.sol/StakingLib.dbg.json +4 -0
  285. package/artifacts/contracts/staking/StakingLib.sol/StakingLib.json +470 -0
  286. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
  287. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +232 -113
  288. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
  289. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +430 -94
  290. package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
  291. package/artifacts/contracts/staking/StakingService.sol/StakingService.json +442 -305
  292. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
  293. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +181 -93
  294. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
  295. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +2044 -637
  296. package/artifacts/contracts/staking/TargetHandler.sol/TargetHandler.dbg.json +4 -0
  297. package/artifacts/contracts/staking/TargetHandler.sol/TargetHandler.json +309 -0
  298. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
  299. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +253 -68
  300. package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +1 -1
  301. package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.json +2 -2
  302. package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +1 -1
  303. package/artifacts/contracts/type/Amount.sol/AmountLib.json +122 -5
  304. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
  305. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +64 -19
  306. package/artifacts/contracts/type/ChainId.sol/ChainIdLib.dbg.json +4 -0
  307. package/artifacts/contracts/type/ChainId.sol/ChainIdLib.json +193 -0
  308. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +1 -1
  309. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +28 -4
  310. package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
  311. package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +4 -4
  312. package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +1 -1
  313. package/artifacts/contracts/type/Fee.sol/FeeLib.json +98 -37
  314. package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +1 -1
  315. package/artifacts/contracts/type/Key32.sol/Key32Lib.json +2 -2
  316. package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.dbg.json +4 -0
  317. package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.json +33 -0
  318. package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
  319. package/artifacts/contracts/type/NftId.sol/NftIdLib.json +47 -4
  320. package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
  321. package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +2 -2
  322. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
  323. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +153 -4
  324. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +1 -1
  325. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +19 -19
  326. package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +1 -1
  327. package/artifacts/contracts/type/Referral.sol/ReferralLib.json +4 -4
  328. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +4 -0
  329. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +204 -0
  330. package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +1 -1
  331. package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +125 -7
  332. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
  333. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +121 -23
  334. package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
  335. package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +117 -2
  336. package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +4 -0
  337. package/artifacts/contracts/type/Selector.sol/SelectorLib.json +148 -0
  338. package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +4 -0
  339. package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +10 -0
  340. package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
  341. package/artifacts/contracts/type/StateId.sol/StateIdLib.json +15 -2
  342. package/artifacts/contracts/type/String.sol/StrLib.dbg.json +4 -0
  343. package/artifacts/contracts/type/String.sol/StrLib.json +180 -0
  344. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
  345. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +37 -5
  346. package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
  347. package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +126 -33
  348. package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +1 -1
  349. package/artifacts/contracts/type/Version.sol/VersionLib.json +2 -21
  350. package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +1 -1
  351. package/artifacts/contracts/type/Version.sol/VersionPartLib.json +120 -2
  352. package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.dbg.json +4 -0
  353. package/artifacts/contracts/{shared → upgradeability}/IVersionable.sol/IVersionable.json +11 -1
  354. package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.dbg.json +4 -0
  355. package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +672 -0
  356. package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +4 -0
  357. package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +142 -0
  358. package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +4 -0
  359. package/artifacts/contracts/{shared → upgradeability}/Versionable.sol/Versionable.json +11 -1
  360. package/contracts/accounting/AccountingService.sol +274 -0
  361. package/contracts/accounting/AccountingServiceManager.sol +38 -0
  362. package/contracts/accounting/IAccountingService.sol +47 -0
  363. package/contracts/authorization/AccessAdmin.sol +679 -0
  364. package/contracts/authorization/AccessAdminLib.sol +678 -0
  365. package/contracts/authorization/AccessManagerCloneable.sol +140 -0
  366. package/contracts/authorization/Authorization.sol +190 -0
  367. package/contracts/authorization/IAccess.sol +66 -0
  368. package/contracts/authorization/IAccessAdmin.sol +142 -0
  369. package/contracts/authorization/IAuthorization.sol +26 -0
  370. package/contracts/authorization/IServiceAuthorization.sol +78 -0
  371. package/contracts/authorization/ServiceAuthorization.sol +300 -0
  372. package/contracts/distribution/BasicDistribution.sol +140 -0
  373. package/contracts/distribution/BasicDistributionAuthorization.sol +67 -0
  374. package/contracts/distribution/Distribution.sol +125 -143
  375. package/contracts/distribution/DistributionService.sol +287 -137
  376. package/contracts/distribution/DistributionServiceManager.sol +8 -23
  377. package/contracts/distribution/IDistributionComponent.sol +21 -42
  378. package/contracts/distribution/IDistributionService.sol +60 -26
  379. package/contracts/examples/fire/DamageLevel.sol +59 -0
  380. package/contracts/examples/fire/FirePool.sol +86 -0
  381. package/contracts/examples/fire/FirePoolAuthorization.sol +35 -0
  382. package/contracts/examples/fire/FireProduct.sol +433 -0
  383. package/contracts/examples/fire/FireProductAuthorization.sol +45 -0
  384. package/contracts/examples/fire/FireUSD.sol +26 -0
  385. package/contracts/examples/unpermissioned/SimpleDistribution.sol +81 -0
  386. package/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol +28 -0
  387. package/contracts/examples/unpermissioned/SimpleOracle.sol +133 -0
  388. package/contracts/examples/unpermissioned/SimplePool.sol +102 -0
  389. package/contracts/examples/unpermissioned/SimplePoolAuthorization.sol +28 -0
  390. package/contracts/examples/unpermissioned/SimpleProduct.sol +437 -0
  391. package/contracts/examples/unpermissioned/SimpleProductAuthorization.sol +28 -0
  392. package/contracts/instance/BaseStore.sol +93 -0
  393. package/contracts/instance/BundleSet.sol +130 -0
  394. package/contracts/instance/IBaseStore.sol +37 -0
  395. package/contracts/instance/IInstance.sol +128 -49
  396. package/contracts/instance/IInstanceService.sol +82 -46
  397. package/contracts/instance/Instance.sol +254 -131
  398. package/contracts/instance/InstanceAdmin.sol +307 -0
  399. package/contracts/instance/InstanceAuthorizationV3.sol +275 -0
  400. package/contracts/instance/InstanceReader.sol +477 -237
  401. package/contracts/instance/InstanceService.sol +391 -244
  402. package/contracts/instance/InstanceServiceManager.sol +8 -13
  403. package/contracts/instance/InstanceStore.sol +172 -109
  404. package/contracts/instance/ProductStore.sol +290 -0
  405. package/contracts/instance/RiskSet.sol +126 -0
  406. package/contracts/instance/TargetNames.sol +10 -0
  407. package/contracts/instance/base/BalanceStore.sol +15 -12
  408. package/contracts/instance/base/Cloneable.sol +2 -25
  409. package/contracts/instance/base/ObjectCounter.sol +20 -0
  410. package/contracts/instance/base/ObjectLifecycle.sol +109 -0
  411. package/contracts/instance/base/ObjectSet.sol +77 -0
  412. package/contracts/instance/base/ObjectSetHelperLib.sol +30 -0
  413. package/contracts/instance/module/IBundle.sol +6 -5
  414. package/contracts/instance/module/IComponents.sol +29 -21
  415. package/contracts/instance/module/IDistribution.sol +21 -9
  416. package/contracts/instance/module/IPolicy.sol +50 -29
  417. package/contracts/instance/module/IRisk.sol +5 -0
  418. package/contracts/mock/Dip.sol +1 -1
  419. package/contracts/oracle/BasicOracle.sol +44 -0
  420. package/contracts/oracle/BasicOracleAuthorization.sol +53 -0
  421. package/contracts/oracle/IOracle.sol +41 -0
  422. package/contracts/oracle/IOracleComponent.sol +33 -0
  423. package/contracts/oracle/IOracleService.sol +66 -0
  424. package/contracts/oracle/Oracle.sol +152 -0
  425. package/contracts/oracle/OracleService.sol +310 -0
  426. package/contracts/oracle/OracleServiceManager.sol +39 -0
  427. package/contracts/pool/BasicPool.sol +161 -0
  428. package/contracts/pool/BasicPoolAuthorization.sol +81 -0
  429. package/contracts/pool/BundleService.sol +225 -135
  430. package/contracts/pool/BundleServiceManager.sol +8 -11
  431. package/contracts/pool/IBundleService.sol +43 -33
  432. package/contracts/pool/IPoolComponent.sol +20 -70
  433. package/contracts/pool/IPoolService.sol +98 -75
  434. package/contracts/pool/Pool.sol +196 -164
  435. package/contracts/pool/PoolLib.sol +341 -0
  436. package/contracts/pool/PoolService.sol +444 -254
  437. package/contracts/pool/PoolServiceManager.sol +6 -9
  438. package/contracts/product/ApplicationService.sol +159 -86
  439. package/contracts/product/ApplicationServiceManager.sol +6 -6
  440. package/contracts/product/BasicProduct.sol +48 -0
  441. package/contracts/product/BasicProductAuthorization.sol +63 -0
  442. package/contracts/product/ClaimService.sol +396 -207
  443. package/contracts/product/ClaimServiceManager.sol +6 -6
  444. package/contracts/product/IApplicationService.sol +29 -3
  445. package/contracts/product/IClaimService.sol +51 -8
  446. package/contracts/product/IPolicyService.sol +61 -37
  447. package/contracts/product/IPricingService.sol +11 -10
  448. package/contracts/product/IProductComponent.sol +29 -9
  449. package/contracts/product/IRiskService.sol +48 -0
  450. package/contracts/product/PolicyService.sol +450 -278
  451. package/contracts/product/PolicyServiceLib.sol +139 -0
  452. package/contracts/product/PolicyServiceManager.sol +6 -9
  453. package/contracts/product/PricingService.sol +95 -90
  454. package/contracts/product/PricingServiceManager.sol +6 -9
  455. package/contracts/product/Product.sol +261 -147
  456. package/contracts/product/RiskService.sol +189 -0
  457. package/contracts/product/RiskServiceManager.sol +39 -0
  458. package/contracts/registry/ChainNft.sol +72 -39
  459. package/contracts/registry/IRegistry.sol +88 -41
  460. package/contracts/registry/IRegistryService.sol +4 -10
  461. package/contracts/registry/IRelease.sol +29 -0
  462. package/contracts/registry/ITransferInterceptor.sol +1 -2
  463. package/contracts/registry/Registry.sol +389 -231
  464. package/contracts/registry/RegistryAdmin.sol +173 -0
  465. package/contracts/registry/RegistryAuthorization.sol +337 -0
  466. package/contracts/registry/RegistryService.sol +50 -75
  467. package/contracts/registry/RegistryServiceManager.sol +5 -24
  468. package/contracts/registry/ReleaseAdmin.sol +199 -0
  469. package/contracts/registry/ReleaseLifecycle.sol +32 -0
  470. package/contracts/registry/ReleaseRegistry.sol +525 -0
  471. package/contracts/registry/ServiceAuthorizationV3.sol +342 -0
  472. package/contracts/registry/TokenRegistry.sol +73 -110
  473. package/contracts/shared/Component.sol +72 -148
  474. package/contracts/shared/ComponentService.sol +466 -370
  475. package/contracts/shared/ComponentServiceManager.sol +10 -7
  476. package/contracts/shared/ContractLib.sol +312 -0
  477. package/contracts/shared/IComponent.sol +7 -23
  478. package/contracts/shared/IComponentService.sol +51 -31
  479. package/contracts/shared/IInstanceLinkedComponent.sol +10 -26
  480. package/contracts/shared/ILifecycle.sol +3 -2
  481. package/contracts/shared/INftOwnable.sol +5 -1
  482. package/contracts/shared/IPolicyHolder.sol +12 -22
  483. package/contracts/shared/IRegisterable.sol +22 -1
  484. package/contracts/shared/IService.sol +10 -5
  485. package/contracts/shared/{ERC165.sol → InitializableERC165.sol} +11 -3
  486. package/contracts/shared/InstanceLinkedComponent.sol +96 -49
  487. package/contracts/shared/Lifecycle.sol +30 -63
  488. package/contracts/shared/{NftIdSetManager.sol → NftIdSet.sol} +1 -1
  489. package/contracts/shared/NftOwnable.sol +35 -24
  490. package/contracts/shared/PolicyHolder.sol +19 -57
  491. package/contracts/shared/Registerable.sol +52 -21
  492. package/contracts/shared/RegistryLinked.sol +9 -14
  493. package/contracts/shared/Service.sol +31 -41
  494. package/contracts/shared/TokenHandler.sol +310 -26
  495. package/contracts/shared/TokenHandlerDeployerLib.sol +20 -0
  496. package/contracts/staking/IStaking.sol +284 -70
  497. package/contracts/staking/IStakingService.sol +59 -94
  498. package/contracts/staking/ITargetLimitHandler.sol +17 -0
  499. package/contracts/staking/Staking.sol +558 -263
  500. package/contracts/staking/StakingLib.sol +195 -0
  501. package/contracts/staking/StakingManager.sol +20 -32
  502. package/contracts/staking/StakingReader.sol +84 -60
  503. package/contracts/staking/StakingService.sol +108 -162
  504. package/contracts/staking/StakingServiceManager.sol +10 -8
  505. package/contracts/staking/StakingStore.sol +1222 -183
  506. package/contracts/staking/TargetHandler.sol +132 -0
  507. package/contracts/staking/TargetManagerLib.sol +95 -40
  508. package/contracts/type/Amount.sol +43 -3
  509. package/contracts/type/Blocknumber.sol +24 -23
  510. package/contracts/type/ChainId.sol +101 -0
  511. package/contracts/type/ClaimId.sol +6 -1
  512. package/contracts/type/Fee.sol +8 -8
  513. package/contracts/type/Key32.sol +2 -2
  514. package/contracts/type/Key32Set.sol +62 -0
  515. package/contracts/type/NftId.sol +15 -8
  516. package/contracts/type/ObjectType.sol +203 -65
  517. package/contracts/type/PayoutId.sol +10 -10
  518. package/contracts/type/Referral.sol +1 -0
  519. package/contracts/type/RequestId.sol +75 -0
  520. package/contracts/type/RiskId.sol +38 -6
  521. package/contracts/type/RoleId.sol +121 -84
  522. package/contracts/type/Seconds.sol +50 -1
  523. package/contracts/type/Selector.sol +107 -0
  524. package/contracts/type/StateId.sol +27 -1
  525. package/contracts/type/String.sol +65 -0
  526. package/contracts/type/Timestamp.sol +20 -9
  527. package/contracts/type/UFixed.sol +62 -125
  528. package/contracts/type/Version.sol +57 -6
  529. package/contracts/{shared → upgradeability}/IVersionable.sol +3 -0
  530. package/contracts/{shared → upgradeability}/ProxyManager.sol +102 -51
  531. package/contracts/upgradeability/UpgradableProxyWithAdmin.sol +24 -0
  532. package/contracts/{shared → upgradeability}/Versionable.sol +8 -5
  533. package/package.json +12 -8
  534. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +0 -4
  535. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +0 -778
  536. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +0 -4
  537. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +0 -1348
  538. package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +0 -4
  539. package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +0 -132
  540. package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +0 -4
  541. package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +0 -256
  542. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +0 -4
  543. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +0 -237
  544. package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +0 -4
  545. package/artifacts/contracts/product/IProductService.sol/IProductService.json +0 -381
  546. package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +0 -4
  547. package/artifacts/contracts/product/ProductService.sol/ProductService.json +0 -673
  548. package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
  549. package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +0 -675
  550. package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +0 -4
  551. package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +0 -322
  552. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +0 -4
  553. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +0 -1151
  554. package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.dbg.json +0 -4
  555. package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.json +0 -137
  556. package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +0 -4
  557. package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +0 -1206
  558. package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +0 -4
  559. package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +0 -4
  560. package/artifacts/contracts/shared/ERC165.sol/ERC165.json +0 -73
  561. package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +0 -4
  562. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +0 -4
  563. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +0 -4
  564. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +0 -581
  565. package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.dbg.json +0 -4
  566. package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.json +0 -306
  567. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +0 -4
  568. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +0 -598
  569. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +0 -4
  570. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +0 -129
  571. package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +0 -4
  572. package/artifacts/contracts/staking/IStakingManager.sol/IStakingManager.dbg.json +0 -4
  573. package/artifacts/contracts/staking/IStakingManager.sol/IStakingManager.json +0 -37
  574. package/artifacts/contracts/staking/IStakingStore.sol/IStakingStore.dbg.json +0 -4
  575. package/artifacts/contracts/staking/IStakingStore.sol/IStakingStore.json +0 -357
  576. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +0 -4
  577. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +0 -402
  578. package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +0 -4
  579. package/artifacts/contracts/type/UFixed.sol/MathLib.json +0 -10
  580. package/contracts/instance/BundleManager.sol +0 -126
  581. package/contracts/instance/InstanceAccessManager.sol +0 -543
  582. package/contracts/instance/InstanceAuthorizationsLib.sol +0 -336
  583. package/contracts/instance/base/ObjectManager.sol +0 -82
  584. package/contracts/instance/module/IAccess.sol +0 -54
  585. package/contracts/product/IProductService.sol +0 -33
  586. package/contracts/product/ProductService.sol +0 -124
  587. package/contracts/product/ProductServiceManager.sol +0 -42
  588. package/contracts/registry/RegistryAccessManager.sol +0 -196
  589. package/contracts/registry/ReleaseManager.sol +0 -563
  590. package/contracts/registry/ServiceAuthorizationsLib.sol +0 -173
  591. package/contracts/shared/AccessManagerUpgradeableInitializeable.sol +0 -13
  592. package/contracts/shared/ComponentVerifyingService.sol +0 -111
  593. package/contracts/shared/IKeyValueStore.sol +0 -53
  594. package/contracts/shared/KeyValueStore.sol +0 -130
  595. package/contracts/shared/UpgradableProxyWithAdmin.sol +0 -16
  596. package/contracts/staking/IStakingManager.sol +0 -15
  597. package/contracts/staking/IStakingStore.sol +0 -130
  598. package/contracts/staking/StakeManagerLib.sol +0 -156
@@ -1,30 +1,35 @@
1
1
  // SPDX-License-Identifier: Apache-2.0
2
2
  pragma solidity ^0.8.20;
3
3
 
4
- import {Amount, AmountLib} from "../type/Amount.sol";
5
- import {ChainNft} from "../registry/ChainNft.sol";
6
- import {Component} from "../shared/Component.sol";
4
+ import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
5
+
7
6
  import {IRegistry} from "../registry/IRegistry.sol";
8
- import {IRegistryService} from "../registry/IRegistryService.sol";
7
+ import {IRelease} from "../registry/IRelease.sol";
9
8
  import {IStaking} from "./IStaking.sol";
10
- import {IVersionable} from "../shared/IVersionable.sol";
11
- import {Key32} from "../type/Key32.sol";
12
- import {KEEP_STATE} from "../type/StateId.sol";
13
- import {LibNftIdSet} from "../type/NftIdSet.sol";
14
- import {NftId, NftIdLib} from "../type/NftId.sol";
15
- import {NftIdSetManager} from "../shared/NftIdSetManager.sol";
16
- import {ObjectType, INSTANCE, PROTOCOL, STAKE, STAKING, TARGET} from "../type/ObjectType.sol";
9
+ import {IStakingService} from "./IStakingService.sol";
10
+ import {ITargetLimitHandler} from "./ITargetLimitHandler.sol";
11
+ import {IVersionable} from "../upgradeability/IVersionable.sol";
12
+
13
+ import {Amount, AmountLib} from "../type/Amount.sol";
14
+ import {Blocknumber} from "../type/Blocknumber.sol";
15
+ import {ChainId, ChainIdLib} from "../type/ChainId.sol";
16
+ import {Component} from "../shared/Component.sol";
17
+ import {IComponent} from "../shared/IComponent.sol";
18
+ import {NftId} from "../type/NftId.sol";
19
+ import {ObjectType, PROTOCOL, INSTANCE, STAKE, STAKING, TARGET} from "../type/ObjectType.sol";
17
20
  import {Seconds, SecondsLib} from "../type/Seconds.sol";
18
- import {StakeManagerLib} from "./StakeManagerLib.sol";
21
+ import {Registerable} from "../shared/Registerable.sol";
22
+ import {StakingLib} from "./StakingLib.sol";
19
23
  import {StakingReader} from "./StakingReader.sol";
20
24
  import {StakingStore} from "./StakingStore.sol";
21
- import {TargetManagerLib} from "./TargetManagerLib.sol";
22
- import {Timestamp, TimestampLib} from "../type/Timestamp.sol";
25
+ import {TargetHandler} from "./TargetHandler.sol";
23
26
  import {TokenHandler} from "../shared/TokenHandler.sol";
27
+ import {TokenHandlerDeployerLib} from "../shared/TokenHandlerDeployerLib.sol";
24
28
  import {TokenRegistry} from "../registry/TokenRegistry.sol";
25
29
  import {UFixed, UFixedLib} from "../type/UFixed.sol";
26
- import {Version, VersionLib} from "../type/Version.sol";
27
- import {Versionable} from "../shared/Versionable.sol";
30
+ import {Version, VersionLib, VersionPart, VersionPartLib} from "../type/Version.sol";
31
+ import {Versionable} from "../upgradeability/Versionable.sol";
32
+
28
33
 
29
34
  contract Staking is
30
35
  Component,
@@ -32,464 +37,755 @@ contract Staking is
32
37
  IStaking
33
38
  {
34
39
  string public constant CONTRACT_NAME = "Staking";
35
- uint8 private constant GIF_MAJOR_VERSION = 3;
36
40
 
37
41
  // keccak256(abi.encode(uint256(keccak256("gif-next.contracts.component.Staking.sol")) - 1)) & ~bytes32(uint256(0xff));
38
42
  bytes32 public constant STAKING_LOCATION_V1 = 0xafe8d4462b2ed26a47154f4b8f6d1497d2f772496965791d25bd456e342b7f00;
39
43
 
40
44
  struct StakingStorage {
41
- IRegistryService _registryService;
42
45
  TokenRegistry _tokenRegistry;
46
+ TokenHandler _tokenHandler;
47
+ IStakingService _stakingService;
48
+ TargetHandler _targetHandler;
43
49
  StakingStore _store;
44
50
  StakingReader _reader;
51
+ NftId _protocolNftId;
52
+ }
45
53
 
46
- mapping(uint256 chainId => mapping(address token => UFixed stakingRate)) _stakingRate;
47
54
 
48
- mapping(NftId targetNftId => Amount stakedAmount) _stakedAmount;
49
- mapping(NftId targetNftId => mapping(address token => Amount tvlAmount)) _tvlAmount;
55
+ modifier onlyStakeOwner(NftId stakeNftId) {
56
+ _checkTypeAndOwner(stakeNftId, STAKE(), true);
57
+ _;
58
+ }
50
59
 
51
- NftId _protocolNftId;
60
+
61
+ modifier onlyTarget(NftId targetNftId) {
62
+ _checkTypeAndOwner(targetNftId, TARGET(), false);
63
+ _;
52
64
  }
53
65
 
54
66
 
55
- modifier onlyStake(NftId stakeNftId) {
56
- if (!_getStakingStorage()._store.exists(stakeNftId)) {
57
- revert ErrorStakingNotStake(stakeNftId);
58
- }
67
+ modifier onlyTargetOwner(NftId targetNftId) {
68
+ _checkTypeAndOwner(targetNftId, TARGET(), true);
59
69
  _;
60
70
  }
61
71
 
72
+ //--- contract intitialization -------------------------------------------
62
73
 
63
- modifier onlyTarget(NftId targetNftId) {
64
- if (!_getStakingStorage()._store.getTargetManager().exists(targetNftId)) {
65
- revert ErrorStakingNotTarget(targetNftId);
74
+ function initializeTokenHandler()
75
+ external
76
+ virtual
77
+ {
78
+ if (msg.sender != address(getRegistry())) {
79
+ revert ErrorStakingNotRegistry(msg.sender);
66
80
  }
67
- _;
81
+
82
+ StakingStorage storage $ = _getStakingStorage();
83
+ address dipToken = _getStakingStorage()._tokenRegistry.getDipTokenAddress();
84
+ $._tokenHandler = TokenHandlerDeployerLib.deployTokenHandler(
85
+ address(getRegistry()),
86
+ address(this),
87
+ dipToken,
88
+ getRegistry().getAuthority());
68
89
  }
69
90
 
70
91
 
71
- // from Versionable
72
- function getVersion()
73
- public
74
- pure
75
- virtual override (IVersionable, Versionable)
76
- returns(Version)
92
+ //--- staking owner functions -------------------------------------------//
93
+
94
+ function setSupportInfo(
95
+ ObjectType targetType,
96
+ bool isSupported,
97
+ bool allowNewTargets,
98
+ bool allowCrossChain,
99
+ Amount minStakingAmount,
100
+ Amount maxStakingAmount,
101
+ Seconds minLockingPeriod,
102
+ Seconds maxLockingPeriod,
103
+ UFixed minRewardRate,
104
+ UFixed maxRewardRate
105
+ )
106
+ external
107
+ virtual
108
+ restricted()
109
+ onlyOwner()
110
+ {
111
+ StakingStorage storage $ = _getStakingStorage();
112
+ $._store.setSupportInfo(
113
+ targetType,
114
+ isSupported,
115
+ allowNewTargets,
116
+ allowCrossChain,
117
+ minStakingAmount,
118
+ maxStakingAmount,
119
+ minLockingPeriod,
120
+ maxLockingPeriod,
121
+ minRewardRate,
122
+ maxRewardRate);
123
+ }
124
+
125
+
126
+ /// @inheritdoc IStaking
127
+ function setUpdateTriggers(
128
+ uint16 tvlUpdatesTrigger,
129
+ UFixed minTvlRatioTrigger
130
+ )
131
+ external
132
+ restricted()
133
+ {
134
+ StakingStorage storage $ = _getStakingStorage();
135
+ $._targetHandler.setUpdateTriggers(tvlUpdatesTrigger, minTvlRatioTrigger);
136
+ }
137
+
138
+
139
+ /// @inheritdoc IStaking
140
+ function setProtocolLockingPeriod(Seconds newLockingPeriod)
141
+ external
142
+ virtual
143
+ restricted()
144
+ onlyOwner()
77
145
  {
78
- return VersionLib.toVersion(GIF_MAJOR_VERSION,0,0);
146
+ StakingStorage storage $ = _getStakingStorage();
147
+ $._store.setLockingPeriod($._protocolNftId, newLockingPeriod);
79
148
  }
80
149
 
81
- // set/update staking reader
82
- function setStakingReader(StakingReader stakingReader)
150
+
151
+ /// @inheritdoc IStaking
152
+ function setProtocolRewardRate(UFixed newRewardRate)
83
153
  external
84
154
  virtual
85
- onlyOwner
155
+ restricted()
156
+ onlyOwner()
86
157
  {
158
+ StakingStorage storage $ = _getStakingStorage();
159
+ $._store.setRewardRate($._protocolNftId, newRewardRate);
160
+ }
161
+
162
+
163
+ /// @inheritdoc IStaking
164
+ function setStakingRate(
165
+ ChainId chainId,
166
+ address token,
167
+ UFixed stakingRate
168
+ )
169
+ external
170
+ virtual
171
+ restricted()
172
+ onlyOwner()
173
+ {
174
+ (
175
+ UFixed oldStakingRate,
176
+ Blocknumber lastUpdateIn
177
+ ) = _getStakingStorage()._store.setStakingRate(chainId, token, stakingRate);
178
+
179
+ emit LogStakingStakingRateSet(chainId, token, stakingRate, oldStakingRate, lastUpdateIn);
180
+ }
181
+
182
+
183
+ /// @inheritdoc IStaking
184
+ function setStakingService(VersionPart release)
185
+ external
186
+ virtual
187
+ restricted()
188
+ onlyOwner()
189
+ {
190
+ // effects
191
+ StakingStorage storage $ = _getStakingStorage();
192
+ address oldStakingService = address($._stakingService);
193
+ $._stakingService = StakingLib.checkAndGetStakingService(getRegistry(), release);
194
+
195
+ emit LogStakingStakingServiceSet(address($._stakingService), release, oldStakingService);
196
+ }
197
+
198
+
199
+ /// @inheritdoc IStaking
200
+ function setStakingReader(address reader)
201
+ external
202
+ virtual
203
+ restricted()
204
+ onlyOwner()
205
+ {
206
+ StakingReader stakingReader = StakingReader(reader);
207
+
87
208
  if(stakingReader.getStaking() != IStaking(this)) {
88
209
  revert ErrorStakingStakingReaderStakingMismatch(address(stakingReader.getStaking()));
89
210
  }
90
211
 
91
- _getStakingStorage()._reader = stakingReader;
212
+ StakingStorage storage $ = _getStakingStorage();
213
+ $._reader = stakingReader;
214
+ $._store.setStakingReader(reader);
92
215
  }
93
216
 
94
217
 
95
- // rate management
96
- function setStakingRate(uint256 chainId, address token, UFixed stakingRate)
218
+ // TODO move to TargetHandler?
219
+ /// @inheritdoc IStaking
220
+ function addToken(
221
+ ChainId chainId,
222
+ address token
223
+ )
97
224
  external
98
225
  virtual
99
- onlyOwner
226
+ restricted()
227
+ onlyOwner()
228
+ {
229
+ _addToken(
230
+ _getStakingStorage(), chainId, token);
231
+ }
232
+
233
+
234
+ /// @inheritdoc IStaking
235
+ function approveTokenHandler(IERC20Metadata token, Amount amount)
236
+ public
237
+ virtual
238
+ restricted()
239
+ onlyOwner()
100
240
  {
241
+ StakingStorage storage $ = _getStakingStorage();
242
+ Amount oldAllowanceAmount = AmountLib.toAmount(
243
+ token.allowance(
244
+ address(this),
245
+ address($._tokenHandler)));
101
246
 
247
+ // staking token handler approval via its own implementation in staking service
248
+ $._stakingService.approveTokenHandler(
249
+ token,
250
+ amount);
251
+
252
+ emit LogStakingTokenHandlerApproved(address(token), amount, oldAllowanceAmount);
102
253
  }
103
254
 
104
- // reward management
255
+ //--- target management -------------------------------------------------//
256
+
257
+
258
+ /// @inheritdoc IStaking
259
+ function refillRewardReserves(NftId targetNftId, Amount dipAmount)
260
+ external
261
+ virtual
262
+ restricted()
263
+ onlyTarget(targetNftId)
264
+ returns (Amount newBalance)
265
+ {
266
+ address transferFrom = msg.sender;
267
+ _refillRewardReserves(targetNftId, dipAmount, transferFrom);
268
+ }
105
269
 
106
- // target management
107
270
 
271
+ /// @inheritdoc IStaking
272
+ function withdrawRewardReserves(NftId targetNftId, Amount dipAmount)
273
+ external
274
+ virtual
275
+ restricted()
276
+ onlyTarget(targetNftId)
277
+ returns (Amount newBalance)
278
+ {
279
+ address transferTo;
280
+
281
+ // case 1: protocol target: staking owner is recipient
282
+ if (targetNftId == getRegistry().getProtocolNftId()) {
283
+ // verify that the caller is the staking owner
284
+ transferTo = getOwner();
285
+ if (msg.sender != transferTo) {
286
+ revert ErrorStakingNotStakingOwner();
287
+ }
288
+
289
+ // case 2: same chain target: target owner is recipient
290
+ } else if (ChainIdLib.isCurrentChain(targetNftId)) {
291
+ // verify that the caller is the target owner
292
+ transferTo = getRegistry().ownerOf(targetNftId);
293
+ if (msg.sender != transferTo) {
294
+ revert ErrorStakingNotNftOwner(targetNftId);
295
+ }
296
+
297
+ // case 3: cross-chain target: TODO decide how to handle and implement
298
+ } else {
299
+ revert("Cross-chain target not supported");
300
+ }
301
+
302
+ newBalance = _withdrawRewardReserves(targetNftId, dipAmount, transferTo);
303
+ }
304
+
305
+
306
+ /// @inheritdoc IStaking
307
+ function refillRewardReservesByService(NftId targetNftId, Amount dipAmount, address transferFrom)
308
+ external
309
+ virtual
310
+ restricted()
311
+ onlyTarget(targetNftId)
312
+ returns (Amount newBalance)
313
+ {
314
+ _refillRewardReserves(targetNftId, dipAmount, transferFrom);
315
+ }
316
+
317
+
318
+ /// @inheritdoc IStaking
319
+ function withdrawRewardReservesByService(NftId targetNftId, Amount dipAmount, address transferTo)
320
+ external
321
+ virtual
322
+ restricted()
323
+ onlyTarget(targetNftId)
324
+ returns (Amount newBalance)
325
+ {
326
+ // check that service does not withdraw from protocol target
327
+ if (targetNftId == getRegistry().getProtocolNftId()) {
328
+ revert ErrorStakingTargetTypeNotSupported(targetNftId, PROTOCOL());
329
+ }
330
+
331
+ // default: on-chain target owner is recipient
332
+ address targetOwner = getRegistry().ownerOf(targetNftId);
333
+ return _withdrawRewardReserves(targetNftId, dipAmount, targetOwner);
334
+ }
335
+
336
+
337
+ /// @inheritdoc IStaking
108
338
  function registerTarget(
109
339
  NftId targetNftId,
110
340
  ObjectType expectedObjectType,
111
- uint256 chainId,
112
341
  Seconds initialLockingPeriod,
113
342
  UFixed initialRewardRate
114
343
  )
115
344
  external
116
345
  virtual
117
- // restricted // staking service access
346
+ restricted() // staking service
118
347
  {
119
- TargetManagerLib.checkTargetParameters(
120
- getRegistry(),
121
- _getStakingStorage()._reader,
122
- targetNftId,
123
- expectedObjectType,
124
- initialLockingPeriod,
125
- initialRewardRate);
126
-
348
+ // checks done by staking store
127
349
  _getStakingStorage()._store.createTarget(
128
350
  targetNftId,
129
- TargetInfo({
130
- objectType: expectedObjectType,
131
- chainId: chainId,
132
- lockingPeriod: initialLockingPeriod,
133
- rewardRate: initialRewardRate}));
351
+ expectedObjectType,
352
+ initialLockingPeriod,
353
+ initialRewardRate);
134
354
  }
135
355
 
136
356
 
357
+ /// @inheritdoc IStaking
137
358
  function setLockingPeriod(
138
359
  NftId targetNftId,
139
360
  Seconds lockingPeriod
140
361
  )
141
362
  external
142
363
  virtual
143
- // TODO add restricted // only staking service
144
- onlyTarget(targetNftId) // maybe duplicate check
364
+ restricted()
365
+ onlyTarget(targetNftId)
145
366
  {
146
- (
147
- Seconds oldLockingPeriod,
148
- TargetInfo memory targetInfo
149
- ) = TargetManagerLib.updateLockingPeriod(
150
- this,
151
- targetNftId,
152
- lockingPeriod);
153
-
154
- _getStakingStorage()._store.updateTarget(targetNftId, targetInfo);
155
-
156
- emit LogStakingLockingPeriodSet(targetNftId, oldLockingPeriod, lockingPeriod);
367
+ _getStakingStorage()._store.setLockingPeriod(targetNftId, lockingPeriod);
157
368
  }
158
369
 
159
- // TODO add function to set protocol reward rate: onlyOwner
160
- // get protocol nft id (from where)
161
370
 
371
+ /// @inheritdoc IStaking
162
372
  function setRewardRate(NftId targetNftId, UFixed rewardRate)
163
373
  external
164
374
  virtual
165
- onlyTarget(targetNftId) // maybe duplicate check
375
+ restricted()
376
+ onlyTarget(targetNftId)
166
377
  {
167
- (
168
- UFixed oldRewardRate,
169
- TargetInfo memory targetInfo
170
- ) = TargetManagerLib.updateRewardRate(
171
- this,
172
- targetNftId,
173
- rewardRate);
174
-
175
- _getStakingStorage()._store.updateTarget(targetNftId, targetInfo);
176
-
177
- emit LogStakingRewardRateSet(targetNftId, oldRewardRate, rewardRate);
378
+ _getStakingStorage()._store.setRewardRate(targetNftId, rewardRate);
178
379
  }
179
380
 
180
381
 
181
- function refillRewardReserves(NftId targetNftId, Amount dipAmount)
382
+ // TODO refactor into setTargetLimits
383
+ /// @inheritdoc IStaking
384
+ function setMaxStakedAmount(NftId targetNftId, Amount stakeLimitAmount)
182
385
  external
183
386
  virtual
387
+ restricted()
388
+ onlyTarget(targetNftId)
184
389
  {
185
-
390
+ StakingStorage storage $ = _getStakingStorage();
391
+ $._store.setMaxStakedAmount(targetNftId, stakeLimitAmount);
186
392
  }
187
393
 
188
- function withdrawRewardReserves(NftId targetNftId, Amount dipAmount)
394
+
395
+ /// @inheritdoc IStaking
396
+ function setTargetLimits(NftId targetNftId, Amount marginAmount, Amount limitAmount)
189
397
  external
190
398
  virtual
191
- // onlyNftOwner(targetNftId)
399
+ restricted()
400
+ onlyTargetOwner(targetNftId)
192
401
  {
193
-
402
+ StakingStorage storage $ = _getStakingStorage();
403
+ $._store.setTargetLimits(targetNftId, marginAmount, limitAmount);
194
404
  }
195
405
 
196
406
 
197
- function increaseTvl(NftId targetNftId, address token, Amount amount)
407
+ /// @inheritdoc IStaking
408
+ function addTargetToken(NftId targetNftId, address token)
198
409
  external
199
410
  virtual
200
- // restricted // service to service access
411
+ restricted()
412
+ onlyTarget(targetNftId)
201
413
  {
414
+ StakingStorage storage $ = _getStakingStorage();
415
+ ChainId chainId = ChainIdLib.fromNftId(targetNftId);
416
+
417
+ if (! $._store.hasTokenInfo(chainId, token)) {
418
+ _addToken($, chainId, token);
419
+ }
420
+
421
+ $._store.addTargetToken(targetNftId, token);
202
422
 
423
+ // TODO move logging to store
424
+ emit LogStakingTargetTokenAdded(targetNftId, chainId, token);
203
425
  }
204
426
 
205
- function decreaseTvl(NftId targetNftId, address token, Amount amount)
427
+
428
+ /// @inheritdoc IStaking
429
+ function increaseTotalValueLocked(NftId targetNftId, address token, Amount amount)
206
430
  external
207
431
  virtual
208
- // restricted // service to service access
432
+ restricted() // only pool service
209
433
  {
434
+ StakingStorage storage $ = _getStakingStorage();
435
+ $._store.increaseTotalValueLocked(targetNftId, token, amount);
436
+ }
437
+
210
438
 
439
+ /// @inheritdoc IStaking
440
+ function decreaseTotalValueLocked(NftId targetNftId, address token, Amount amount)
441
+ external
442
+ virtual
443
+ restricted() // only pool service
444
+ {
445
+ StakingStorage storage $ = _getStakingStorage();
446
+ $._store.decreaseTotalValueLocked(targetNftId, token, amount);
211
447
  }
212
448
 
213
449
 
450
+ // TODO add to interface and implement
451
+ /// inheritdoc IStaking
214
452
  function registerRemoteTarget(NftId targetNftId, TargetInfo memory targetInfo)
215
453
  external
216
454
  virtual
455
+ restricted()
217
456
  onlyOwner // or CCIP
218
457
  {
219
458
 
220
459
  }
221
460
 
461
+ // TODO add to interface and implement
462
+ /// @inheritdoc IStaking
222
463
  function updateRemoteTvl(NftId targetNftId, address token, Amount amount)
223
464
  external
224
465
  virtual
466
+ restricted()
225
467
  onlyOwner // or CCIP
226
468
  {
227
469
 
228
470
  }
229
471
 
230
- //--- staking functions -------------------------------------------------//
472
+ //--- public functions --------------------------------------------------//
231
473
 
232
- function registerStake(
233
- NftId stakeNftId,
234
- NftId targetNftId,
235
- Amount dipAmount
236
- )
474
+ /// @inheritdoc IStaking
475
+ function updateTargetLimit(NftId targetNftId)
237
476
  external
238
- virtual
239
- // TODO add restricted() // only staking service
477
+ restricted()
240
478
  {
241
- Timestamp lockedUntil = StakeManagerLib.checkStakeParameters(
242
- _getStakingStorage()._reader,
243
- targetNftId,
244
- dipAmount);
245
-
246
- _getStakingStorage()._store.create(
247
- stakeNftId,
248
- StakeInfo({
249
- lockedUntil: lockedUntil}),
250
- dipAmount);
479
+ StakingStorage storage $ = _getStakingStorage();
480
+ $._store.updateTargetLimit(targetNftId);
251
481
  }
252
482
 
253
483
 
254
- function stake(NftId stakeNftId, Amount dipAmount)
484
+ /// @inheritdoc IStaking
485
+ function createStake(
486
+ NftId targetNftId,
487
+ Amount stakeAmount,
488
+ address stakeOwner
489
+ )
255
490
  external
256
491
  virtual
257
- // TODO add restricted() // only staking service
258
- onlyStake(stakeNftId)
492
+ restricted()
493
+ onlyTarget(targetNftId)
494
+ returns (NftId stakeNftId)
259
495
  {
496
+ // effects (includes further checks in service)
260
497
  StakingStorage storage $ = _getStakingStorage();
261
- Amount rewardIncrement = StakeManagerLib.calculateRewardIncrease(
262
- $._reader,
263
- stakeNftId);
498
+ stakeNftId = $._stakingService.createStakeObject(targetNftId, stakeOwner);
499
+ $._store.createStake(stakeNftId, targetNftId, stakeOwner, stakeAmount);
264
500
 
265
- $._store.increaseBalance(
266
- stakeNftId,
267
- dipAmount,
268
- rewardIncrement);
501
+ // interactions
502
+ if (stakeAmount.gtz()) {
503
+ $._stakingService.pullDipToken(stakeAmount, stakeOwner);
504
+ }
269
505
  }
270
506
 
507
+ //--- stake owner functions ---------------------------------------------//
271
508
 
272
- function restake(NftId stakeNftId)
509
+
510
+ /// @inheritdoc IStaking
511
+ function stake(
512
+ NftId stakeNftId,
513
+ Amount stakeAmount
514
+ )
273
515
  external
274
516
  virtual
275
- // TODO add restricted() // only staking service
276
- onlyStake(stakeNftId)
517
+ restricted()
518
+ onlyStakeOwner(stakeNftId)
519
+ returns (Amount newStakeBalance)
277
520
  {
278
- // TODO add check that target is active and allows additional staking amount
279
521
  StakingStorage storage $ = _getStakingStorage();
280
- Amount rewardIncrement = StakeManagerLib.calculateRewardIncrease(
281
- $._reader,
282
- stakeNftId);
283
-
284
- $._store.restakeRewards(
522
+ $._store.stake(
285
523
  stakeNftId,
286
- rewardIncrement);
524
+ true, // update rewards
525
+ true, // restake rewards
526
+ SecondsLib.max(), // max additional locking duration
527
+ stakeAmount);
528
+
529
+ // collect staked DIP token via staking service
530
+ if (stakeAmount.gtz()) {
531
+ address stakeOwner = getRegistry().ownerOf(stakeNftId);
532
+ $._stakingService.pullDipToken(stakeAmount, stakeOwner);
533
+ }
287
534
  }
288
535
 
289
536
 
290
- function updateRewards(NftId stakeNftId)
537
+ /// @inheritdoc IStaking
538
+ function unstake(NftId stakeNftId)
291
539
  external
292
540
  virtual
293
- // TODO add restricted() // only staking service
294
- onlyStake(stakeNftId)
541
+ restricted()
542
+ onlyStakeOwner(stakeNftId)
543
+ returns (Amount unstakedAmount)
295
544
  {
296
545
  StakingStorage storage $ = _getStakingStorage();
297
- _updateRewards($._reader, $._store, stakeNftId);
546
+ unstakedAmount = $._store.unstake(
547
+ stakeNftId,
548
+ true, // update rewards
549
+ true, // restake rewards
550
+ AmountLib.max()); // unstake up to this amount
551
+
552
+ // transfer unstaked DIP token via staking service
553
+ if (unstakedAmount.gtz()) {
554
+ address stakeOwner = getRegistry().ownerOf(stakeNftId);
555
+ $._stakingService.pushDipToken(unstakedAmount, stakeOwner);
556
+ }
298
557
  }
299
558
 
300
559
 
301
- function claimRewards(NftId stakeNftId)
560
+ /// @inheritdoc IStaking
561
+ function restake(
562
+ NftId stakeNftId,
563
+ NftId newTargetNftId
564
+ )
302
565
  external
303
566
  virtual
304
- // TODO add restricted() // only staking service
305
- onlyStake(stakeNftId)
567
+ restricted() // only staking service
568
+ onlyStakeOwner(stakeNftId)
569
+ onlyTarget(newTargetNftId)
306
570
  returns (
307
- Amount rewardsClaimedAmount
571
+ NftId newStakeNftId,
572
+ Amount newStakedAmount
308
573
  )
309
574
  {
310
575
  StakingStorage storage $ = _getStakingStorage();
311
576
 
312
- // update rewards since last update
313
- _updateRewards($._reader, $._store, stakeNftId);
577
+ // step 1: unstake as much as possible
578
+ newStakedAmount = $._store.unstake(
579
+ stakeNftId,
580
+ true, // update rewards
581
+ true, // restake rewards
582
+ AmountLib.max()); // unstake up to this amount
583
+
584
+ // step 2: create new stake with full unstaked amount
585
+ address stakeOwner = getRegistry().ownerOf(stakeNftId);
586
+ newStakeNftId = $._stakingService.createStakeObject(newTargetNftId, stakeOwner);
587
+ $._store.createStake(newStakeNftId, newTargetNftId, stakeOwner, newStakedAmount);
314
588
 
315
- // unstake all available rewards
316
- rewardsClaimedAmount = $._store.claimUpTo(
317
- stakeNftId,
318
- AmountLib.max());
589
+ // logging
590
+ emit LogStakingStakeRestaked(newStakeNftId, newTargetNftId, newStakedAmount, stakeOwner, stakeNftId);
319
591
  }
320
592
 
321
593
 
322
- function unstake(NftId stakeNftId)
594
+ function updateRewards(NftId stakeNftId)
323
595
  external
324
596
  virtual
325
- // TODO add restricted() // only staking service
326
- onlyStake(stakeNftId)
327
- returns (
328
- Amount unstakedAmount,
329
- Amount rewardsClaimedAmount
330
- )
597
+ restricted()
598
+ onlyStakeOwner(stakeNftId)
599
+ returns (Amount newRewardAmount)
331
600
  {
332
- // TODO add check that stake locking is in the past
333
601
  StakingStorage storage $ = _getStakingStorage();
334
-
335
- // update rewards since last update
336
- _updateRewards($._reader, $._store, stakeNftId);
337
-
338
- // unstake all available dips
339
- (
340
- unstakedAmount,
341
- rewardsClaimedAmount
342
- ) = $._store.unstakeUpTo(
343
- stakeNftId,
344
- AmountLib.max(), // unstake all stakes
345
- AmountLib.max()); // claim all rewards
602
+ $._store.updateRewards(stakeNftId);
346
603
  }
347
604
 
348
605
 
349
-
350
- function _updateRewards(
351
- StakingReader reader,
352
- StakingStore store,
353
- NftId stakeNftId
354
- )
355
- internal
606
+ function claimRewards(NftId stakeNftId)
607
+ external
356
608
  virtual
609
+ restricted()
610
+ onlyStakeOwner(stakeNftId)
611
+ returns (
612
+ Amount claimedAmount
613
+ )
357
614
  {
358
- Amount rewardIncrement = StakeManagerLib.calculateRewardIncrease(
359
- reader,
360
- stakeNftId);
361
-
362
- store.updateRewards(
615
+ StakingStorage storage $ = _getStakingStorage();
616
+ claimedAmount = $._store.claimRewards(
363
617
  stakeNftId,
364
- rewardIncrement);
618
+ true,
619
+ AmountLib.max());
620
+
621
+ // collect staked DIP token by staking service
622
+ if (claimedAmount.gtz()) {
623
+ // interactions
624
+ address stakeOwner = getRegistry().ownerOf(stakeNftId);
625
+ $._stakingService.pushDipToken(claimedAmount, stakeOwner);
626
+ }
365
627
  }
366
628
 
367
629
 
368
- //--- other functions ---------------------------------------------------//
630
+ //--- view functions ----------------------------------------------------//
369
631
 
370
- function collectDipAmount(address from, Amount dipAmount)
371
- external
372
- // TODO add restricted() // only staking service
373
- {
374
- TokenHandler tokenHandler = getTokenHandler();
375
- address stakingWallet = getWallet();
632
+ function getStakingReader() public virtual view returns (StakingReader reader) {
633
+ return _getStakingStorage()._reader;
634
+ }
635
+
636
+ function getTargetHandler() external virtual view returns (TargetHandler targetHandler) {
637
+ return _getStakingStorage()._targetHandler;
638
+ }
376
639
 
377
- StakeManagerLib.checkDipBalanceAndAllowance(
378
- getToken(),
379
- from,
380
- address(tokenHandler),
381
- dipAmount);
640
+ function getStakingStore() external virtual view returns (StakingStore stakingStore) {
641
+ return _getStakingStorage()._store;
642
+ }
382
643
 
383
- tokenHandler.transfer(from, stakingWallet, dipAmount);
644
+ function getTokenRegistryAddress() external virtual view returns (address tokenRegistry) {
645
+ return address(_getStakingStorage()._tokenRegistry);
384
646
  }
385
647
 
648
+ function getTokenHandler() public virtual override(Component, IComponent) view returns (TokenHandler tokenHandler) {
649
+ return _getStakingStorage()._tokenHandler;
650
+ }
386
651
 
387
- function transferDipAmount(address to, Amount dipAmount)
388
- external
389
- // TODO add restricted() // only staking service
652
+ // from IRegisterable
653
+ function getRelease()
654
+ public
655
+ pure
656
+ virtual override (IRelease, Registerable)
657
+ returns(VersionPart)
390
658
  {
391
- TokenHandler tokenHandler = getTokenHandler();
392
- address stakingWallet = getWallet();
393
-
394
- StakeManagerLib.checkDipBalanceAndAllowance(
395
- getToken(),
396
- stakingWallet,
397
- address(tokenHandler),
398
- dipAmount);
659
+ return VersionPartLib.toVersionPart(3);
660
+ }
399
661
 
400
- tokenHandler.transfer(stakingWallet, to, dipAmount);
662
+ // from IVersionable
663
+ function getVersion()
664
+ public
665
+ pure
666
+ virtual override (Component, IVersionable, Versionable)
667
+ returns(Version)
668
+ {
669
+ return VersionLib.toVersion(3,0,0);
401
670
  }
402
671
 
672
+ //--- internal functions ------------------------------------------------//
403
673
 
404
- //--- view functions ----------------------------------------------------//
405
674
 
406
- function getStakingReader() public view returns (StakingReader reader) {
407
- return _getStakingStorage()._reader;
408
- }
675
+ function _refillRewardReserves(NftId targetNftId, Amount dipAmount, address transferFrom)
676
+ internal
677
+ virtual
678
+ returns (Amount newBalance)
679
+ {
680
+ // checks + effects
681
+ StakingStorage storage $ = _getStakingStorage();
682
+ newBalance = $._store.refillRewardReserves(targetNftId, dipAmount);
409
683
 
410
- function getStakingStore() external view returns (StakingStore stakingStore) {
411
- return _getStakingStorage()._store;
684
+ // interactions
685
+ // collect DIP token from target owner
686
+ if (dipAmount.gtz()) {
687
+ $._stakingService.pullDipToken(dipAmount, transferFrom);
688
+ }
412
689
  }
413
690
 
414
- function getStakingRate(uint256 chainId, address token) external view returns (UFixed stakingRate) {
415
- return _getStakingStorage()._stakingRate[chainId][token];
416
- }
417
691
 
418
- function getTvlAmount(NftId targetNftId, address token) external view returns (Amount tvlAmount) {
419
- return _getStakingStorage()._tvlAmount[targetNftId][token];
420
- }
692
+ function _withdrawRewardReserves(NftId targetNftId, Amount dipAmount, address transferTo)
693
+ internal
694
+ virtual
695
+ returns (Amount newBalance)
696
+ {
697
+ // checks + effects
698
+ StakingStorage storage $ = _getStakingStorage();
699
+ newBalance = $._store.withdrawRewardReserves(targetNftId, dipAmount);
421
700
 
422
- function getStakedAmount(NftId targetNftId) external view returns (Amount stakeAmount) {
423
- return _getStakingStorage()._stakedAmount[targetNftId];
701
+ // interactions
702
+ // transfer DIP token to designated address
703
+ if (dipAmount.gtz()) {
704
+ $._stakingService.pushDipToken(dipAmount, transferTo);
705
+ }
424
706
  }
425
707
 
426
- function getTokenRegistryAddress() external view returns (address tokenRegistry) {
427
- return address(_getStakingStorage()._tokenRegistry);
428
- }
429
708
 
430
- function calculateRewardIncrementAmount(
431
- NftId targetNftId,
432
- Timestamp rewardsLastUpdatedAt
709
+ function _addToken(
710
+ StakingStorage storage $,
711
+ ChainId chainId,
712
+ address token
433
713
  )
434
- public
714
+ internal
435
715
  virtual
436
- view
437
- returns (Amount rewardIncrementAmount)
438
716
  {
439
-
717
+ $._store.addToken(chainId, token);
440
718
  }
441
719
 
442
- //--- internal functions ------------------------------------------------//
443
720
 
721
+ /// @dev top level initializer (upgradable contract)
444
722
  function _initialize(
445
723
  address owner,
446
724
  bytes memory data
447
725
  )
448
726
  internal
449
727
  virtual override
450
- initializer
728
+ onlyInitializing()
451
729
  {
452
730
  (
453
- address initialAuthority,
454
731
  address registryAddress,
455
- address stakingReaderAddress,
732
+ address targetHandlerAddress,
456
733
  address stakingStoreAddress,
457
- address initialOwner
458
- ) = abi.decode(data, (address, address, address, address, address));
734
+ address tokenRegistryAddress
735
+ ) = abi.decode(data, (address, address, address, address));
459
736
 
737
+ // wiring to external contracts
460
738
  IRegistry registry = IRegistry(registryAddress);
461
- TokenRegistry tokenRegistry = TokenRegistry(registry.getTokenRegistryAddress());
462
- address dipTokenAddress = address(tokenRegistry.getDipToken());
463
-
464
- initializeComponent(
465
- initialAuthority,
466
- registryAddress,
467
- registry.getNftId(),
739
+ StakingStorage storage $ = _getStakingStorage();
740
+ $._protocolNftId = registry.getProtocolNftId();
741
+ $._targetHandler = TargetHandler(targetHandlerAddress);
742
+ $._store = StakingStore(stakingStoreAddress);
743
+ $._reader = StakingStore(stakingStoreAddress).getStakingReader();
744
+ $._tokenRegistry = TokenRegistry(tokenRegistryAddress);
745
+ // staking service has to be set via setStakingService after deploying the first GIF release
746
+
747
+ // initialize component
748
+ __Component_init(
749
+ registry.getAuthority(),
750
+ address(registry),
751
+ registry.getNftId(), // parent nft id
468
752
  CONTRACT_NAME,
469
- dipTokenAddress,
470
753
  STAKING(),
471
754
  false, // is interceptor
472
- initialOwner,
473
- "", // registry data
474
- ""); // component data
755
+ owner,
756
+ ""); // registry data
475
757
 
476
- _createAndSetTokenHandler();
758
+ // Protocol target is created in the StakingStore constructor.
759
+ // This allows setting up the protocol target before the full
760
+ // staking authorization setup is in place.
477
761
 
478
- // wiring to external contracts
479
- StakingStorage storage $ = _getStakingStorage();
480
- $._protocolNftId = getRegistry().getProtocolNftId();
481
- $._store = StakingStore(stakingStoreAddress);
482
- $._reader = StakingReader(stakingReaderAddress);
483
- $._tokenRegistry = TokenRegistry(
484
- address(tokenRegistry));
762
+ _registerInterface(type(IStaking).interfaceId);
763
+ }
485
764
 
486
- // wiring to staking
487
- $._reader.setStakingDependencies(
488
- registryAddress,
489
- address(this),
490
- stakingStoreAddress);
491
765
 
492
- registerInterface(type(IStaking).interfaceId);
766
+ function _checkTypeAndOwner(NftId nftId, ObjectType expectedObjectType, bool checkOwner)
767
+ internal
768
+ view
769
+ {
770
+ StakingStorage storage $ = _getStakingStorage();
771
+ if (expectedObjectType == STAKE()) {
772
+ if (!$._store.exists(nftId)) {
773
+ revert ErrorStakingNotStake(nftId);
774
+ }
775
+ } else {
776
+ if (expectedObjectType == TARGET()) {
777
+ if (!$._store.getTargetSet().exists(nftId)) {
778
+ revert ErrorStakingNotTarget(nftId);
779
+ }
780
+ }
781
+ }
782
+
783
+ if (checkOwner) {
784
+ address nftOwner = getRegistry().ownerOf(nftId);
785
+ if (msg.sender != nftOwner) {
786
+ revert ErrorStakingNotOwner(nftId, nftOwner, msg.sender);
787
+ }
788
+ }
493
789
  }
494
790
 
495
791
 
@@ -498,5 +794,4 @@ contract Staking is
498
794
  $.slot := STAKING_LOCATION_V1
499
795
  }
500
796
  }
501
-
502
797
  }