@etherisc/gif-next 0.0.2-a66c9a8-623 → 0.0.2-a6a9eeb-432

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