@etherisc/gif-next 0.0.2-f1b01e0-214 → 0.0.2-f1e6957-384
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.
- package/README.md +76 -341
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.dbg.json +1 -1
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.json +100 -32
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.json +111 -45
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.dbg.json +1 -1
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.json +52 -0
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +367 -126
- package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.json +1546 -211
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.json +2 -2
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +261 -59
- package/artifacts/contracts/authorization/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.json +258 -82
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +97 -14
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.json +256 -16
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +426 -27
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +52 -27
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +264 -64
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +20 -11
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +368 -139
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +160 -78
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +19 -10
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +228 -15
- package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.json +81 -52
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +263 -63
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +109 -68
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +263 -63
- package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.json +74 -33
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.json +263 -63
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +35 -26
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +85 -60
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.json +263 -63
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +264 -78
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.json +263 -63
- package/artifacts/contracts/instance/BaseStore.sol/BaseStore.dbg.json +4 -0
- package/artifacts/contracts/{shared/IKeyValueStore.sol/IKeyValueStore.json → instance/BaseStore.sol/BaseStore.json} +51 -229
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +2 -2
- package/artifacts/contracts/instance/IBaseStore.sol/IBaseStore.dbg.json +4 -0
- package/artifacts/contracts/instance/IBaseStore.sol/IBaseStore.json +304 -0
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +359 -33
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +297 -3
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +407 -97
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +756 -392
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +231 -75
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +492 -424
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +323 -29
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +100 -42
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +1444 -2133
- package/artifacts/contracts/instance/ProductStore.sol/ProductStore.dbg.json +4 -0
- package/artifacts/contracts/instance/ProductStore.sol/ProductStore.json +3427 -0
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.dbg.json +1 -1
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.json +101 -88
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +8 -8
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +2 -2
- package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.json +2 -2
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.json +2 -2
- package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.json +2 -2
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
- package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.json +25 -16
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +277 -60
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +19 -10
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +29 -0
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +19 -10
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +83 -38
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +116 -50
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +37 -36
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +263 -63
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +294 -117
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +144 -58
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +180 -27
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +19 -10
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +220 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +19 -10
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.json +88 -22
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +324 -65
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +141 -63
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +216 -59
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +113 -43
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +19 -10
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +263 -63
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +142 -102
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +128 -70
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +166 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +50 -10
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +55 -0
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +29 -0
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +19 -10
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +1 -1
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.json +203 -18
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +157 -86
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.json +508 -18
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +138 -72
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +93 -72
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +120 -50
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +19 -10
- package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +1 -1
- package/artifacts/contracts/product/RiskService.sol/RiskService.json +231 -46
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +101 -43
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +33 -22
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +29 -0
- package/artifacts/contracts/registry/IRelease.sol/IRelease.dbg.json +1 -1
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +71 -60
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +537 -300
- package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.json +330 -71
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +41 -12
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +96 -38
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.json +543 -226
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +2 -2
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +167 -103
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +459 -26
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +119 -59
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +19 -10
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +169 -174
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +130 -64
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +1 -1
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +76 -41
- package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.dbg.json +1 -1
- package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.dbg.json +1 -1
- package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.dbg.json +1 -1
- package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.json +2 -2
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +19 -10
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +84 -105
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +19 -10
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +19 -0
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +19 -0
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +29 -0
- package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +19 -10
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.dbg.json +1 -1
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.json +2 -2
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +21 -2
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +2 -2
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +19 -0
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -2
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +29 -0
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +2 -2
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.json +2 -2
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +2 -2
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +1384 -128
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +94 -114
- package/artifacts/contracts/staking/ITargetLimitHandler.sol/ITargetLimitHandler.dbg.json +4 -0
- package/artifacts/contracts/staking/ITargetLimitHandler.sol/ITargetLimitHandler.json +50 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +1472 -185
- package/artifacts/contracts/staking/StakingLib.sol/StakingLib.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingLib.sol/StakingLib.json +73 -72
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +139 -64
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +293 -149
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +128 -164
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +96 -46
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +1617 -817
- package/artifacts/contracts/staking/TargetHandler.sol/TargetHandler.dbg.json +4 -0
- package/artifacts/contracts/staking/TargetHandler.sol/TargetHandler.json +309 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +140 -78
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.json +2 -2
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +64 -19
- package/artifacts/contracts/type/ChainId.sol/ChainIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/ChainId.sol/ChainIdLib.json +193 -0
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +2 -2
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +2 -2
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/type/Fee.sol/FeeLib.json +2 -2
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/type/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.dbg.json +1 -1
- package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.json +2 -2
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +2 -2
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +2 -2
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +6 -6
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +2 -2
- package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +1 -1
- package/artifacts/contracts/type/Referral.sol/ReferralLib.json +2 -2
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +2 -2
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +2 -2
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +39 -218
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +45 -2
- package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +1 -1
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/String.sol/StrLib.dbg.json +1 -1
- package/artifacts/contracts/type/String.sol/StrLib.json +50 -2
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +3 -3
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +2 -2
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.json +10 -0
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +81 -27
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +15 -2
- package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.json +10 -0
- package/contracts/accounting/AccountingService.sol +15 -3
- package/contracts/accounting/IAccountingService.sol +2 -0
- package/contracts/authorization/AccessAdmin.sol +292 -317
- package/contracts/authorization/AccessAdminLib.sol +517 -22
- package/contracts/authorization/AccessManagerCloneable.sol +0 -18
- package/contracts/authorization/Authorization.sol +64 -239
- package/contracts/authorization/IAccess.sol +23 -14
- package/contracts/authorization/IAccessAdmin.sol +25 -53
- package/contracts/authorization/IAuthorization.sol +3 -57
- package/contracts/authorization/IServiceAuthorization.sol +55 -17
- package/contracts/authorization/ServiceAuthorization.sol +228 -34
- package/contracts/distribution/BasicDistribution.sol +3 -4
- package/contracts/distribution/BasicDistributionAuthorization.sol +11 -4
- package/contracts/distribution/Distribution.sol +9 -8
- package/contracts/distribution/DistributionService.sol +98 -35
- package/contracts/distribution/IDistributionComponent.sol +3 -1
- package/contracts/distribution/IDistributionService.sol +20 -8
- package/contracts/examples/fire/FireProduct.sol +6 -6
- package/contracts/examples/unpermissioned/SimpleProduct.sol +83 -19
- package/contracts/instance/BaseStore.sol +93 -0
- package/contracts/instance/IBaseStore.sol +37 -0
- package/contracts/instance/IInstance.sol +55 -5
- package/contracts/instance/IInstanceService.sol +37 -6
- package/contracts/instance/Instance.sol +103 -56
- package/contracts/instance/InstanceAdmin.sol +151 -294
- package/contracts/instance/InstanceAuthorizationV3.sol +106 -66
- package/contracts/instance/InstanceReader.sol +350 -394
- package/contracts/instance/InstanceService.sol +180 -125
- package/contracts/instance/InstanceStore.sol +153 -128
- package/contracts/instance/ProductStore.sol +290 -0
- package/contracts/instance/RiskSet.sol +10 -2
- package/contracts/instance/TargetNames.sol +10 -0
- package/contracts/instance/base/BalanceStore.sol +4 -6
- package/contracts/instance/base/ObjectLifecycle.sol +2 -6
- package/contracts/instance/module/IComponents.sol +0 -2
- package/contracts/oracle/BasicOracle.sol +2 -3
- package/contracts/oracle/BasicOracleAuthorization.sol +18 -2
- package/contracts/oracle/Oracle.sol +4 -6
- package/contracts/oracle/OracleService.sol +8 -8
- package/contracts/pool/BasicPool.sol +4 -16
- package/contracts/pool/BasicPoolAuthorization.sol +10 -5
- package/contracts/pool/BundleService.sol +34 -43
- package/contracts/pool/IBundleService.sol +14 -13
- package/contracts/pool/IPoolService.sol +7 -2
- package/contracts/pool/Pool.sol +6 -18
- package/contracts/pool/PoolLib.sol +127 -2
- package/contracts/pool/PoolService.sol +40 -181
- package/contracts/product/ApplicationService.sol +64 -11
- package/contracts/product/BasicProduct.sol +2 -3
- package/contracts/product/BasicProductAuthorization.sol +11 -4
- package/contracts/product/ClaimService.sol +99 -105
- package/contracts/product/IApplicationService.sol +21 -2
- package/contracts/product/IClaimService.sol +5 -4
- package/contracts/product/IPolicyService.sol +9 -2
- package/contracts/product/IRiskService.sol +18 -3
- package/contracts/product/PolicyService.sol +40 -59
- package/contracts/product/PolicyServiceLib.sol +79 -5
- package/contracts/product/PricingService.sol +22 -25
- package/contracts/product/Product.sol +40 -16
- package/contracts/product/RiskService.sol +50 -15
- package/contracts/registry/IRegistry.sol +11 -9
- package/contracts/registry/IRelease.sol +6 -3
- package/contracts/registry/Registry.sol +15 -9
- package/contracts/registry/RegistryAdmin.sol +33 -118
- package/contracts/registry/RegistryAuthorization.sol +139 -69
- package/contracts/registry/RegistryService.sol +1 -1
- package/contracts/registry/ReleaseAdmin.sol +52 -106
- package/contracts/registry/ReleaseRegistry.sol +20 -12
- package/contracts/registry/ServiceAuthorizationV3.sol +43 -32
- package/contracts/registry/TokenRegistry.sol +56 -52
- package/contracts/shared/Component.sol +8 -8
- package/contracts/shared/ComponentService.sol +245 -262
- package/contracts/shared/ContractLib.sol +106 -75
- package/contracts/shared/IComponent.sol +1 -1
- package/contracts/shared/IComponentService.sol +12 -13
- package/contracts/shared/INftOwnable.sol +2 -0
- package/contracts/shared/IRegisterable.sol +0 -1
- package/contracts/shared/InstanceLinkedComponent.sol +6 -9
- package/contracts/shared/NftOwnable.sol +3 -1
- package/contracts/shared/PolicyHolder.sol +3 -2
- package/contracts/shared/Service.sol +6 -4
- package/contracts/staking/IStaking.sol +261 -70
- package/contracts/staking/IStakingService.sol +39 -84
- package/contracts/staking/ITargetLimitHandler.sol +17 -0
- package/contracts/staking/Staking.sol +468 -217
- package/contracts/staking/StakingLib.sol +38 -124
- package/contracts/staking/StakingManager.sol +4 -3
- package/contracts/staking/StakingReader.sol +62 -71
- package/contracts/staking/StakingService.sol +42 -185
- package/contracts/staking/StakingServiceManager.sol +1 -0
- package/contracts/staking/StakingStore.sol +1093 -331
- package/contracts/staking/TargetHandler.sol +132 -0
- package/contracts/staking/TargetManagerLib.sol +69 -46
- package/contracts/type/Amount.sol +4 -0
- package/contracts/type/Blocknumber.sol +17 -22
- package/contracts/type/ChainId.sol +101 -0
- package/contracts/type/NftId.sol +3 -3
- package/contracts/type/ObjectType.sol +16 -3
- package/contracts/type/RoleId.sol +57 -59
- package/contracts/type/Seconds.sol +19 -0
- package/contracts/type/String.sol +12 -0
- package/contracts/type/Timestamp.sol +4 -2
- package/contracts/type/UFixed.sol +1 -0
- package/contracts/upgradeability/IVersionable.sol +3 -0
- package/contracts/upgradeability/ProxyManager.sol +26 -12
- package/contracts/upgradeability/UpgradableProxyWithAdmin.sol +12 -2
- package/contracts/upgradeability/Versionable.sol +6 -3
- package/package.json +1 -1
- package/artifacts/contracts/authorization/AccessAdmin.sol/IAccessManagedChecker.dbg.json +0 -4
- package/artifacts/contracts/authorization/AccessAdmin.sol/IAccessManagedChecker.json +0 -24
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +0 -4
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +0 -485
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +0 -4
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +0 -4
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +0 -538
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.dbg.json +0 -4
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.json +0 -205
- package/contracts/shared/ComponentVerifyingService.sol +0 -128
- package/contracts/shared/IKeyValueStore.sol +0 -54
- package/contracts/shared/KeyValueStore.sol +0 -131
- package/contracts/staking/StakingLifecycle.sol +0 -23
| @@ -2,140 +2,479 @@ | |
| 2 2 | 
             
            pragma solidity ^0.8.20;
         | 
| 3 3 |  | 
| 4 4 | 
             
            import {AccessManaged} from "@openzeppelin/contracts/access/manager/AccessManaged.sol";
         | 
| 5 | 
            +
            import {Initializable} from "@openzeppelin/contracts-upgradeable/proxy/utils/Initializable.sol"; 
         | 
| 5 6 |  | 
| 6 7 | 
             
            import {IRegistry} from "../registry/IRegistry.sol";
         | 
| 7 8 | 
             
            import {IStaking} from "./IStaking.sol";
         | 
| 9 | 
            +
            import {ITargetLimitHandler} from "./ITargetLimitHandler.sol";
         | 
| 8 10 |  | 
| 9 11 | 
             
            import {Amount, AmountLib} from "../type/Amount.sol";
         | 
| 12 | 
            +
            import {ChainId, ChainIdLib} from "../type/ChainId.sol";
         | 
| 10 13 | 
             
            import {Blocknumber, BlocknumberLib} from "../type/Blocknumber.sol";
         | 
| 11 | 
            -
            import {KeyValueStore} from "../shared/KeyValueStore.sol";
         | 
| 12 | 
            -
            import {KEEP_STATE} from "../type/StateId.sol";
         | 
| 13 14 | 
             
            import {NftId, NftIdLib} from "../type/NftId.sol";
         | 
| 14 15 | 
             
            import {NftIdSet} from "../shared/NftIdSet.sol";
         | 
| 15 | 
            -
            import { | 
| 16 | 
            +
            import {ObjectType} from "../type/ObjectType.sol";
         | 
| 17 | 
            +
            import {PROTOCOL, INSTANCE} from "../type/ObjectType.sol";
         | 
| 18 | 
            +
            import {Seconds, SecondsLib} from "../type/Seconds.sol";
         | 
| 19 | 
            +
            import {StakingLib} from "./StakingLib.sol";
         | 
| 16 20 | 
             
            import {StakingReader} from "./StakingReader.sol";
         | 
| 17 21 | 
             
            import {TargetManagerLib} from "./TargetManagerLib.sol";
         | 
| 18 22 | 
             
            import {Timestamp, TimestampLib} from "../type/Timestamp.sol";
         | 
| 19 | 
            -
            import { | 
| 20 | 
            -
            import {UFixed} from "../type/UFixed.sol";
         | 
| 23 | 
            +
            import {UFixed, UFixedLib} from "../type/UFixed.sol";
         | 
| 21 24 |  | 
| 22 25 |  | 
| 23 26 | 
             
            contract StakingStore is 
         | 
| 24 | 
            -
                 | 
| 25 | 
            -
                 | 
| 26 | 
            -
                StakingLifecycle
         | 
| 27 | 
            +
                Initializable,
         | 
| 28 | 
            +
                AccessManaged
         | 
| 27 29 | 
             
            {
         | 
| 28 30 |  | 
| 29 | 
            -
                 | 
| 30 | 
            -
                 | 
| 31 | 
            +
                // token
         | 
| 32 | 
            +
                error ErrorStakingStoreTokenNotRegistered(ChainId chainId, address token);
         | 
| 33 | 
            +
                error ErrorStakingStoreTokenAlreadyAdded(ChainId chainId, address token);
         | 
| 34 | 
            +
                error ErrorStakingStoreTokenUnknown(ChainId chainId, address token);
         | 
| 31 35 |  | 
| 32 | 
            -
                 | 
| 33 | 
            -
                 | 
| 34 | 
            -
             | 
| 35 | 
            -
                event LogStakingStoreStakesIncreased(NftId nftId, Amount addedAmount, Amount newBalance, Blocknumber lastUpdatedIn);
         | 
| 36 | 
            -
                event LogStakingStoreStakesDecreased(NftId nftId, Amount addedAmount, Amount newBalance, Blocknumber lastUpdatedIn);
         | 
| 37 | 
            -
             | 
| 38 | 
            -
                event LogStakingStoreRewardsIncreased(NftId nftId, Amount addedAmount, Amount newBalance, Blocknumber lastUpdatedIn);
         | 
| 39 | 
            -
                event LogStakingStoreRewardsDecreased(NftId nftId, Amount addedAmount, Amount newBalance, Blocknumber lastUpdatedIn);
         | 
| 40 | 
            -
             | 
| 41 | 
            -
                event LogStakingStoreRewardsRestaked(NftId nftId, Amount amount, Amount rewardAmount, Amount rewardIncrementAmount, Amount newBalance, Blocknumber lastUpdatedIn);
         | 
| 36 | 
            +
                // target
         | 
| 37 | 
            +
                error ErrorStakingStoreTargetNotInitialized(NftId targetNftId);
         | 
| 38 | 
            +
                error ErrorStakingStoreLimitNotInitialized(NftId targetNftId);
         | 
| 42 39 |  | 
| 43 40 | 
             
                // in/decreasing reward reserves
         | 
| 44 41 | 
             
                error ErrorStakingStoreNotTarget(NftId targetNftId);
         | 
| 45 | 
            -
                error ErrorStakingStoreRewardReservesInsufficient(NftId targetNftId, Amount  | 
| 42 | 
            +
                error ErrorStakingStoreRewardReservesInsufficient(NftId targetNftId, Amount reserveAmount, Amount claimedAmount);
         | 
| 46 43 |  | 
| 47 | 
            -
                //  | 
| 48 | 
            -
                error  | 
| 49 | 
            -
                error  | 
| 44 | 
            +
                // stakes
         | 
| 45 | 
            +
                error ErrorStakingStoreStakesExceedingTargetMaxAmount(NftId targetNftId, Amount stakeLimitAmount, Amount newIStaking);
         | 
| 46 | 
            +
                error ErrorStakingStoreStakeNotInitialized(NftId nftId);
         | 
| 50 47 |  | 
| 51 | 
            -
                //  | 
| 52 | 
            -
                error  | 
| 48 | 
            +
                // creating and updating of staking balance
         | 
| 49 | 
            +
                error ErrorStakingStoreStakeBalanceAlreadyInitialized(NftId nftId);
         | 
| 50 | 
            +
                error ErrorStakingStoreStakeBalanceNotInitialized(NftId nftI);
         | 
| 51 | 
            +
             | 
| 52 | 
            +
                // creating and updating of tvl balance
         | 
| 53 | 
            +
                error ErrorStakingStoreTvlBalanceAlreadyInitialized(NftId nftId, address token);
         | 
| 54 | 
            +
                error ErrorStakingStoreTvlBalanceNotInitialized(NftId nftId, address token);
         | 
| 53 55 |  | 
| 54 56 | 
             
                IRegistry private _registry;
         | 
| 55 | 
            -
                 | 
| 57 | 
            +
                ITargetLimitHandler private _targetLimitHandler;
         | 
| 56 58 | 
             
                StakingReader private _reader;
         | 
| 59 | 
            +
                NftIdSet private _targetNftIdSet;
         | 
| 57 60 |  | 
| 58 | 
            -
                //  | 
| 59 | 
            -
                mapping( | 
| 61 | 
            +
                // target support
         | 
| 62 | 
            +
                mapping(ObjectType targetType => IStaking.SupportInfo) private _supportInfo;
         | 
| 60 63 |  | 
| 61 | 
            -
                //  | 
| 62 | 
            -
                mapping(NftId  | 
| 63 | 
            -
                mapping(NftId  | 
| 64 | 
            -
                mapping(NftId  | 
| 64 | 
            +
                // targets
         | 
| 65 | 
            +
                mapping(NftId targetNftId => IStaking.TargetInfo) private _targetInfo;
         | 
| 66 | 
            +
                mapping(NftId targetNftId => IStaking.LimitInfo) private _limitInfo;
         | 
| 67 | 
            +
                mapping(NftId targetNftId => mapping(address token => IStaking.TvlInfo)) private _tvlInfo;
         | 
| 68 | 
            +
                mapping(NftId targetNftId => address [] token) private _targetToken;
         | 
| 65 69 |  | 
| 66 | 
            -
                 | 
| 67 | 
            -
                mapping( | 
| 70 | 
            +
                // staking rate
         | 
| 71 | 
            +
                mapping(ChainId chainId => mapping(address token => IStaking.TokenInfo)) private _tokenInfo;
         | 
| 68 72 |  | 
| 69 | 
            -
                //  | 
| 70 | 
            -
                mapping(NftId  | 
| 71 | 
            -
                mapping(NftId nftId => mapping(address token => Amount tvlInDip)) private _tvlInDip;
         | 
| 72 | 
            -
                mapping(NftId nftId => Amount tvlRequiredDip) private _tvlRequiredDip;
         | 
| 73 | 
            -
                mapping(NftId nftId => Blocknumber lastUpdatedIn) private _tvlLastUpdatedIn;
         | 
| 73 | 
            +
                // stakes
         | 
| 74 | 
            +
                mapping(NftId stakeNftId => IStaking.StakeInfo) private _stakeInfo;
         | 
| 74 75 |  | 
| 75 76 |  | 
| 76 | 
            -
                constructor( | 
| 77 | 
            +
                constructor(
         | 
| 78 | 
            +
                    IRegistry registry, 
         | 
| 79 | 
            +
                    StakingReader reader
         | 
| 80 | 
            +
                )
         | 
| 77 81 | 
             
                    AccessManaged(msg.sender)
         | 
| 78 82 | 
             
                {
         | 
| 79 83 | 
             
                    // set final authority
         | 
| 80 84 | 
             
                    setAuthority(registry.getAuthority());
         | 
| 81 85 |  | 
| 82 86 | 
             
                    // set internal variables
         | 
| 83 | 
            -
                    _registry = registry; | 
| 87 | 
            +
                    _registry = registry;
         | 
| 84 88 | 
             
                    _reader = reader;
         | 
| 85 89 | 
             
                    _targetNftIdSet = new NftIdSet();
         | 
| 86 90 |  | 
| 91 | 
            +
                    _createInitialSetup();
         | 
| 87 92 | 
             
                    // register protocol target
         | 
| 93 | 
            +
                }
         | 
| 94 | 
            +
             | 
| 95 | 
            +
             | 
| 96 | 
            +
                function _createInitialSetup()
         | 
| 97 | 
            +
                    internal
         | 
| 98 | 
            +
                {
         | 
| 99 | 
            +
                    // define support parameters for protocol target
         | 
| 100 | 
            +
                    _setSupportInfo(
         | 
| 101 | 
            +
                        PROTOCOL(), 
         | 
| 102 | 
            +
                        true, // isSupported
         | 
| 103 | 
            +
                        false, // allowNewTargets,
         | 
| 104 | 
            +
                        true, // crossChainIsSupported
         | 
| 105 | 
            +
                        AmountLib.zero(), // minStakingAmount
         | 
| 106 | 
            +
                        AmountLib.max(), // maxStakingAmount, 
         | 
| 107 | 
            +
                        SecondsLib.oneDay(), // minLockingPeriod, 
         | 
| 108 | 
            +
                        SecondsLib.oneYear(), // maxLockingPeriod, 
         | 
| 109 | 
            +
                        UFixedLib.zero(), // minRewardRate, 
         | 
| 110 | 
            +
                        UFixedLib.toUFixed(15, -2)); // maxRewardRate
         | 
| 111 | 
            +
             | 
| 112 | 
            +
                    // create protocol target
         | 
| 88 113 | 
             
                    _createTarget(
         | 
| 89 114 | 
             
                        NftIdLib.toNftId(1101), 
         | 
| 90 | 
            -
                         | 
| 91 | 
            -
             | 
| 92 | 
            -
             | 
| 93 | 
            -
             | 
| 94 | 
            -
             | 
| 95 | 
            -
             | 
| 115 | 
            +
                        PROTOCOL(),
         | 
| 116 | 
            +
                        TargetManagerLib.getDefaultLockingPeriod(),
         | 
| 117 | 
            +
                        TargetManagerLib.getDefaultRewardRate(),
         | 
| 118 | 
            +
                        false); // no parameter check
         | 
| 119 | 
            +
             | 
| 120 | 
            +
                    // define support parameters for instance targets
         | 
| 121 | 
            +
                    _setSupportInfo(
         | 
| 122 | 
            +
                        INSTANCE(), 
         | 
| 123 | 
            +
                        true, // isSupported
         | 
| 124 | 
            +
                        true, // allowNewTargets,
         | 
| 125 | 
            +
                        true, // allowCrossChain
         | 
| 126 | 
            +
                        AmountLib.toAmount(100000 * 10 ** 18), // minStakingAmount 100'000 DIP
         | 
| 127 | 
            +
                        AmountLib.max(), // maxStakingAmount, 
         | 
| 128 | 
            +
                        SecondsLib.oneDay(), // minLockingPeriod, 
         | 
| 129 | 
            +
                        SecondsLib.oneYear(), // maxLockingPeriod, 
         | 
| 130 | 
            +
                        UFixedLib.zero(), // minRewardRate, 
         | 
| 131 | 
            +
                        UFixedLib.toUFixed(3, -1)); // maxRewardRate 30%
         | 
| 132 | 
            +
                }
         | 
| 133 | 
            +
             | 
| 134 | 
            +
             | 
| 135 | 
            +
                function initialize(
         | 
| 136 | 
            +
                    address targetLimitHandler
         | 
| 137 | 
            +
                )
         | 
| 138 | 
            +
                    external
         | 
| 139 | 
            +
                    initializer()
         | 
| 140 | 
            +
                {
         | 
| 141 | 
            +
                    _targetLimitHandler = ITargetLimitHandler(targetLimitHandler);
         | 
| 142 | 
            +
                }
         | 
| 143 | 
            +
             | 
| 144 | 
            +
             | 
| 145 | 
            +
                //--- dependency management ---------------------------------------------//
         | 
| 146 | 
            +
             | 
| 147 | 
            +
                function setStakingReader(address reader)
         | 
| 148 | 
            +
                    external
         | 
| 149 | 
            +
                    restricted()
         | 
| 150 | 
            +
                {
         | 
| 151 | 
            +
                    address oldReader = address(_reader);
         | 
| 152 | 
            +
                    _reader = StakingReader(reader);
         | 
| 153 | 
            +
             | 
| 154 | 
            +
                    emit IStaking.LogStakingStakingReaderSet(reader, oldReader);
         | 
| 155 | 
            +
                }
         | 
| 156 | 
            +
             | 
| 157 | 
            +
             | 
| 158 | 
            +
                function setTargetLimitHandler(address targetLimitHandler )
         | 
| 159 | 
            +
                    external
         | 
| 160 | 
            +
                    restricted()
         | 
| 161 | 
            +
                {
         | 
| 162 | 
            +
                    address oldTargetHandler = address(_targetLimitHandler);
         | 
| 163 | 
            +
                    _targetLimitHandler = ITargetLimitHandler(targetLimitHandler );
         | 
| 164 | 
            +
             | 
| 165 | 
            +
                    emit IStaking.LogStakingTargetHandlerSet(targetLimitHandler , oldTargetHandler);
         | 
| 166 | 
            +
                }
         | 
| 167 | 
            +
             | 
| 168 | 
            +
                //--- target support management -----------------------------------------//
         | 
| 169 | 
            +
             | 
| 170 | 
            +
                /// @dev Generic setter for support info.
         | 
| 171 | 
            +
                /// Any change in any of the parameters requires to set all parameters.
         | 
| 172 | 
            +
                function setSupportInfo(
         | 
| 173 | 
            +
                    ObjectType targetType,
         | 
| 174 | 
            +
                    bool isSupported,
         | 
| 175 | 
            +
                    bool allowNewTargets,
         | 
| 176 | 
            +
                    bool allowCrossChain,
         | 
| 177 | 
            +
                    Amount minStakingAmount,
         | 
| 178 | 
            +
                    Amount maxStakingAmount,
         | 
| 179 | 
            +
                    Seconds minLockingPeriod,
         | 
| 180 | 
            +
                    Seconds maxLockingPeriod,
         | 
| 181 | 
            +
                    UFixed minRewardRate,
         | 
| 182 | 
            +
                    UFixed maxRewardRate
         | 
| 183 | 
            +
                )
         | 
| 184 | 
            +
                    external
         | 
| 185 | 
            +
                    restricted()
         | 
| 186 | 
            +
                {
         | 
| 187 | 
            +
                    _setSupportInfo(
         | 
| 188 | 
            +
                        targetType,
         | 
| 189 | 
            +
                        isSupported,
         | 
| 190 | 
            +
                        allowNewTargets,
         | 
| 191 | 
            +
                        allowCrossChain,
         | 
| 192 | 
            +
                        minStakingAmount,
         | 
| 193 | 
            +
                        maxStakingAmount,
         | 
| 194 | 
            +
                        minLockingPeriod,
         | 
| 195 | 
            +
                        maxLockingPeriod,
         | 
| 196 | 
            +
                        minRewardRate,
         | 
| 197 | 
            +
                        maxRewardRate);
         | 
| 198 | 
            +
                }
         | 
| 199 | 
            +
             | 
| 200 | 
            +
             | 
| 201 | 
            +
                function _setSupportInfo(
         | 
| 202 | 
            +
                    ObjectType targetType,
         | 
| 203 | 
            +
                    bool isSupported,
         | 
| 204 | 
            +
                    bool allowNewTargets,
         | 
| 205 | 
            +
                    bool allowCrossChain,
         | 
| 206 | 
            +
                    Amount minStakingAmount,
         | 
| 207 | 
            +
                    Amount maxStakingAmount,
         | 
| 208 | 
            +
                    Seconds minLockingPeriod,
         | 
| 209 | 
            +
                    Seconds maxLockingPeriod,
         | 
| 210 | 
            +
                    UFixed minRewardRate,
         | 
| 211 | 
            +
                    UFixed maxRewardRate
         | 
| 212 | 
            +
                )
         | 
| 213 | 
            +
                    private
         | 
| 214 | 
            +
                {
         | 
| 215 | 
            +
                    // checks
         | 
| 216 | 
            +
                    if (targetType.eqz()) {
         | 
| 217 | 
            +
                        revert IStaking.ErrorStakingSupportTypeInvalid(targetType);
         | 
| 218 | 
            +
                    }
         | 
| 219 | 
            +
             | 
| 220 | 
            +
                    // check staking amount limits
         | 
| 221 | 
            +
                    if (minStakingAmount > maxStakingAmount) {
         | 
| 222 | 
            +
                        revert IStaking.ErrorStakingStakingAmountsInvalid(minStakingAmount, maxStakingAmount);
         | 
| 223 | 
            +
                    }
         | 
| 224 | 
            +
             | 
| 225 | 
            +
                    // check locking period limits
         | 
| 226 | 
            +
                    if (minLockingPeriod > maxLockingPeriod) {
         | 
| 227 | 
            +
                        revert IStaking.ErrorStakingLockingPeriodsInvalid(minLockingPeriod, maxLockingPeriod);
         | 
| 228 | 
            +
                    }
         | 
| 229 | 
            +
             | 
| 230 | 
            +
                    // check reward rate limits
         | 
| 231 | 
            +
                    if (minRewardRate > maxRewardRate) {
         | 
| 232 | 
            +
                        revert IStaking.ErrorStakingRewardRatesInvalid(minRewardRate, maxRewardRate);
         | 
| 233 | 
            +
                    }
         | 
| 234 | 
            +
             | 
| 235 | 
            +
                    // effects
         | 
| 236 | 
            +
                    // remember previous last update
         | 
| 237 | 
            +
                    Blocknumber lastUpdateIn = _supportInfo[targetType].lastUpdateIn;
         | 
| 238 | 
            +
             | 
| 239 | 
            +
                    // set parameters to new values
         | 
| 240 | 
            +
                    _supportInfo[targetType].isSupported = isSupported;
         | 
| 241 | 
            +
                    _supportInfo[targetType].allowNewTargets = allowNewTargets;
         | 
| 242 | 
            +
                    _supportInfo[targetType].allowCrossChain = allowCrossChain;
         | 
| 243 | 
            +
                    _supportInfo[targetType].minStakingAmount = minStakingAmount;
         | 
| 244 | 
            +
                    _supportInfo[targetType].maxStakingAmount = maxStakingAmount;
         | 
| 245 | 
            +
                    _supportInfo[targetType].minLockingPeriod = minLockingPeriod;
         | 
| 246 | 
            +
                    _supportInfo[targetType].maxLockingPeriod = maxLockingPeriod;
         | 
| 247 | 
            +
                    _supportInfo[targetType].minRewardRate = minRewardRate;
         | 
| 248 | 
            +
                    _supportInfo[targetType].maxRewardRate = maxRewardRate;
         | 
| 249 | 
            +
                    // update last update
         | 
| 250 | 
            +
                    _supportInfo[targetType].lastUpdateIn = BlocknumberLib.current();
         | 
| 251 | 
            +
             | 
| 252 | 
            +
                    // logging
         | 
| 253 | 
            +
                    emit IStaking.LogStakingSupportInfoSet(
         | 
| 254 | 
            +
                        targetType,
         | 
| 255 | 
            +
                        isSupported,
         | 
| 256 | 
            +
                        allowNewTargets,
         | 
| 257 | 
            +
                        allowCrossChain,
         | 
| 258 | 
            +
                        minStakingAmount,
         | 
| 259 | 
            +
                        maxStakingAmount,
         | 
| 260 | 
            +
                        minLockingPeriod,
         | 
| 261 | 
            +
                        maxLockingPeriod,
         | 
| 262 | 
            +
                        minRewardRate,
         | 
| 263 | 
            +
                        maxRewardRate,
         | 
| 264 | 
            +
                        lastUpdateIn);
         | 
| 96 265 | 
             
                }
         | 
| 97 266 |  | 
| 267 | 
            +
                /// @dev Returns the support info for the specified target type.
         | 
| 268 | 
            +
                function getSupportInfo(ObjectType targetType)
         | 
| 269 | 
            +
                    external
         | 
| 270 | 
            +
                    view
         | 
| 271 | 
            +
                    returns (IStaking.SupportInfo memory supportInfo)
         | 
| 272 | 
            +
                {
         | 
| 273 | 
            +
                    return _supportInfo[targetType];
         | 
| 274 | 
            +
                }
         | 
| 275 | 
            +
             | 
| 276 | 
            +
                //--- token management --------------------------------------------------//
         | 
| 277 | 
            +
             | 
| 278 | 
            +
                /// @dev Registers a token for tvl management.
         | 
| 279 | 
            +
                function addToken(
         | 
| 280 | 
            +
                    ChainId chainId, 
         | 
| 281 | 
            +
                    address token
         | 
| 282 | 
            +
                )
         | 
| 283 | 
            +
                    external
         | 
| 284 | 
            +
                    restricted() // token registry via staking
         | 
| 285 | 
            +
                {
         | 
| 286 | 
            +
                    // checks
         | 
| 287 | 
            +
                    IStaking.TokenInfo storage info = _tokenInfo[chainId][token];
         | 
| 288 | 
            +
             | 
| 289 | 
            +
                    // check token is not yet registered
         | 
| 290 | 
            +
                    if (info.lastUpdateIn.gtz()) {
         | 
| 291 | 
            +
                        revert ErrorStakingStoreTokenAlreadyAdded(chainId, token);
         | 
| 292 | 
            +
                    }
         | 
| 293 | 
            +
             | 
| 294 | 
            +
                    info.stakingRate = UFixedLib.zero();
         | 
| 295 | 
            +
                    info.lastUpdateIn = BlocknumberLib.current();
         | 
| 296 | 
            +
             | 
| 297 | 
            +
                    // logging
         | 
| 298 | 
            +
                    emit IStaking.LogStakingTokenAdded(chainId, token);
         | 
| 299 | 
            +
                }
         | 
| 98 300 |  | 
| 99 | 
            -
                //--- staking rate specific functions -----------------------------------//
         | 
| 100 301 |  | 
| 302 | 
            +
                /// @dev Sets the staking rate for the token.
         | 
| 101 303 | 
             
                function setStakingRate(
         | 
| 102 | 
            -
                     | 
| 304 | 
            +
                    ChainId chainId, 
         | 
| 103 305 | 
             
                    address token, 
         | 
| 104 306 | 
             
                    UFixed stakingRate
         | 
| 105 307 | 
             
                )
         | 
| 106 308 | 
             
                    external
         | 
| 107 | 
            -
                    restricted()
         | 
| 309 | 
            +
                    restricted() // staking
         | 
| 310 | 
            +
                    returns (
         | 
| 311 | 
            +
                        UFixed oldStakingRate,
         | 
| 312 | 
            +
                        Blocknumber lastUpdatedIn
         | 
| 313 | 
            +
                    )
         | 
| 108 314 | 
             
                {
         | 
| 109 | 
            -
                     | 
| 315 | 
            +
                    IStaking.TokenInfo storage info = _tokenInfo[chainId][token];
         | 
| 316 | 
            +
                    if (info.lastUpdateIn.eqz()) {
         | 
| 317 | 
            +
                        revert ErrorStakingStoreTokenUnknown(chainId, token);
         | 
| 318 | 
            +
                    }
         | 
| 319 | 
            +
             | 
| 320 | 
            +
                    // get previous values
         | 
| 321 | 
            +
                    oldStakingRate = info.stakingRate;
         | 
| 322 | 
            +
                    lastUpdatedIn = info.lastUpdateIn;
         | 
| 323 | 
            +
             | 
| 324 | 
            +
                    // update values
         | 
| 325 | 
            +
                    info.stakingRate = stakingRate;
         | 
| 326 | 
            +
                    info.lastUpdateIn = BlocknumberLib.current();
         | 
| 110 327 | 
             
                }
         | 
| 111 328 |  | 
| 112 | 
            -
                //--- target  | 
| 329 | 
            +
                //--- target management -------------------------------------------------//
         | 
| 113 330 |  | 
| 114 331 | 
             
                function createTarget(
         | 
| 115 332 | 
             
                    NftId targetNftId,
         | 
| 116 | 
            -
                     | 
| 333 | 
            +
                    ObjectType objectType,
         | 
| 334 | 
            +
                    Seconds lockingPeriod,
         | 
| 335 | 
            +
                    UFixed rewardRate
         | 
| 117 336 | 
             
                )
         | 
| 118 337 | 
             
                    external
         | 
| 119 | 
            -
                    restricted()
         | 
| 338 | 
            +
                    restricted() // staking
         | 
| 120 339 | 
             
                {
         | 
| 121 | 
            -
                    _createTarget(targetNftId,  | 
| 340 | 
            +
                    _createTarget(targetNftId, objectType, lockingPeriod, rewardRate, true);
         | 
| 122 341 | 
             
                }
         | 
| 123 342 |  | 
| 124 343 |  | 
| 125 | 
            -
                function  | 
| 344 | 
            +
                function setLockingPeriod(
         | 
| 345 | 
            +
                    NftId targetNftId,
         | 
| 346 | 
            +
                    Seconds lockingPeriod
         | 
| 347 | 
            +
                )
         | 
| 348 | 
            +
                    external
         | 
| 349 | 
            +
                    restricted() // staking
         | 
| 350 | 
            +
                {
         | 
| 351 | 
            +
                    // checks
         | 
| 352 | 
            +
                    (
         | 
| 353 | 
            +
                        IStaking.TargetInfo storage targetInfo, 
         | 
| 354 | 
            +
                        Blocknumber lastUpdateIn
         | 
| 355 | 
            +
                    ) = _verifyAndUpdateTarget(targetNftId);
         | 
| 356 | 
            +
             | 
| 357 | 
            +
                    TargetManagerLib.checkLockingPeriod(_reader, targetNftId, targetInfo.objectType, lockingPeriod);
         | 
| 358 | 
            +
             | 
| 359 | 
            +
                    // effects
         | 
| 360 | 
            +
                    Seconds oldLockingPeriod = targetInfo.lockingPeriod;
         | 
| 361 | 
            +
                    targetInfo.lockingPeriod = lockingPeriod;
         | 
| 362 | 
            +
                    targetInfo.lastUpdateIn = BlocknumberLib.current();
         | 
| 363 | 
            +
             | 
| 364 | 
            +
                    // logging
         | 
| 365 | 
            +
                    emit IStaking.LogStakingTargetLockingPeriodSet(targetNftId, lockingPeriod, oldLockingPeriod, lastUpdateIn);
         | 
| 366 | 
            +
                }
         | 
| 367 | 
            +
             | 
| 368 | 
            +
             | 
| 369 | 
            +
                function setRewardRate(
         | 
| 370 | 
            +
                    NftId targetNftId,
         | 
| 371 | 
            +
                    UFixed rewardRate
         | 
| 372 | 
            +
                )
         | 
| 373 | 
            +
                    external
         | 
| 374 | 
            +
                    restricted() // staking
         | 
| 375 | 
            +
                {
         | 
| 376 | 
            +
                    // checks
         | 
| 377 | 
            +
                    (
         | 
| 378 | 
            +
                        IStaking.TargetInfo storage targetInfo, 
         | 
| 379 | 
            +
                        Blocknumber lastUpdateIn
         | 
| 380 | 
            +
                    ) = _verifyAndUpdateTarget(targetNftId);
         | 
| 381 | 
            +
             | 
| 382 | 
            +
                    TargetManagerLib.checkRewardRate(_reader, targetNftId, targetInfo.objectType, rewardRate);
         | 
| 383 | 
            +
             | 
| 384 | 
            +
                    // effects
         | 
| 385 | 
            +
                    UFixed oldRewardRate = targetInfo.rewardRate;
         | 
| 386 | 
            +
                    targetInfo.rewardRate = rewardRate;
         | 
| 387 | 
            +
                    targetInfo.lastUpdateIn = BlocknumberLib.current();
         | 
| 388 | 
            +
             | 
| 389 | 
            +
                    // logging
         | 
| 390 | 
            +
                    emit IStaking.LogStakingTargetRewardRateSet(targetNftId, rewardRate, oldRewardRate, lastUpdateIn);
         | 
| 391 | 
            +
                }
         | 
| 392 | 
            +
             | 
| 393 | 
            +
             | 
| 394 | 
            +
                // TODO refactor to set limits functionality
         | 
| 395 | 
            +
                function setMaxStakedAmount(
         | 
| 396 | 
            +
                    NftId targetNftId,
         | 
| 397 | 
            +
                    Amount stakeLimitAmount
         | 
| 398 | 
            +
                )
         | 
| 399 | 
            +
                    external
         | 
| 400 | 
            +
                    restricted() // staking
         | 
| 401 | 
            +
                    returns (
         | 
| 402 | 
            +
                        Amount oldLimitAmount,
         | 
| 403 | 
            +
                        Blocknumber lastUpdatedIn
         | 
| 404 | 
            +
                    )
         | 
| 405 | 
            +
                {
         | 
| 406 | 
            +
                    IStaking.TargetInfo storage targetInfo;
         | 
| 407 | 
            +
                    (targetInfo, lastUpdatedIn) = _verifyAndUpdateTarget(targetNftId);
         | 
| 408 | 
            +
             | 
| 409 | 
            +
                    oldLimitAmount = targetInfo.limitAmount;
         | 
| 410 | 
            +
                    targetInfo.limitAmount = stakeLimitAmount;
         | 
| 411 | 
            +
             | 
| 412 | 
            +
                    emit IStaking.LogStakingTargetMaxStakedAmountSet(targetNftId, stakeLimitAmount, lastUpdatedIn);
         | 
| 413 | 
            +
             | 
| 414 | 
            +
                }
         | 
| 415 | 
            +
             | 
| 416 | 
            +
             | 
| 417 | 
            +
                function setTargetLimits(
         | 
| 126 418 | 
             
                    NftId targetNftId, 
         | 
| 127 | 
            -
                     | 
| 419 | 
            +
                    Amount marginAmount, 
         | 
| 420 | 
            +
                    Amount hardLimitAmount
         | 
| 421 | 
            +
                )
         | 
| 422 | 
            +
                    external
         | 
| 423 | 
            +
                    virtual
         | 
| 424 | 
            +
                    restricted()
         | 
| 425 | 
            +
                {
         | 
| 426 | 
            +
                    // checks
         | 
| 427 | 
            +
                    IStaking.LimitInfo storage limitInfo = _getAndVerifyLimit(targetNftId);
         | 
| 428 | 
            +
                    Blocknumber lastUpdateIn = limitInfo.lastUpdateIn;
         | 
| 429 | 
            +
             | 
| 430 | 
            +
                    // effects
         | 
| 431 | 
            +
                    limitInfo.marginAmount = marginAmount;
         | 
| 432 | 
            +
                    limitInfo.hardLimitAmount = hardLimitAmount;
         | 
| 433 | 
            +
                    limitInfo.lastUpdateIn = BlocknumberLib.current();
         | 
| 434 | 
            +
             | 
| 435 | 
            +
                    // logging
         | 
| 436 | 
            +
                    emit IStaking.LogStakingTargetLimitsUpdated(
         | 
| 437 | 
            +
                        targetNftId,
         | 
| 438 | 
            +
                        marginAmount,
         | 
| 439 | 
            +
                        hardLimitAmount,
         | 
| 440 | 
            +
                        lastUpdateIn);
         | 
| 441 | 
            +
                }
         | 
| 442 | 
            +
             | 
| 443 | 
            +
             | 
| 444 | 
            +
                function addTargetToken(
         | 
| 445 | 
            +
                    NftId targetNftId,
         | 
| 446 | 
            +
                    address token
         | 
| 128 447 | 
             
                )
         | 
| 129 448 | 
             
                    external
         | 
| 130 449 | 
             
                    restricted()
         | 
| 131 450 | 
             
                {
         | 
| 132 | 
            -
                     | 
| 133 | 
            -
             | 
| 134 | 
            -
             | 
| 451 | 
            +
                    // checks
         | 
| 452 | 
            +
             | 
| 453 | 
            +
                    // skip registering if tvl balance has already been initialized
         | 
| 454 | 
            +
                    IStaking.TvlInfo storage tvlInfo = _tvlInfo[targetNftId][token];
         | 
| 455 | 
            +
                    if (tvlInfo.lastUpdateIn.gtz()) {
         | 
| 456 | 
            +
                        return;
         | 
| 457 | 
            +
                    }
         | 
| 458 | 
            +
             | 
| 459 | 
            +
                    // check target exists
         | 
| 460 | 
            +
                    _getAndVerifyTarget(targetNftId);
         | 
| 461 | 
            +
             | 
| 462 | 
            +
                    // check token is known for chain id of target
         | 
| 463 | 
            +
                    ChainId chainId = ChainIdLib.fromNftId(targetNftId);
         | 
| 464 | 
            +
                    if (_tokenInfo[chainId][token].lastUpdateIn.eqz()) {
         | 
| 465 | 
            +
                        revert ErrorStakingStoreTokenUnknown(chainId, token);
         | 
| 466 | 
            +
                    }
         | 
| 467 | 
            +
             | 
| 468 | 
            +
                    // effects
         | 
| 469 | 
            +
                    tvlInfo.tvlAmount = AmountLib.zero();
         | 
| 470 | 
            +
                    tvlInfo.lastUpdateIn = BlocknumberLib.current();
         | 
| 471 | 
            +
             | 
| 472 | 
            +
                    // add token to list of know tokens for target
         | 
| 473 | 
            +
                    _targetToken[targetNftId].push(token);
         | 
| 135 474 | 
             
                }
         | 
| 136 475 |  | 
| 137 476 |  | 
| 138 | 
            -
                function  | 
| 477 | 
            +
                function refillRewardReserves(
         | 
| 139 478 | 
             
                    NftId targetNftId, 
         | 
| 140 479 | 
             
                    Amount dipAmount
         | 
| 141 480 | 
             
                )
         | 
| @@ -143,14 +482,26 @@ contract StakingStore is | |
| 143 482 | 
             
                    restricted()
         | 
| 144 483 | 
             
                    returns (Amount newReserveBalance)
         | 
| 145 484 | 
             
                {
         | 
| 146 | 
            -
                     | 
| 147 | 
            -
                     | 
| 485 | 
            +
                    // checks
         | 
| 486 | 
            +
                    IStaking.TargetInfo storage targetInfo = _getAndVerifyTarget(targetNftId);
         | 
| 487 | 
            +
                    Blocknumber lastUpdateIn = targetInfo.lastUpdateIn;
         | 
| 488 | 
            +
             | 
| 489 | 
            +
                    // effects
         | 
| 490 | 
            +
                    targetInfo.reserveAmount = targetInfo.reserveAmount + dipAmount;
         | 
| 491 | 
            +
                    targetInfo.lastUpdateIn = BlocknumberLib.current();
         | 
| 148 492 |  | 
| 149 | 
            -
                     | 
| 493 | 
            +
                    // logging
         | 
| 494 | 
            +
                    newReserveBalance = targetInfo.reserveAmount;
         | 
| 495 | 
            +
                    emit IStaking.LogStakingRewardReservesRefilled(
         | 
| 496 | 
            +
                        targetNftId,
         | 
| 497 | 
            +
                        dipAmount,
         | 
| 498 | 
            +
                        _registry.ownerOf(targetNftId),
         | 
| 499 | 
            +
                        newReserveBalance,
         | 
| 500 | 
            +
                        lastUpdateIn);
         | 
| 150 501 | 
             
                }
         | 
| 151 502 |  | 
| 152 503 |  | 
| 153 | 
            -
                function  | 
| 504 | 
            +
                function withdrawRewardReserves(
         | 
| 154 505 | 
             
                    NftId targetNftId, 
         | 
| 155 506 | 
             
                    Amount dipAmount
         | 
| 156 507 | 
             
                )
         | 
| @@ -158,18 +509,20 @@ contract StakingStore is | |
| 158 509 | 
             
                    restricted()
         | 
| 159 510 | 
             
                    returns (Amount newReserveBalance)
         | 
| 160 511 | 
             
                {
         | 
| 161 | 
            -
                     | 
| 162 | 
            -
                     | 
| 163 | 
            -
                        revert ErrorStakingStoreRewardReservesInsufficient(
         | 
| 164 | 
            -
                            targetNftId,
         | 
| 165 | 
            -
                            dipAmount,
         | 
| 166 | 
            -
                            reserveAmount);
         | 
| 167 | 
            -
                    }
         | 
| 512 | 
            +
                    // checks
         | 
| 513 | 
            +
                    IStaking.TargetInfo storage targetInfo = _getAndVerifyTarget(targetNftId);
         | 
| 168 514 |  | 
| 169 | 
            -
                     | 
| 170 | 
            -
                    Blocknumber  | 
| 515 | 
            +
                    // effects
         | 
| 516 | 
            +
                    Blocknumber lastUpdateIn = _decreaseReserves(targetNftId, targetInfo, dipAmount);
         | 
| 171 517 |  | 
| 172 | 
            -
                     | 
| 518 | 
            +
                    // logging
         | 
| 519 | 
            +
                    newReserveBalance = targetInfo.reserveAmount;
         | 
| 520 | 
            +
                    emit IStaking.LogStakingRewardReservesWithdrawn(
         | 
| 521 | 
            +
                        targetNftId,
         | 
| 522 | 
            +
                        dipAmount,
         | 
| 523 | 
            +
                        _registry.ownerOf(targetNftId),
         | 
| 524 | 
            +
                        newReserveBalance,
         | 
| 525 | 
            +
                        lastUpdateIn);
         | 
| 173 526 | 
             
                }
         | 
| 174 527 |  | 
| 175 528 |  | 
| @@ -177,7 +530,6 @@ contract StakingStore is | |
| 177 530 |  | 
| 178 531 | 
             
                function increaseTotalValueLocked(
         | 
| 179 532 | 
             
                    NftId targetNftId,
         | 
| 180 | 
            -
                    UFixed stakingRate,
         | 
| 181 533 | 
             
                    address token,
         | 
| 182 534 | 
             
                    Amount amount
         | 
| 183 535 | 
             
                )
         | 
| @@ -185,32 +537,24 @@ contract StakingStore is | |
| 185 537 | 
             
                    restricted()
         | 
| 186 538 | 
             
                    returns (Amount newBalance)
         | 
| 187 539 | 
             
                {
         | 
| 188 | 
            -
                     | 
| 189 | 
            -
             | 
| 190 | 
            -
             | 
| 191 | 
            -
             | 
| 192 | 
            -
                     | 
| 193 | 
            -
             | 
| 194 | 
            -
                     | 
| 195 | 
            -
                     | 
| 196 | 
            -
             | 
| 197 | 
            -
                     | 
| 198 | 
            -
             | 
| 199 | 
            -
                     | 
| 200 | 
            -
             | 
| 201 | 
            -
                    // update new amount of required dip
         | 
| 202 | 
            -
                    _tvlRequiredDip[targetNftId] = _tvlRequiredDip[targetNftId] - oldDipBalance + newDipBalance;
         | 
| 203 | 
            -
             | 
| 204 | 
            -
                    // update last updated in
         | 
| 205 | 
            -
                    _tvlLastUpdatedIn[targetNftId] = BlocknumberLib.currentBlocknumber();
         | 
| 206 | 
            -
             | 
| 207 | 
            -
                    emit LogStakingStoreTotalValueLockedIncreased(targetNftId, token, amount, newBalance, tvlLastUpdatedIn);
         | 
| 540 | 
            +
                    // checks
         | 
| 541 | 
            +
                    IStaking.TvlInfo storage tvlInfo = _getAndVerifyTvl(targetNftId, token);
         | 
| 542 | 
            +
                    Blocknumber lastUpdateIn = tvlInfo.lastUpdateIn;
         | 
| 543 | 
            +
             | 
| 544 | 
            +
                    // effects
         | 
| 545 | 
            +
                    // update tvl balance and adapts required stakes if necessary
         | 
| 546 | 
            +
                    tvlInfo.tvlAmount = tvlInfo.tvlAmount + amount;
         | 
| 547 | 
            +
                    _checkAndUpdateTargetLimit(targetNftId, token, tvlInfo);
         | 
| 548 | 
            +
                    tvlInfo.lastUpdateIn = BlocknumberLib.current();
         | 
| 549 | 
            +
                    newBalance = tvlInfo.tvlAmount;
         | 
| 550 | 
            +
             | 
| 551 | 
            +
                    // logging
         | 
| 552 | 
            +
                    emit IStaking.LogStakingTvlIncreased(targetNftId, token, amount, newBalance, lastUpdateIn);
         | 
| 208 553 | 
             
                }
         | 
| 209 554 |  | 
| 210 555 |  | 
| 211 556 | 
             
                function decreaseTotalValueLocked(
         | 
| 212 557 | 
             
                    NftId targetNftId,
         | 
| 213 | 
            -
                    UFixed stakingRate,
         | 
| 214 558 | 
             
                    address token,
         | 
| 215 559 | 
             
                    Amount amount
         | 
| 216 560 | 
             
                )
         | 
| @@ -218,389 +562,807 @@ contract StakingStore is | |
| 218 562 | 
             
                    restricted()
         | 
| 219 563 | 
             
                    returns (Amount newBalance)
         | 
| 220 564 | 
             
                {
         | 
| 221 | 
            -
                     | 
| 222 | 
            -
             | 
| 223 | 
            -
             | 
| 224 | 
            -
             | 
| 225 | 
            -
                     | 
| 565 | 
            +
                    // checks
         | 
| 566 | 
            +
                    IStaking.TvlInfo storage tvlInfo = _getAndVerifyTvl(targetNftId, token);
         | 
| 567 | 
            +
                    Blocknumber lastUpdateIn = tvlInfo.lastUpdateIn;
         | 
| 568 | 
            +
             | 
| 569 | 
            +
                    // effects
         | 
| 570 | 
            +
                    // update tvl balance and adapts required stakes if necessary
         | 
| 571 | 
            +
                    tvlInfo.tvlAmount = tvlInfo.tvlAmount - amount;
         | 
| 572 | 
            +
                    _checkAndUpdateTargetLimit(targetNftId, token, tvlInfo);
         | 
| 573 | 
            +
                    tvlInfo.lastUpdateIn = BlocknumberLib.current();
         | 
| 574 | 
            +
                    newBalance = tvlInfo.tvlAmount;
         | 
| 575 | 
            +
             | 
| 576 | 
            +
                    // logging
         | 
| 577 | 
            +
                    emit IStaking.LogStakingTvlDecreased(targetNftId, token, amount, newBalance, lastUpdateIn);
         | 
| 578 | 
            +
                }
         | 
| 226 579 |  | 
| 227 | 
            -
                    newBalance = oldBalance - amount;
         | 
| 228 | 
            -
                    Amount newDipBalance = AmountLib.toAmount((
         | 
| 229 | 
            -
                        stakingRate * newBalance.toUFixed()).toInt());
         | 
| 230 580 |  | 
| 231 | 
            -
             | 
| 232 | 
            -
                     | 
| 233 | 
            -
                     | 
| 581 | 
            +
                function updateTargetLimit(NftId targetNftId)
         | 
| 582 | 
            +
                    external
         | 
| 583 | 
            +
                    restricted()
         | 
| 584 | 
            +
                    returns (Amount stakeLimitAmount)
         | 
| 585 | 
            +
                {
         | 
| 586 | 
            +
                    return _updateTargetLimit(targetNftId);
         | 
| 587 | 
            +
                }
         | 
| 234 588 |  | 
| 235 | 
            -
                    // update new amount of required dip
         | 
| 236 | 
            -
                    _tvlRequiredDip[targetNftId] = _tvlRequiredDip[targetNftId] - oldDipBalance + newDipBalance;
         | 
| 237 589 |  | 
| 238 | 
            -
             | 
| 239 | 
            -
                     | 
| 590 | 
            +
                function _checkAndUpdateTargetLimit(
         | 
| 591 | 
            +
                    NftId targetNftId, 
         | 
| 592 | 
            +
                    address token,
         | 
| 593 | 
            +
                    IStaking.TvlInfo storage tvlInfo
         | 
| 594 | 
            +
                )
         | 
| 595 | 
            +
                    internal
         | 
| 596 | 
            +
                {
         | 
| 597 | 
            +
                    // update counter
         | 
| 598 | 
            +
                    tvlInfo.updatesCounter++;
         | 
| 599 | 
            +
             | 
| 600 | 
            +
                    // check if upgrade is necessary
         | 
| 601 | 
            +
                    bool updateRequired = _targetLimitHandler.isLimitUpdateRequired(
         | 
| 602 | 
            +
                        targetNftId, 
         | 
| 603 | 
            +
                        token, 
         | 
| 604 | 
            +
                        tvlInfo.updatesCounter,
         | 
| 605 | 
            +
                        tvlInfo.tvlBaselineAmount, 
         | 
| 606 | 
            +
                        tvlInfo.tvlAmount);
         | 
| 607 | 
            +
             | 
| 608 | 
            +
                    if (updateRequired) {
         | 
| 609 | 
            +
                        // reset baseline and counter
         | 
| 610 | 
            +
                        tvlInfo.tvlBaselineAmount = tvlInfo.tvlAmount;
         | 
| 611 | 
            +
                        tvlInfo.updatesCounter = 0;
         | 
| 612 | 
            +
             | 
| 613 | 
            +
                        // update limit
         | 
| 614 | 
            +
                        _updateTargetLimit(targetNftId);
         | 
| 615 | 
            +
                    }
         | 
| 616 | 
            +
                }
         | 
| 617 | 
            +
             | 
| 240 618 |  | 
| 241 | 
            -
             | 
| 619 | 
            +
                function _updateTargetLimit(NftId targetNftId)
         | 
| 620 | 
            +
                    internal
         | 
| 621 | 
            +
                    returns (Amount limitAmount)
         | 
| 622 | 
            +
                {
         | 
| 623 | 
            +
                    // checks
         | 
| 624 | 
            +
                    IStaking.TargetInfo storage targetInfo = _getAndVerifyTarget(targetNftId);
         | 
| 625 | 
            +
                    IStaking.LimitInfo storage limitInfo = _getAndVerifyLimit(targetNftId);
         | 
| 626 | 
            +
                    Blocknumber lastUpdateIn = limitInfo.lastUpdateIn;
         | 
| 627 | 
            +
             | 
| 628 | 
            +
                    // calculate max stake amount
         | 
| 629 | 
            +
                    Amount requiredStakeAmount = getRequiredStakeBalance(targetNftId, false);
         | 
| 630 | 
            +
                    // limitAmount = AmountLib.min(
         | 
| 631 | 
            +
                    //     targetInfo.limitAmount, 
         | 
| 632 | 
            +
                    //     requiredStakeAmount + limitInfo.marginAmount);
         | 
| 633 | 
            +
                    
         | 
| 634 | 
            +
                    // add margin to required stakes
         | 
| 635 | 
            +
                    limitAmount = requiredStakeAmount + limitInfo.marginAmount;
         | 
| 636 | 
            +
                    // cap at hard limit
         | 
| 637 | 
            +
                    limitAmount = AmountLib.min(limitAmount, limitInfo.hardLimitAmount);
         | 
| 638 | 
            +
             | 
| 639 | 
            +
                    // effects
         | 
| 640 | 
            +
                    targetInfo.limitAmount = limitAmount;
         | 
| 641 | 
            +
                    targetInfo.lastUpdateIn = BlocknumberLib.current();
         | 
| 642 | 
            +
             | 
| 643 | 
            +
                    // logging
         | 
| 644 | 
            +
                    emit IStaking.LogStakingTargetLimitUpdated(
         | 
| 645 | 
            +
                        targetNftId,
         | 
| 646 | 
            +
                        targetInfo.limitAmount,
         | 
| 647 | 
            +
                        limitInfo.hardLimitAmount,
         | 
| 648 | 
            +
                        requiredStakeAmount,
         | 
| 649 | 
            +
                        targetInfo.stakedAmount,
         | 
| 650 | 
            +
                        lastUpdateIn);
         | 
| 242 651 | 
             
                }
         | 
| 243 652 |  | 
| 244 653 | 
             
                //--- stake specific functions -------------------------------------//
         | 
| 245 654 |  | 
| 246 | 
            -
                function  | 
| 655 | 
            +
                function createStake(
         | 
| 247 656 | 
             
                    NftId stakeNftId, 
         | 
| 248 | 
            -
                     | 
| 657 | 
            +
                    NftId targetNftId,
         | 
| 658 | 
            +
                    address stakeOwner,
         | 
| 659 | 
            +
                    Amount stakeAmount
         | 
| 249 660 | 
             
                )
         | 
| 250 661 | 
             
                    external
         | 
| 251 662 | 
             
                    restricted()
         | 
| 663 | 
            +
                    returns (Timestamp lockedUntil)
         | 
| 252 664 | 
             
                {
         | 
| 253 | 
            -
                     | 
| 254 | 
            -
             | 
| 255 | 
            -
             | 
| 665 | 
            +
                    // checks
         | 
| 666 | 
            +
                    IStaking.StakeInfo storage stakeInfo = _stakeInfo[stakeNftId];
         | 
| 667 | 
            +
                    if (stakeInfo.lastUpdateIn.gtz()) {
         | 
| 668 | 
            +
                        revert ErrorStakingStoreStakeBalanceAlreadyInitialized(stakeNftId);
         | 
| 669 | 
            +
                    }
         | 
| 670 | 
            +
             | 
| 671 | 
            +
                    IStaking.TargetInfo storage targetInfo = _getAndVerifyTarget(targetNftId);
         | 
| 672 | 
            +
                    _checkMaxStakedAmount(targetNftId, targetInfo, stakeAmount);
         | 
| 256 673 |  | 
| 257 | 
            -
                     | 
| 674 | 
            +
                    // effects
         | 
| 675 | 
            +
                    stakeInfo.targetNftId = targetNftId;
         | 
| 676 | 
            +
                    stakeInfo.stakedAmount = AmountLib.zero();
         | 
| 677 | 
            +
                    stakeInfo.rewardAmount = AmountLib.zero();
         | 
| 678 | 
            +
                    stakeInfo.lockedUntil = TimestampLib.current();
         | 
| 679 | 
            +
                    _setStakeLastUpdatesToCurrent(stakeInfo);
         | 
| 680 | 
            +
             | 
| 681 | 
            +
                    // logging for creation of empty stake
         | 
| 682 | 
            +
                    emit IStaking.LogStakingStakeCreated(stakeNftId, stakeInfo.targetNftId, stakeInfo.stakedAmount, stakeInfo.lockedUntil, stakeOwner);
         | 
| 683 | 
            +
             | 
| 684 | 
            +
                    // process stake amount
         | 
| 685 | 
            +
                    _stake(stakeNftId, stakeInfo, targetInfo, targetInfo.lockingPeriod, stakeAmount);
         | 
| 686 | 
            +
             | 
| 687 | 
            +
                    return stakeInfo.lockedUntil;
         | 
| 258 688 | 
             
                }
         | 
| 259 689 |  | 
| 260 | 
            -
             | 
| 261 | 
            -
             | 
| 262 | 
            -
                     | 
| 690 | 
            +
             | 
| 691 | 
            +
                function stake(
         | 
| 692 | 
            +
                    NftId stakeNftId,
         | 
| 693 | 
            +
                    bool updateRewards,
         | 
| 694 | 
            +
                    bool restakeRewards,
         | 
| 695 | 
            +
                    Seconds additionalLockingPeriod,
         | 
| 696 | 
            +
                    Amount stakeAmount
         | 
| 263 697 | 
             
                )
         | 
| 264 698 | 
             
                    external
         | 
| 265 699 | 
             
                    restricted()
         | 
| 266 700 | 
             
                {
         | 
| 267 | 
            -
                     | 
| 268 | 
            -
             | 
| 269 | 
            -
             | 
| 270 | 
            -
                        KEEP_STATE());
         | 
| 271 | 
            -
                }
         | 
| 701 | 
            +
                    // checks
         | 
| 702 | 
            +
                    IStaking.StakeInfo storage stakeInfo = _getAndVerifyStake(stakeNftId);
         | 
| 703 | 
            +
                    IStaking.TargetInfo storage targetInfo = _getAndVerifyTarget(stakeInfo.targetNftId);
         | 
| 272 704 |  | 
| 273 | 
            -
             | 
| 705 | 
            +
                    if (updateRewards) {
         | 
| 706 | 
            +
                        _updateRewards(stakeNftId, stakeInfo, targetInfo);
         | 
| 707 | 
            +
                    }
         | 
| 274 708 |  | 
| 709 | 
            +
                    if (restakeRewards) {
         | 
| 710 | 
            +
                        _restakeRewards(stakeNftId, stakeInfo, targetInfo);
         | 
| 711 | 
            +
                    }
         | 
| 275 712 |  | 
| 276 | 
            -
             | 
| 277 | 
            -
             | 
| 278 | 
            -
             | 
| 279 | 
            -
             | 
| 713 | 
            +
                    _stake(stakeNftId, stakeInfo, targetInfo, additionalLockingPeriod, stakeAmount);
         | 
| 714 | 
            +
                }
         | 
| 715 | 
            +
             | 
| 716 | 
            +
             | 
| 717 | 
            +
                function unstake(
         | 
| 718 | 
            +
                    NftId stakeNftId,
         | 
| 719 | 
            +
                    bool updateRewards,
         | 
| 720 | 
            +
                    bool restakeRewards,
         | 
| 721 | 
            +
                    Amount maxUnstakeAmount
         | 
| 280 722 | 
             
                )
         | 
| 281 723 | 
             
                    external
         | 
| 282 724 | 
             
                    restricted()
         | 
| 725 | 
            +
                    returns (Amount unstakedAmount)
         | 
| 283 726 | 
             
                {
         | 
| 284 | 
            -
                     | 
| 727 | 
            +
                    // checks
         | 
| 728 | 
            +
                    IStaking.StakeInfo storage stakeInfo = _getAndVerifyStake(stakeNftId);
         | 
| 729 | 
            +
                    IStaking.TargetInfo storage targetInfo = _getAndVerifyTarget(stakeInfo.targetNftId);
         | 
| 285 730 |  | 
| 286 | 
            -
                     | 
| 287 | 
            -
                         | 
| 288 | 
            -
             | 
| 289 | 
            -
                        _rewardBalance[nftId]); // unchanged reward balance
         | 
| 731 | 
            +
                    if (updateRewards) {
         | 
| 732 | 
            +
                        _updateRewards(stakeNftId, stakeInfo, targetInfo);
         | 
| 733 | 
            +
                    }
         | 
| 290 734 |  | 
| 291 | 
            -
                     | 
| 292 | 
            -
                         | 
| 293 | 
            -
             | 
| 294 | 
            -
                        _rewardBalance[targetNftId]);
         | 
| 735 | 
            +
                    if (restakeRewards) {
         | 
| 736 | 
            +
                        _restakeRewards(stakeNftId, stakeInfo, targetInfo);
         | 
| 737 | 
            +
                    }
         | 
| 295 738 |  | 
| 296 | 
            -
                     | 
| 739 | 
            +
                    return _unstake(stakeNftId, stakeInfo, targetInfo, maxUnstakeAmount);
         | 
| 297 740 | 
             
                }
         | 
| 298 741 |  | 
| 299 742 |  | 
| 300 | 
            -
                function  | 
| 301 | 
            -
                    NftId nftId, 
         | 
| 302 | 
            -
                    NftId targetNftId,
         | 
| 303 | 
            -
                    Amount rewardIncrementAmount
         | 
| 304 | 
            -
                )
         | 
| 743 | 
            +
                function updateRewards(NftId stakeNftId)
         | 
| 305 744 | 
             
                    external
         | 
| 306 745 | 
             
                    restricted()
         | 
| 307 746 | 
             
                {
         | 
| 308 | 
            -
                     | 
| 309 | 
            -
                     | 
| 310 | 
            -
                     | 
| 311 | 
            -
             | 
| 312 | 
            -
                    // move all rewards to stake balance
         | 
| 313 | 
            -
                    _updateStakeBalance(
         | 
| 314 | 
            -
                        nftId, 
         | 
| 315 | 
            -
                        stakeAmount + rewardAmount + rewardIncrementAmount, // new stake balance
         | 
| 316 | 
            -
                        AmountLib.zero()); // new reward balance
         | 
| 317 | 
            -
             | 
| 318 | 
            -
                    _updateTargetBalance(
         | 
| 319 | 
            -
                        targetNftId,
         | 
| 320 | 
            -
                        _stakeBalance[targetNftId] + rewardAmount + rewardIncrementAmount,
         | 
| 321 | 
            -
                        _rewardBalance[targetNftId] - rewardAmount);
         | 
| 322 | 
            -
             | 
| 323 | 
            -
                    emit LogStakingStoreRewardsRestaked(nftId, stakeAmount, rewardAmount, rewardIncrementAmount, _stakeBalance[nftId], lastUpdatedIn);
         | 
| 747 | 
            +
                    // checks
         | 
| 748 | 
            +
                    IStaking.StakeInfo storage stakeInfo = _getAndVerifyStake(stakeNftId);
         | 
| 749 | 
            +
                    IStaking.TargetInfo storage targetInfo = _getAndVerifyTarget(stakeInfo.targetNftId);
         | 
| 750 | 
            +
                    _updateRewards(stakeNftId, stakeInfo, targetInfo);
         | 
| 324 751 | 
             
                }
         | 
| 325 752 |  | 
| 326 753 |  | 
| 327 | 
            -
                function  | 
| 328 | 
            -
                    NftId  | 
| 329 | 
            -
                     | 
| 330 | 
            -
                    Amount rewardIncrementAmount
         | 
| 754 | 
            +
                function restakeRewards(
         | 
| 755 | 
            +
                    NftId stakeNftId,
         | 
| 756 | 
            +
                    bool updateRewards
         | 
| 331 757 | 
             
                )
         | 
| 332 758 | 
             
                    external
         | 
| 333 759 | 
             
                    restricted()
         | 
| 334 760 | 
             
                {
         | 
| 335 | 
            -
                     | 
| 761 | 
            +
                    // checks
         | 
| 762 | 
            +
                    IStaking.StakeInfo storage stakeInfo = _getAndVerifyStake(stakeNftId);
         | 
| 763 | 
            +
                    IStaking.TargetInfo storage targetInfo = _getAndVerifyTarget(stakeInfo.targetNftId);
         | 
| 336 764 |  | 
| 337 | 
            -
                     | 
| 338 | 
            -
             | 
| 339 | 
            -
             | 
| 340 | 
            -
                        _stakeBalance[nftId], // unchanged stake balance
         | 
| 341 | 
            -
                        _rewardBalance[nftId] + rewardIncrementAmount); // new reward balance
         | 
| 342 | 
            -
             | 
| 343 | 
            -
                    _updateTargetBalance(
         | 
| 344 | 
            -
                        targetNftId,
         | 
| 345 | 
            -
                        _stakeBalance[targetNftId],
         | 
| 346 | 
            -
                        _rewardBalance[targetNftId] + rewardIncrementAmount);
         | 
| 765 | 
            +
                    if (updateRewards) {
         | 
| 766 | 
            +
                        _updateRewards(stakeNftId, stakeInfo, targetInfo);
         | 
| 767 | 
            +
                    }
         | 
| 347 768 |  | 
| 348 | 
            -
                     | 
| 769 | 
            +
                    _restakeRewards(stakeNftId, stakeInfo, targetInfo);
         | 
| 349 770 | 
             
                }
         | 
| 350 771 |  | 
| 351 772 |  | 
| 352 | 
            -
                function  | 
| 353 | 
            -
                    NftId  | 
| 354 | 
            -
                     | 
| 773 | 
            +
                function claimRewards(
         | 
| 774 | 
            +
                    NftId stakeNftId,
         | 
| 775 | 
            +
                    bool updateRewards,
         | 
| 355 776 | 
             
                    Amount maxClaimAmount
         | 
| 356 777 | 
             
                )
         | 
| 357 778 | 
             
                    external
         | 
| 358 779 | 
             
                    restricted()
         | 
| 359 780 | 
             
                    returns (Amount claimedAmount)
         | 
| 360 781 | 
             
                {
         | 
| 361 | 
            -
                     | 
| 782 | 
            +
                    // checks
         | 
| 783 | 
            +
                    IStaking.StakeInfo storage stakeInfo = _getAndVerifyStake(stakeNftId);
         | 
| 784 | 
            +
                    IStaking.TargetInfo storage targetInfo = _getAndVerifyTarget(stakeInfo.targetNftId);
         | 
| 362 785 |  | 
| 363 | 
            -
                     | 
| 364 | 
            -
             | 
| 786 | 
            +
                    if (updateRewards) {
         | 
| 787 | 
            +
                        _updateRewards(stakeNftId, stakeInfo, targetInfo);
         | 
| 788 | 
            +
                    }
         | 
| 365 789 |  | 
| 366 | 
            -
                     | 
| 367 | 
            -
             | 
| 368 | 
            -
                        nftId, 
         | 
| 369 | 
            -
                        _stakeBalance[nftId], // unchanged stake balance
         | 
| 370 | 
            -
                        _rewardBalance[nftId] - claimedAmount); // new reward balance
         | 
| 790 | 
            +
                    claimedAmount = _claimRewards(stakeNftId, stakeInfo, targetInfo, maxClaimAmount);
         | 
| 791 | 
            +
                }
         | 
| 371 792 |  | 
| 372 | 
            -
             | 
| 373 | 
            -
                        targetNftId,
         | 
| 374 | 
            -
                        _stakeBalance[targetNftId],
         | 
| 375 | 
            -
                        _rewardBalance[targetNftId] - claimedAmount);
         | 
| 793 | 
            +
                //--- view functions -----------------------------------------------//
         | 
| 376 794 |  | 
| 377 | 
            -
             | 
| 795 | 
            +
                function getStakingReader() external view returns (StakingReader stakingReader){
         | 
| 796 | 
            +
                    return _reader;
         | 
| 378 797 | 
             
                }
         | 
| 379 798 |  | 
| 799 | 
            +
                function getTargetManager() external view returns (ITargetLimitHandler targetLimitHandler ){
         | 
| 800 | 
            +
                    return _targetLimitHandler;
         | 
| 801 | 
            +
                }
         | 
| 380 802 |  | 
| 381 | 
            -
             | 
| 382 | 
            -
             | 
| 383 | 
            -
                     | 
| 384 | 
            -
             | 
| 385 | 
            -
             | 
| 803 | 
            +
             | 
| 804 | 
            +
                function exists(NftId stakeNftId) external view returns (bool) { 
         | 
| 805 | 
            +
                    return _stakeInfo[stakeNftId].lastUpdateIn.gtz();
         | 
| 806 | 
            +
                }
         | 
| 807 | 
            +
             | 
| 808 | 
            +
             | 
| 809 | 
            +
                function getRequiredStakeBalance(
         | 
| 810 | 
            +
                    NftId targetNftId,
         | 
| 811 | 
            +
                    bool includeTargetTypeRequirements
         | 
| 386 812 | 
             
                )
         | 
| 387 | 
            -
                     | 
| 388 | 
            -
                     | 
| 389 | 
            -
                    returns (
         | 
| 390 | 
            -
                        Amount unstakedAmount,
         | 
| 391 | 
            -
                        Amount claimedAmount
         | 
| 392 | 
            -
                    )
         | 
| 813 | 
            +
                    public
         | 
| 814 | 
            +
                    view
         | 
| 815 | 
            +
                    returns (Amount requiredStakeAmount)
         | 
| 393 816 | 
             
                {
         | 
| 394 | 
            -
                     | 
| 817 | 
            +
                    address [] memory tokens = _targetToken[targetNftId];
         | 
| 818 | 
            +
                    if (tokens.length == 0) {
         | 
| 819 | 
            +
                        return AmountLib.zero();
         | 
| 820 | 
            +
                    }
         | 
| 395 821 |  | 
| 396 | 
            -
                    //  | 
| 397 | 
            -
                     | 
| 398 | 
            -
                     | 
| 822 | 
            +
                    // calculate tvl based required stake amount
         | 
| 823 | 
            +
                    requiredStakeAmount = AmountLib.zero();
         | 
| 824 | 
            +
                    ChainId targetChainId = _targetInfo[targetNftId].chainId;
         | 
| 825 | 
            +
                    address token;
         | 
| 826 | 
            +
                    Amount tvlAmount;
         | 
| 827 | 
            +
                    UFixed stakingRate;
         | 
| 399 828 |  | 
| 400 | 
            -
                     | 
| 401 | 
            -
             | 
| 402 | 
            -
                         | 
| 403 | 
            -
                         | 
| 404 | 
            -
                        _rewardBalance[nftId] - claimedAmount); // new reward balance
         | 
| 829 | 
            +
                    for (uint256 i = 0; i < tokens.length; i++) {
         | 
| 830 | 
            +
                        token = tokens[i];
         | 
| 831 | 
            +
                        tvlAmount = _tvlInfo[targetNftId][token].tvlAmount;
         | 
| 832 | 
            +
                        if (tvlAmount.eqz()) { continue; }
         | 
| 405 833 |  | 
| 406 | 
            -
             | 
| 407 | 
            -
                         | 
| 408 | 
            -
             | 
| 409 | 
            -
                         | 
| 834 | 
            +
                        stakingRate = _tokenInfo[targetChainId][token].stakingRate;
         | 
| 835 | 
            +
                        if (stakingRate.eqz()) { continue; }
         | 
| 836 | 
            +
             | 
| 837 | 
            +
                        requiredStakeAmount = requiredStakeAmount + tvlAmount.multiplyWith(stakingRate);
         | 
| 838 | 
            +
                    }
         | 
| 839 | 
            +
             | 
| 840 | 
            +
                    // update required amount based on target type
         | 
| 841 | 
            +
                    if (includeTargetTypeRequirements) {
         | 
| 842 | 
            +
                        ObjectType targetType = _targetInfo[targetNftId].objectType;
         | 
| 843 | 
            +
                        IStaking.SupportInfo storage supportInfo = _supportInfo[targetType];
         | 
| 410 844 |  | 
| 411 | 
            -
             | 
| 412 | 
            -
             | 
| 845 | 
            +
                        if (requiredStakeAmount < supportInfo.minStakingAmount) {
         | 
| 846 | 
            +
                            requiredStakeAmount = supportInfo.minStakingAmount;
         | 
| 847 | 
            +
                        } else if (requiredStakeAmount > supportInfo.maxStakingAmount) {
         | 
| 848 | 
            +
                            requiredStakeAmount = supportInfo.maxStakingAmount;
         | 
| 849 | 
            +
                        }
         | 
| 850 | 
            +
                    }
         | 
| 413 851 | 
             
                }
         | 
| 414 852 |  | 
| 415 | 
            -
                //--- view functions -----------------------------------------------//
         | 
| 416 853 |  | 
| 417 | 
            -
                 | 
| 418 | 
            -
             | 
| 854 | 
            +
                /// @dev Returns true iff current stake amount is still locked
         | 
| 855 | 
            +
                function isStakeLocked(NftId stakeNftId) public view returns (bool) { 
         | 
| 856 | 
            +
                    return _stakeInfo[stakeNftId].lockedUntil > TimestampLib.current(); 
         | 
| 419 857 | 
             
                }
         | 
| 420 858 |  | 
| 421 | 
            -
             | 
| 422 | 
            -
                 | 
| 423 | 
            -
             | 
| 859 | 
            +
             | 
| 860 | 
            +
                /// @dev Returns the stake infos for the specified stake.
         | 
| 861 | 
            +
                function getStakeInfo(NftId stakeNftId) external view returns (IStaking.StakeInfo memory stakeInfo) { 
         | 
| 862 | 
            +
                    return _stakeInfo[stakeNftId]; 
         | 
| 424 863 | 
             
                }
         | 
| 425 864 |  | 
| 426 | 
            -
                function getStakingRate(uint256 chainId, address token) external view returns (UFixed stakingRate) { return _stakingRate[chainId][token]; }
         | 
| 427 865 |  | 
| 428 | 
            -
                 | 
| 866 | 
            +
                /// @dev Returns the stake infos for the specified stake.
         | 
| 867 | 
            +
                function getStakeTarget(NftId stakeNftId) external view returns (NftId targetNftId) { 
         | 
| 868 | 
            +
                    return _stakeInfo[stakeNftId].targetNftId; 
         | 
| 869 | 
            +
                }
         | 
| 429 870 |  | 
| 430 | 
            -
                function getTotalValueLocked(NftId nftId, address token) external view returns (Amount tvlBalanceAmount) { return _tvlBalance[nftId][token]; }
         | 
| 431 | 
            -
                function getRequiredStakeBalance(NftId nftId) external view returns (Amount requiredAmount) { return _tvlRequiredDip[nftId]; }
         | 
| 432 871 |  | 
| 433 | 
            -
                 | 
| 434 | 
            -
                function  | 
| 435 | 
            -
             | 
| 436 | 
            -
                 | 
| 437 | 
            -
                function getBalanceUpdatedIn(NftId nftId) external view returns (Blocknumber blocknumber) { return _lastUpdatedIn[nftId]; }
         | 
| 872 | 
            +
                /// @dev Returns the target infos for the specified target.
         | 
| 873 | 
            +
                function getTargetInfo(NftId targetNftId) external view returns (IStaking.TargetInfo memory targetInfo) { 
         | 
| 874 | 
            +
                    return _targetInfo[targetNftId]; 
         | 
| 875 | 
            +
                }
         | 
| 438 876 |  | 
| 439 877 |  | 
| 440 | 
            -
                 | 
| 441 | 
            -
             | 
| 442 | 
            -
                     | 
| 443 | 
            -
                    returns (
         | 
| 444 | 
            -
                        Amount stakeBalance,
         | 
| 445 | 
            -
                        Amount rewardBalance,
         | 
| 446 | 
            -
                        Amount reserveBalance,
         | 
| 447 | 
            -
                        Blocknumber lastUpdatedIn
         | 
| 448 | 
            -
                    )
         | 
| 449 | 
            -
                {
         | 
| 450 | 
            -
                    stakeBalance = _stakeBalance[nftId];
         | 
| 451 | 
            -
                    rewardBalance = _rewardBalance[nftId];
         | 
| 452 | 
            -
                    reserveBalance = _reserveBalance[nftId];
         | 
| 453 | 
            -
                    lastUpdatedIn = _lastUpdatedIn[nftId];
         | 
| 878 | 
            +
                /// @dev Returns the target limit infos for the specified target.
         | 
| 879 | 
            +
                function getLimitInfo(NftId targetNftId) external view returns (IStaking.LimitInfo memory limitInfo) { 
         | 
| 880 | 
            +
                    return _limitInfo[targetNftId]; 
         | 
| 454 881 | 
             
                }
         | 
| 455 882 |  | 
| 456 883 |  | 
| 457 | 
            -
                 | 
| 458 | 
            -
             | 
| 459 | 
            -
                     | 
| 884 | 
            +
                /// @dev Returns the tvl infos for the specified target.
         | 
| 885 | 
            +
                function getTvlInfo(NftId targetNftId, address token) external view returns (IStaking.TvlInfo memory tvlInfo) {
         | 
| 886 | 
            +
                    return _tvlInfo[targetNftId][token];
         | 
| 887 | 
            +
                }
         | 
| 888 | 
            +
             | 
| 889 | 
            +
             | 
| 890 | 
            +
                /// @dev Returns the tvl infos for the specified target.
         | 
| 891 | 
            +
                function getTokenInfo(ChainId chainId, address token) external view returns (IStaking.TokenInfo memory tokenInfo) {
         | 
| 892 | 
            +
                    return _tokenInfo[chainId][token];
         | 
| 893 | 
            +
                }
         | 
| 894 | 
            +
             | 
| 895 | 
            +
                function hasTokenInfo(ChainId chainId, address token) external view returns (bool) {
         | 
| 896 | 
            +
                    return _tokenInfo[chainId][token].lastUpdateIn.gtz();
         | 
| 897 | 
            +
                }
         | 
| 898 | 
            +
             | 
| 899 | 
            +
             | 
| 900 | 
            +
                function getTargetSet() external view returns (NftIdSet targetNftIdSet) { 
         | 
| 901 | 
            +
                    return _targetNftIdSet;
         | 
| 902 | 
            +
                }
         | 
| 903 | 
            +
             | 
| 904 | 
            +
                //--- internal functions -----------------------------------------------//
         | 
| 905 | 
            +
             | 
| 906 | 
            +
                function _verifyAndUpdateTarget(NftId targetNftId)
         | 
| 907 | 
            +
                    private
         | 
| 460 908 | 
             
                    returns (
         | 
| 461 | 
            -
                         | 
| 462 | 
            -
                         | 
| 463 | 
            -
                        Timestamp lastUpdatedAt
         | 
| 909 | 
            +
                        IStaking.TargetInfo storage targetInfo,
         | 
| 910 | 
            +
                        Blocknumber lastUpdatedIn
         | 
| 464 911 | 
             
                    )
         | 
| 465 912 | 
             
                {
         | 
| 466 | 
            -
                     | 
| 467 | 
            -
                     | 
| 468 | 
            -
                     | 
| 913 | 
            +
                    // checks
         | 
| 914 | 
            +
                    targetInfo = _getAndVerifyTarget(targetNftId);
         | 
| 915 | 
            +
                    lastUpdatedIn = targetInfo.lastUpdateIn;
         | 
| 916 | 
            +
                    targetInfo.lastUpdateIn = BlocknumberLib.current();
         | 
| 469 917 | 
             
                }
         | 
| 470 918 |  | 
| 471 | 
            -
                //--- private functions -------------------------------------------//
         | 
| 472 919 |  | 
| 473 920 | 
             
                function _createTarget(
         | 
| 474 921 | 
             
                    NftId targetNftId,
         | 
| 475 | 
            -
                     | 
| 922 | 
            +
                    ObjectType objectType,
         | 
| 923 | 
            +
                    Seconds lockingPeriod,
         | 
| 924 | 
            +
                    UFixed rewardRate,
         | 
| 925 | 
            +
                    bool checkParameters
         | 
| 476 926 | 
             
                )
         | 
| 477 927 | 
             
                    private
         | 
| 478 928 | 
             
                {
         | 
| 479 | 
            -
                     | 
| 480 | 
            -
             | 
| 481 | 
            -
                         | 
| 482 | 
            -
             | 
| 483 | 
            -
             | 
| 484 | 
            -
             | 
| 485 | 
            -
             | 
| 929 | 
            +
                    // checks
         | 
| 930 | 
            +
                    if (checkParameters) {
         | 
| 931 | 
            +
                        TargetManagerLib.checkTargetParameters(
         | 
| 932 | 
            +
                            _registry, 
         | 
| 933 | 
            +
                            _reader, 
         | 
| 934 | 
            +
                            targetNftId, 
         | 
| 935 | 
            +
                            objectType, 
         | 
| 936 | 
            +
                            lockingPeriod, 
         | 
| 937 | 
            +
                            rewardRate);
         | 
| 938 | 
            +
                    }
         | 
| 486 939 |  | 
| 940 | 
            +
                    // effects
         | 
| 941 | 
            +
             | 
| 942 | 
            +
                    // target info
         | 
| 943 | 
            +
                    IStaking.TargetInfo storage targetInfo = _targetInfo[targetNftId];
         | 
| 944 | 
            +
                    targetInfo.stakedAmount = AmountLib.zero();
         | 
| 945 | 
            +
                    targetInfo.rewardAmount = AmountLib.zero();
         | 
| 946 | 
            +
                    targetInfo.reserveAmount = AmountLib.zero();
         | 
| 947 | 
            +
                    targetInfo.limitAmount = AmountLib.max();
         | 
| 948 | 
            +
             | 
| 949 | 
            +
                    targetInfo.objectType = objectType;
         | 
| 950 | 
            +
                    targetInfo.lockingPeriod = lockingPeriod;
         | 
| 951 | 
            +
                    targetInfo.rewardRate = rewardRate;
         | 
| 952 | 
            +
                    targetInfo.chainId = ChainIdLib.fromNftId(targetNftId);
         | 
| 953 | 
            +
                    targetInfo.lastUpdateIn = BlocknumberLib.current();
         | 
| 954 | 
            +
             | 
| 955 | 
            +
                    // create limit info
         | 
| 956 | 
            +
                    _setLimits(
         | 
| 957 | 
            +
                        _limitInfo[targetNftId],
         | 
| 958 | 
            +
                        targetNftId, 
         | 
| 959 | 
            +
                        AmountLib.toAmount(AmountLib.max().toInt() / 2), // margin limit
         | 
| 960 | 
            +
                        AmountLib.max()); // hard limit
         | 
| 961 | 
            +
             | 
| 962 | 
            +
                    // add new target to target set
         | 
| 487 963 | 
             
                    _targetNftIdSet.add(targetNftId);
         | 
| 964 | 
            +
             | 
| 965 | 
            +
                    // logging
         | 
| 966 | 
            +
                    emit IStaking.LogStakingTargetCreated(targetNftId, objectType, lockingPeriod, rewardRate);
         | 
| 488 967 | 
             
                }
         | 
| 489 968 |  | 
| 490 | 
            -
             | 
| 491 | 
            -
             | 
| 492 | 
            -
                     | 
| 969 | 
            +
             | 
| 970 | 
            +
                function _setLimits(
         | 
| 971 | 
            +
                    IStaking.LimitInfo storage limitInfo,
         | 
| 972 | 
            +
                    NftId targetNftId,
         | 
| 973 | 
            +
                    Amount marginAmount,
         | 
| 974 | 
            +
                    Amount hardLimitAmount
         | 
| 493 975 | 
             
                )
         | 
| 494 976 | 
             
                    private
         | 
| 495 | 
            -
                    returns (Blocknumber lastUpdatedIn)
         | 
| 496 977 | 
             
                {
         | 
| 497 | 
            -
                     | 
| 498 | 
            -
             | 
| 499 | 
            -
                     | 
| 978 | 
            +
                    // effects
         | 
| 979 | 
            +
                    Blocknumber lastUpdateIn = limitInfo.lastUpdateIn;
         | 
| 980 | 
            +
                    limitInfo.marginAmount = marginAmount;
         | 
| 981 | 
            +
                    limitInfo.hardLimitAmount = hardLimitAmount;
         | 
| 982 | 
            +
                    limitInfo.lastUpdateIn = BlocknumberLib.current();
         | 
| 983 | 
            +
             | 
| 984 | 
            +
                    // logging
         | 
| 985 | 
            +
                    emit IStaking.LogStakingLimitsSet(targetNftId, limitInfo.marginAmount , limitInfo.hardLimitAmount, lastUpdateIn);
         | 
| 986 | 
            +
                }
         | 
| 987 | 
            +
             | 
| 500 988 |  | 
| 501 | 
            -
             | 
| 989 | 
            +
                function _spendRewardReserves(
         | 
| 990 | 
            +
                    NftId targetNftId, 
         | 
| 991 | 
            +
                    IStaking.TargetInfo storage targetInfo,
         | 
| 992 | 
            +
                    Amount dipAmount
         | 
| 993 | 
            +
                )
         | 
| 994 | 
            +
                    private
         | 
| 995 | 
            +
                {
         | 
| 996 | 
            +
                    Blocknumber lastUpdateIn = _decreaseReserves(targetNftId, targetInfo, dipAmount);
         | 
| 502 997 |  | 
| 503 | 
            -
                     | 
| 504 | 
            -
                     | 
| 998 | 
            +
                    // logging
         | 
| 999 | 
            +
                    emit IStaking.LogStakingRewardReservesSpent(
         | 
| 1000 | 
            +
                        targetNftId,
         | 
| 1001 | 
            +
                        dipAmount,
         | 
| 1002 | 
            +
                        targetInfo.reserveAmount,
         | 
| 1003 | 
            +
                        lastUpdateIn);
         | 
| 505 1004 | 
             
                }
         | 
| 506 1005 |  | 
| 507 1006 |  | 
| 508 | 
            -
                function  | 
| 1007 | 
            +
                function _decreaseReserves(
         | 
| 1008 | 
            +
                    NftId targetNftId,
         | 
| 1009 | 
            +
                    IStaking.TargetInfo storage targetInfo, 
         | 
| 1010 | 
            +
                    Amount dipAmount
         | 
| 1011 | 
            +
                )
         | 
| 509 1012 | 
             
                    private
         | 
| 1013 | 
            +
                    returns ( Blocknumber lastUpdateIn)
         | 
| 510 1014 | 
             
                {
         | 
| 511 | 
            -
                     | 
| 512 | 
            -
             | 
| 1015 | 
            +
                    lastUpdateIn = targetInfo.lastUpdateIn;
         | 
| 1016 | 
            +
             | 
| 1017 | 
            +
                    // check if reserves are sufficient
         | 
| 1018 | 
            +
                    if (dipAmount > targetInfo.reserveAmount) {
         | 
| 1019 | 
            +
                        revert ErrorStakingStoreRewardReservesInsufficient(
         | 
| 1020 | 
            +
                            targetNftId,
         | 
| 1021 | 
            +
                            targetInfo.reserveAmount,
         | 
| 1022 | 
            +
                            dipAmount);
         | 
| 513 1023 | 
             
                    }
         | 
| 514 1024 |  | 
| 515 | 
            -
                    //  | 
| 516 | 
            -
                     | 
| 517 | 
            -
                     | 
| 518 | 
            -
             | 
| 1025 | 
            +
                    // effects
         | 
| 1026 | 
            +
                    targetInfo.reserveAmount = targetInfo.reserveAmount - dipAmount;
         | 
| 1027 | 
            +
                    targetInfo.lastUpdateIn = BlocknumberLib.current();
         | 
| 1028 | 
            +
                }
         | 
| 519 1029 |  | 
| 520 | 
            -
             | 
| 521 | 
            -
             | 
| 522 | 
            -
                     | 
| 1030 | 
            +
             | 
| 1031 | 
            +
                function _updateRewards(
         | 
| 1032 | 
            +
                    NftId stakeNftId,
         | 
| 1033 | 
            +
                    IStaking.StakeInfo storage stakeInfo,
         | 
| 1034 | 
            +
                    IStaking.TargetInfo storage targetInfo
         | 
| 1035 | 
            +
                )
         | 
| 1036 | 
            +
                    internal
         | 
| 1037 | 
            +
                    returns (Amount rewardIncreaseAmount)
         | 
| 1038 | 
            +
                {
         | 
| 1039 | 
            +
                    // return if reward rate is zero
         | 
| 1040 | 
            +
                    if (targetInfo.rewardRate.eqz()) {
         | 
| 1041 | 
            +
                        return rewardIncreaseAmount;
         | 
| 1042 | 
            +
                    }
         | 
| 1043 | 
            +
             | 
| 1044 | 
            +
                    // get seconds since last update on stake
         | 
| 1045 | 
            +
                    Seconds duration = SecondsLib.toSeconds(
         | 
| 1046 | 
            +
                        block.timestamp - stakeInfo.lastUpdateAt.toInt());
         | 
| 1047 | 
            +
             | 
| 1048 | 
            +
                    // return if duration is zero
         | 
| 1049 | 
            +
                    if (duration.eqz()) {
         | 
| 1050 | 
            +
                        return AmountLib.zero();
         | 
| 1051 | 
            +
                    }
         | 
| 1052 | 
            +
                    
         | 
| 1053 | 
            +
                    // calculate reward increase since
         | 
| 1054 | 
            +
                    rewardIncreaseAmount = StakingLib.calculateRewardAmount(
         | 
| 1055 | 
            +
                        targetInfo.rewardRate,
         | 
| 1056 | 
            +
                        duration,
         | 
| 1057 | 
            +
                        stakeInfo.stakedAmount);
         | 
| 1058 | 
            +
             | 
| 1059 | 
            +
                    // update target + stake
         | 
| 1060 | 
            +
                    targetInfo.rewardAmount = targetInfo.rewardAmount + rewardIncreaseAmount;
         | 
| 1061 | 
            +
                    stakeInfo.rewardAmount = stakeInfo.rewardAmount + rewardIncreaseAmount;
         | 
| 1062 | 
            +
                    Blocknumber lastUpdateIn = _setLastUpdatesToCurrent(stakeInfo, targetInfo);
         | 
| 1063 | 
            +
             | 
| 1064 | 
            +
                    // logging
         | 
| 1065 | 
            +
                    emit IStaking.LogStakingStakeRewardsUpdated(
         | 
| 1066 | 
            +
                        stakeNftId, 
         | 
| 1067 | 
            +
                        rewardIncreaseAmount, 
         | 
| 1068 | 
            +
                        stakeInfo.stakedAmount, 
         | 
| 1069 | 
            +
                        stakeInfo.rewardAmount, 
         | 
| 1070 | 
            +
                        stakeInfo.lockedUntil,
         | 
| 1071 | 
            +
                        lastUpdateIn);
         | 
| 523 1072 | 
             
                }
         | 
| 524 1073 |  | 
| 525 1074 |  | 
| 526 | 
            -
                function  | 
| 527 | 
            -
                     | 
| 1075 | 
            +
                function _restakeRewards(
         | 
| 1076 | 
            +
                    NftId stakeNftId,
         | 
| 1077 | 
            +
                    IStaking.StakeInfo storage stakeInfo,
         | 
| 1078 | 
            +
                    IStaking.TargetInfo storage targetInfo
         | 
| 1079 | 
            +
                )
         | 
| 1080 | 
            +
                    internal
         | 
| 1081 | 
            +
                    returns (Amount restakeAmount)
         | 
| 528 1082 | 
             
                {
         | 
| 529 | 
            -
                     | 
| 530 | 
            -
             | 
| 1083 | 
            +
                    restakeAmount = stakeInfo.rewardAmount;
         | 
| 1084 | 
            +
             | 
| 1085 | 
            +
                    // return if reward amount is zero
         | 
| 1086 | 
            +
                    if (restakeAmount.eqz()) {
         | 
| 1087 | 
            +
                        return restakeAmount;
         | 
| 531 1088 | 
             
                    }
         | 
| 532 1089 |  | 
| 533 | 
            -
                    //  | 
| 534 | 
            -
                     | 
| 535 | 
            -
             | 
| 1090 | 
            +
                    // check restaking amount does not exceed target max staked amount
         | 
| 1091 | 
            +
                    _checkMaxStakedAmount(stakeInfo.targetNftId, targetInfo, restakeAmount);
         | 
| 1092 | 
            +
             | 
| 1093 | 
            +
                    // use up reserves for newly staked dips
         | 
| 1094 | 
            +
                    _spendRewardReserves(stakeInfo.targetNftId, targetInfo, restakeAmount);
         | 
| 1095 | 
            +
             | 
| 1096 | 
            +
                    // update target + stake
         | 
| 1097 | 
            +
                    targetInfo.stakedAmount = targetInfo.stakedAmount + restakeAmount;
         | 
| 1098 | 
            +
                    targetInfo.rewardAmount = targetInfo.rewardAmount - restakeAmount;
         | 
| 1099 | 
            +
                    stakeInfo.stakedAmount = stakeInfo.stakedAmount + restakeAmount;
         | 
| 1100 | 
            +
                    stakeInfo.rewardAmount = AmountLib.zero();
         | 
| 1101 | 
            +
                    Blocknumber lastUpdateIn = _setLastUpdatesToCurrent(stakeInfo, targetInfo);
         | 
| 1102 | 
            +
             | 
| 1103 | 
            +
                    // logging
         | 
| 1104 | 
            +
                    emit IStaking.LogStakingRewardsRestaked(
         | 
| 1105 | 
            +
                        stakeNftId,
         | 
| 1106 | 
            +
                        restakeAmount, 
         | 
| 1107 | 
            +
                        stakeInfo.stakedAmount, 
         | 
| 1108 | 
            +
                        AmountLib.zero(), 
         | 
| 1109 | 
            +
                        stakeInfo.lockedUntil,
         | 
| 1110 | 
            +
                        lastUpdateIn);
         | 
| 1111 | 
            +
                }
         | 
| 1112 | 
            +
             | 
| 536 1113 |  | 
| 537 | 
            -
             | 
| 538 | 
            -
                     | 
| 539 | 
            -
                     | 
| 1114 | 
            +
                function _stake(
         | 
| 1115 | 
            +
                    NftId stakeNftId,
         | 
| 1116 | 
            +
                    IStaking.StakeInfo storage stakeInfo,
         | 
| 1117 | 
            +
                    IStaking.TargetInfo storage targetInfo,
         | 
| 1118 | 
            +
                    Seconds maxAdditionalLockingPeriod,
         | 
| 1119 | 
            +
                    Amount stakeAmount
         | 
| 1120 | 
            +
                )
         | 
| 1121 | 
            +
                    internal
         | 
| 1122 | 
            +
                {
         | 
| 1123 | 
            +
                    // return if reward amount is zero
         | 
| 1124 | 
            +
                    if (stakeAmount.eqz()) {
         | 
| 1125 | 
            +
                        return;
         | 
| 1126 | 
            +
                    }
         | 
| 1127 | 
            +
             | 
| 1128 | 
            +
                    // check restaking amount does not exceed target max staked amount
         | 
| 1129 | 
            +
                    _checkMaxStakedAmount(stakeInfo.targetNftId, targetInfo, stakeAmount);
         | 
| 1130 | 
            +
             | 
| 1131 | 
            +
                    // update target + stake
         | 
| 1132 | 
            +
                    targetInfo.stakedAmount = targetInfo.stakedAmount + stakeAmount;
         | 
| 1133 | 
            +
                    stakeInfo.stakedAmount = stakeInfo.stakedAmount + stakeAmount;
         | 
| 1134 | 
            +
             | 
| 1135 | 
            +
                    // increase locked until if applicable
         | 
| 1136 | 
            +
                    Seconds additionalLockingPeriod = SecondsLib.min(maxAdditionalLockingPeriod, targetInfo.lockingPeriod);
         | 
| 1137 | 
            +
                    if (stakeAmount.gtz() && additionalLockingPeriod.gtz()) {
         | 
| 1138 | 
            +
                        stakeInfo.lockedUntil = stakeInfo.lockedUntil.addSeconds(additionalLockingPeriod);
         | 
| 1139 | 
            +
                    }
         | 
| 1140 | 
            +
             | 
| 1141 | 
            +
                    Blocknumber lastUpdateIn = _setLastUpdatesToCurrent(stakeInfo, targetInfo);
         | 
| 1142 | 
            +
             | 
| 1143 | 
            +
                    // logging
         | 
| 1144 | 
            +
                    emit IStaking.LogStakingStaked(
         | 
| 1145 | 
            +
                        stakeNftId,
         | 
| 1146 | 
            +
                        stakeAmount, 
         | 
| 1147 | 
            +
                        stakeInfo.stakedAmount, 
         | 
| 1148 | 
            +
                        stakeInfo.rewardAmount, 
         | 
| 1149 | 
            +
                        stakeInfo.lockedUntil,
         | 
| 1150 | 
            +
                        lastUpdateIn);
         | 
| 540 1151 | 
             
                }
         | 
| 541 1152 |  | 
| 542 1153 |  | 
| 543 | 
            -
                function  | 
| 1154 | 
            +
                function _claimRewards(
         | 
| 544 1155 | 
             
                    NftId stakeNftId,
         | 
| 545 | 
            -
                     | 
| 546 | 
            -
                     | 
| 1156 | 
            +
                    IStaking.StakeInfo storage stakeInfo,
         | 
| 1157 | 
            +
                    IStaking.TargetInfo storage targetInfo,
         | 
| 1158 | 
            +
                    Amount maxClaimAmount
         | 
| 547 1159 | 
             
                )
         | 
| 548 | 
            -
                     | 
| 1160 | 
            +
                    internal
         | 
| 1161 | 
            +
                    returns (Amount claimAmount)
         | 
| 1162 | 
            +
                {
         | 
| 1163 | 
            +
                    claimAmount = AmountLib.min(maxClaimAmount, stakeInfo.rewardAmount);
         | 
| 1164 | 
            +
             | 
| 1165 | 
            +
                    // return if no rewards to claim
         | 
| 1166 | 
            +
                    if (claimAmount.eqz()) {
         | 
| 1167 | 
            +
                        return claimAmount;
         | 
| 1168 | 
            +
                    }
         | 
| 1169 | 
            +
             | 
| 1170 | 
            +
                    // effects
         | 
| 1171 | 
            +
                    // use up reserves for claimed rewards
         | 
| 1172 | 
            +
                    _spendRewardReserves(stakeInfo.targetNftId, targetInfo, claimAmount);
         | 
| 1173 | 
            +
             | 
| 1174 | 
            +
                    // update target + stake
         | 
| 1175 | 
            +
                    targetInfo.rewardAmount = targetInfo.rewardAmount - claimAmount;
         | 
| 1176 | 
            +
                    stakeInfo.rewardAmount = stakeInfo.rewardAmount - claimAmount;
         | 
| 1177 | 
            +
                    Blocknumber lastUpdateIn = _setLastUpdatesToCurrent(stakeInfo, targetInfo);
         | 
| 1178 | 
            +
             | 
| 1179 | 
            +
                    // logging
         | 
| 1180 | 
            +
                    emit IStaking.LogStakingRewardsClaimed(
         | 
| 1181 | 
            +
                        stakeNftId,
         | 
| 1182 | 
            +
                        claimAmount, 
         | 
| 1183 | 
            +
                        stakeInfo.stakedAmount, 
         | 
| 1184 | 
            +
                        stakeInfo.rewardAmount, 
         | 
| 1185 | 
            +
                        stakeInfo.lockedUntil,
         | 
| 1186 | 
            +
                        lastUpdateIn);
         | 
| 1187 | 
            +
                }
         | 
| 1188 | 
            +
             | 
| 1189 | 
            +
             | 
| 1190 | 
            +
                function _unstake(
         | 
| 1191 | 
            +
                    NftId stakeNftId,
         | 
| 1192 | 
            +
                    IStaking.StakeInfo storage stakeInfo,
         | 
| 1193 | 
            +
                    IStaking.TargetInfo storage targetInfo,
         | 
| 1194 | 
            +
                    Amount maxUnstakeAmount
         | 
| 1195 | 
            +
                )
         | 
| 1196 | 
            +
                    internal
         | 
| 1197 | 
            +
                    returns (Amount unstakedAmount)
         | 
| 549 1198 | 
             
                {
         | 
| 550 | 
            -
                     | 
| 551 | 
            -
             | 
| 1199 | 
            +
                    unstakedAmount = AmountLib.min(maxUnstakeAmount, stakeInfo.stakedAmount);
         | 
| 1200 | 
            +
             | 
| 1201 | 
            +
                    // return if no stakes to claim
         | 
| 1202 | 
            +
                    if (unstakedAmount.eqz()) {
         | 
| 1203 | 
            +
                        return unstakedAmount;
         | 
| 1204 | 
            +
                    }
         | 
| 552 1205 |  | 
| 553 | 
            -
                     | 
| 554 | 
            -
                     | 
| 1206 | 
            +
                    // check if stake is still locked
         | 
| 1207 | 
            +
                    if (isStakeLocked(stakeNftId)) {
         | 
| 1208 | 
            +
                        revert IStaking.ErrorStakingStakeLocked(stakeNftId, stakeInfo.lockedUntil);
         | 
| 1209 | 
            +
                    }
         | 
| 1210 | 
            +
             | 
| 1211 | 
            +
                    // update target + stake
         | 
| 1212 | 
            +
                    targetInfo.stakedAmount = targetInfo.stakedAmount - unstakedAmount;
         | 
| 1213 | 
            +
                    stakeInfo.stakedAmount = stakeInfo.stakedAmount - unstakedAmount;
         | 
| 1214 | 
            +
                    Blocknumber lastUpdateIn = _setLastUpdatesToCurrent(stakeInfo, targetInfo);
         | 
| 1215 | 
            +
             | 
| 1216 | 
            +
                    // logging
         | 
| 1217 | 
            +
                    emit IStaking.LogStakingUnstaked(
         | 
| 1218 | 
            +
                        stakeNftId,
         | 
| 1219 | 
            +
                        unstakedAmount, 
         | 
| 1220 | 
            +
                        stakeInfo.stakedAmount, 
         | 
| 1221 | 
            +
                        stakeInfo.rewardAmount, 
         | 
| 1222 | 
            +
                        stakeInfo.lockedUntil,
         | 
| 1223 | 
            +
                        lastUpdateIn);
         | 
| 555 1224 | 
             
                }
         | 
| 556 1225 |  | 
| 557 1226 |  | 
| 558 | 
            -
                function  | 
| 559 | 
            -
                     | 
| 560 | 
            -
                     | 
| 561 | 
            -
             | 
| 1227 | 
            +
                function _setLastUpdatesToCurrent(
         | 
| 1228 | 
            +
                    IStaking.StakeInfo storage stakeInfo,
         | 
| 1229 | 
            +
                    IStaking.TargetInfo storage targetInfo
         | 
| 1230 | 
            +
                )
         | 
| 1231 | 
            +
                    internal
         | 
| 1232 | 
            +
                    returns (Blocknumber lastUpdateIn)
         | 
| 1233 | 
            +
                {
         | 
| 1234 | 
            +
                    targetInfo.lastUpdateIn = BlocknumberLib.current();
         | 
| 1235 | 
            +
                    lastUpdateIn = _setStakeLastUpdatesToCurrent(stakeInfo);
         | 
| 1236 | 
            +
                }
         | 
| 1237 | 
            +
             | 
| 1238 | 
            +
             | 
| 1239 | 
            +
                function _setStakeLastUpdatesToCurrent(
         | 
| 1240 | 
            +
                    IStaking.StakeInfo storage stakeInfo
         | 
| 1241 | 
            +
                )
         | 
| 1242 | 
            +
                    internal
         | 
| 1243 | 
            +
                    returns (Blocknumber lastUpdateIn)
         | 
| 1244 | 
            +
                {
         | 
| 1245 | 
            +
                    lastUpdateIn = stakeInfo.lastUpdateIn;
         | 
| 1246 | 
            +
                    stakeInfo.lastUpdateIn = BlocknumberLib.current();
         | 
| 1247 | 
            +
                    stakeInfo.lastUpdateAt = TimestampLib.current();
         | 
| 1248 | 
            +
                }
         | 
| 1249 | 
            +
             | 
| 1250 | 
            +
                //--- private stake and target functions --------------------------------//
         | 
| 1251 | 
            +
             | 
| 1252 | 
            +
             | 
| 1253 | 
            +
                function _getAndVerifyStake(
         | 
| 1254 | 
            +
                    NftId stakeNftId
         | 
| 562 1255 | 
             
                )
         | 
| 563 1256 | 
             
                    private
         | 
| 1257 | 
            +
                    view
         | 
| 1258 | 
            +
                    returns (
         | 
| 1259 | 
            +
                        IStaking.StakeInfo storage stakeInfo
         | 
| 1260 | 
            +
                    )
         | 
| 564 1261 | 
             
                {
         | 
| 565 | 
            -
                     | 
| 566 | 
            -
                     | 
| 1262 | 
            +
                    stakeInfo = _stakeInfo[stakeNftId];
         | 
| 1263 | 
            +
                    if (stakeInfo.lastUpdateIn.eqz()) {
         | 
| 1264 | 
            +
                        revert ErrorStakingStoreStakeNotInitialized(stakeNftId);
         | 
| 1265 | 
            +
                    }
         | 
| 1266 | 
            +
                }
         | 
| 1267 | 
            +
             | 
| 567 1268 |  | 
| 568 | 
            -
             | 
| 569 | 
            -
                     | 
| 1269 | 
            +
                function _checkMaxStakedAmount(
         | 
| 1270 | 
            +
                    NftId targetNftId, 
         | 
| 1271 | 
            +
                    IStaking.TargetInfo storage targetInfo, 
         | 
| 1272 | 
            +
                    Amount additionalstakedAmount
         | 
| 1273 | 
            +
                )
         | 
| 1274 | 
            +
                    private
         | 
| 1275 | 
            +
                {
         | 
| 1276 | 
            +
                    if (targetInfo.stakedAmount + additionalstakedAmount > targetInfo.limitAmount) {
         | 
| 1277 | 
            +
                        revert IStaking.ErrorStakingTargetMaxStakedAmountExceeded(
         | 
| 1278 | 
            +
                            targetNftId,
         | 
| 1279 | 
            +
                            targetInfo.limitAmount,
         | 
| 1280 | 
            +
                            targetInfo.stakedAmount + additionalstakedAmount);
         | 
| 1281 | 
            +
                    }
         | 
| 1282 | 
            +
             | 
| 1283 | 
            +
                    // TODO add check for tvl dependent maximum, see #628
         | 
| 570 1284 | 
             
                }
         | 
| 571 1285 |  | 
| 572 | 
            -
             | 
| 1286 | 
            +
             | 
| 1287 | 
            +
                function _getAndVerifyTarget(
         | 
| 1288 | 
            +
                    NftId targetNftId
         | 
| 1289 | 
            +
                )
         | 
| 573 1290 | 
             
                    private
         | 
| 574 1291 | 
             
                    view
         | 
| 575 | 
            -
                    returns ( | 
| 1292 | 
            +
                    returns (
         | 
| 1293 | 
            +
                        IStaking.TargetInfo storage targetInfo
         | 
| 1294 | 
            +
                    )
         | 
| 576 1295 | 
             
                {
         | 
| 577 | 
            -
                     | 
| 1296 | 
            +
                    targetInfo = _targetInfo[targetNftId];
         | 
| 578 1297 |  | 
| 579 | 
            -
                    if ( | 
| 580 | 
            -
                        revert  | 
| 1298 | 
            +
                    if (targetInfo.lastUpdateIn.eqz()) {
         | 
| 1299 | 
            +
                        revert ErrorStakingStoreTargetNotInitialized(targetNftId);
         | 
| 581 1300 | 
             
                    }
         | 
| 582 1301 | 
             
                }
         | 
| 583 1302 |  | 
| 584 1303 |  | 
| 585 | 
            -
                function  | 
| 586 | 
            -
                    NftId targetNftId | 
| 587 | 
            -
                    address token
         | 
| 1304 | 
            +
                function _getAndVerifyLimit(
         | 
| 1305 | 
            +
                    NftId targetNftId
         | 
| 588 1306 | 
             
                )
         | 
| 589 1307 | 
             
                    private
         | 
| 590 1308 | 
             
                    view
         | 
| 591 1309 | 
             
                    returns (
         | 
| 592 | 
            -
                         | 
| 593 | 
            -
                        Amount oldBalance,
         | 
| 594 | 
            -
                        Amount oldDipBalance
         | 
| 1310 | 
            +
                        IStaking.LimitInfo storage limitInfo
         | 
| 595 1311 | 
             
                    )
         | 
| 596 1312 | 
             
                {
         | 
| 597 | 
            -
                     | 
| 1313 | 
            +
                    limitInfo = _limitInfo[targetNftId];
         | 
| 598 1314 |  | 
| 599 | 
            -
                    if ( | 
| 600 | 
            -
                        revert  | 
| 1315 | 
            +
                    if (limitInfo.lastUpdateIn.eqz()) {
         | 
| 1316 | 
            +
                        revert ErrorStakingStoreLimitNotInitialized(targetNftId);
         | 
| 601 1317 | 
             
                    }
         | 
| 1318 | 
            +
                }
         | 
| 1319 | 
            +
             | 
| 1320 | 
            +
                //--- private tvl functions ------------------------------------------------//
         | 
| 602 1321 |  | 
| 603 | 
            -
             | 
| 604 | 
            -
             | 
| 1322 | 
            +
                /// @dev Initializes token balance handling for the specified target.
         | 
| 1323 | 
            +
                function _createTvlBalance(NftId targetNftId, address token)
         | 
| 1324 | 
            +
                    private
         | 
| 1325 | 
            +
                {
         | 
| 1326 | 
            +
                    IStaking.TvlInfo storage info = _tvlInfo[targetNftId][token];
         | 
| 1327 | 
            +
             | 
| 1328 | 
            +
                    if (info.lastUpdateIn.gtz()) {
         | 
| 1329 | 
            +
                        revert ErrorStakingStoreTvlBalanceAlreadyInitialized(targetNftId, token);
         | 
| 1330 | 
            +
                    }
         | 
| 1331 | 
            +
             | 
| 1332 | 
            +
                    // set tvl balances to 0 and update last updated in
         | 
| 1333 | 
            +
                    info.tvlAmount = AmountLib.zero();
         | 
| 1334 | 
            +
                    info.lastUpdateIn = BlocknumberLib.current();
         | 
| 1335 | 
            +
                }
         | 
| 1336 | 
            +
             | 
| 1337 | 
            +
             | 
| 1338 | 
            +
                function _updateTvlBalance(
         | 
| 1339 | 
            +
                    NftId targetNftId,
         | 
| 1340 | 
            +
                    address token,
         | 
| 1341 | 
            +
                    Amount newTvlAmount
         | 
| 1342 | 
            +
                )
         | 
| 1343 | 
            +
                    private
         | 
| 1344 | 
            +
                    returns (
         | 
| 1345 | 
            +
                        Amount oldTvlAmount,
         | 
| 1346 | 
            +
                        Blocknumber lastUpdatedIn
         | 
| 1347 | 
            +
                    )
         | 
| 1348 | 
            +
                {
         | 
| 1349 | 
            +
                    IStaking.TvlInfo storage tvlInfo = _getAndVerifyTvl(targetNftId, token);
         | 
| 1350 | 
            +
                    oldTvlAmount = tvlInfo.tvlAmount;
         | 
| 1351 | 
            +
                    lastUpdatedIn = tvlInfo.lastUpdateIn;
         | 
| 1352 | 
            +
             | 
| 1353 | 
            +
                    tvlInfo.tvlAmount = newTvlAmount;
         | 
| 1354 | 
            +
                    tvlInfo.lastUpdateIn = BlocknumberLib.current();
         | 
| 1355 | 
            +
                }
         | 
| 1356 | 
            +
             | 
| 1357 | 
            +
             | 
| 1358 | 
            +
                function _getAndVerifyTvl(NftId targetNftId, address token)
         | 
| 1359 | 
            +
                    private
         | 
| 1360 | 
            +
                    view
         | 
| 1361 | 
            +
                    returns (IStaking.TvlInfo storage tvlInfo)
         | 
| 1362 | 
            +
                {
         | 
| 1363 | 
            +
                    tvlInfo = _tvlInfo[targetNftId][token];
         | 
| 1364 | 
            +
                    if (tvlInfo.lastUpdateIn.eqz()) {
         | 
| 1365 | 
            +
                        revert ErrorStakingStoreTvlBalanceNotInitialized(targetNftId, token);
         | 
| 1366 | 
            +
                    }
         | 
| 605 1367 | 
             
                }
         | 
| 606 1368 | 
             
            }
         |