@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
@@ -0,0 +1,290 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {AccessManagedUpgradeable} from "@openzeppelin/contracts-upgradeable/access/manager/AccessManagedUpgradeable.sol";
|
5
|
+
|
6
|
+
import {IComponents} from "./module/IComponents.sol";
|
7
|
+
import {IInstance} from "./IInstance.sol";
|
8
|
+
import {IPolicy} from "./module/IPolicy.sol";
|
9
|
+
import {IRisk} from "./module/IRisk.sol";
|
10
|
+
|
11
|
+
import {BalanceStore} from "./base/BalanceStore.sol";
|
12
|
+
import {BaseStore} from "./BaseStore.sol";
|
13
|
+
import {Blocknumber} from "../type/Blocknumber.sol";
|
14
|
+
import {ClaimId} from "../type/ClaimId.sol";
|
15
|
+
import {Key32} from "../type/Key32.sol";
|
16
|
+
import {NftId} from "../type/NftId.sol";
|
17
|
+
import {ObjectCounter} from "./base/ObjectCounter.sol";
|
18
|
+
import {ObjectLifecycle} from "./base/ObjectLifecycle.sol";
|
19
|
+
import {ObjectType, FEE, POLICY, PREMIUM, PRODUCT} from "../type/ObjectType.sol";
|
20
|
+
import {PayoutId} from "../type/PayoutId.sol";
|
21
|
+
import {RiskId} from "../type/RiskId.sol";
|
22
|
+
import {StateId, KEEP_STATE} from "../type/StateId.sol";
|
23
|
+
|
24
|
+
|
25
|
+
contract ProductStore is
|
26
|
+
AccessManagedUpgradeable,
|
27
|
+
BalanceStore,
|
28
|
+
BaseStore,
|
29
|
+
ObjectCounter,
|
30
|
+
ObjectLifecycle
|
31
|
+
{
|
32
|
+
event LogProductStoreProductInfoCreated(NftId productNftId, StateId state, address createdBy, address txOrigin);
|
33
|
+
event LogProductStoreProductInfoUpdated(NftId productNftId, StateId oldState, StateId newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
|
34
|
+
event LogProductStoreFeeInfoCreated(NftId productNftId, StateId state, address createdBy, address txOrigin);
|
35
|
+
event LogProductStoreFeeInfoUpdated(NftId productNftId, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
|
36
|
+
event LogProductStoreRiskInfoCreated(RiskId riskId, StateId state, address createdBy, address txOrigin);
|
37
|
+
event LogProductStoreRiskInfoUpdated(RiskId riskId, StateId oldState, StateId newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
|
38
|
+
event LogProductStorePolicyInfoCreated(NftId policyNftId, StateId state, address createdBy, address txOrigin);
|
39
|
+
event LogProductStorePolicyInfoUpdated(NftId policyNftId, StateId oldState, StateId newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
|
40
|
+
event LogProductStorePremiumInfoCreated(NftId policyNftId, StateId state, address createdBy, address txOrigin);
|
41
|
+
event LogProductStorePremiumInfoUpdated(NftId policyNftId, StateId oldState, StateId newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
|
42
|
+
event LogProductStoreClaimInfoCreated(NftId policyNftId, ClaimId claimId, StateId state, address createdBy, address txOrigin);
|
43
|
+
event LogProductStoreClaimInfoUpdated(NftId policyNftId, ClaimId claimId, StateId oldState, StateId newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
|
44
|
+
event LogProductStorePayoutInfoCreated(NftId policyNftId, PayoutId payoutId, StateId state, address createdBy, address txOrigin);
|
45
|
+
event LogProductStorePayoutInfoUpdated(NftId policyNftId, PayoutId payoutId, StateId oldState, StateId newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
|
46
|
+
|
47
|
+
mapping(Key32 key32 => IComponents.ProductInfo) private _products;
|
48
|
+
mapping(Key32 key32 => IComponents.FeeInfo) private _fees;
|
49
|
+
mapping(Key32 key32 => IRisk.RiskInfo) private _risks;
|
50
|
+
mapping(Key32 key32 => IPolicy.PolicyInfo) private _policies;
|
51
|
+
mapping(Key32 key32 => IPolicy.PremiumInfo) private _premiums;
|
52
|
+
mapping(Key32 key32 => IPolicy.ClaimInfo) private _claims;
|
53
|
+
mapping(Key32 key32 => IPolicy.PayoutInfo) private _payouts;
|
54
|
+
|
55
|
+
|
56
|
+
/// @dev This initializer needs to be called from the instance itself.
|
57
|
+
function initialize()
|
58
|
+
public
|
59
|
+
initializer()
|
60
|
+
{
|
61
|
+
address instance = msg.sender;
|
62
|
+
address authority = IInstance(instance).authority();
|
63
|
+
|
64
|
+
__AccessManaged_init(authority);
|
65
|
+
// double initialization, safe
|
66
|
+
_initializeLifecycle();
|
67
|
+
}
|
68
|
+
|
69
|
+
|
70
|
+
//--- Product -----------------------------------------------------------//
|
71
|
+
|
72
|
+
function createProduct(NftId productNftId, IComponents.ProductInfo memory info) external restricted() {
|
73
|
+
Key32 key = _toNftKey32(productNftId, PRODUCT());
|
74
|
+
_createMetadata(key);
|
75
|
+
_products[key] = info;
|
76
|
+
// solhint-disable-next-line avoid-tx-origin
|
77
|
+
emit LogProductStoreProductInfoCreated(productNftId, getState(key), msg.sender, tx.origin);
|
78
|
+
}
|
79
|
+
|
80
|
+
function updateProduct(NftId productNftId, IComponents.ProductInfo memory info, StateId newState) external restricted() {
|
81
|
+
Key32 key = _toNftKey32(productNftId, PRODUCT());
|
82
|
+
(Blocknumber lastUpdatedIn, StateId oldState) = _updateState(key, newState);
|
83
|
+
_products[key] = info;
|
84
|
+
// solhint-disable-next-line avoid-tx-origin
|
85
|
+
emit LogProductStoreProductInfoUpdated(productNftId, oldState, newState, msg.sender, tx.origin, lastUpdatedIn);
|
86
|
+
}
|
87
|
+
|
88
|
+
function getProductInfo(NftId productNftId) external view returns (IComponents.ProductInfo memory info) {
|
89
|
+
return _products[_toNftKey32(productNftId, PRODUCT())];
|
90
|
+
}
|
91
|
+
|
92
|
+
//--- Fee -----------------------------------------------------------//
|
93
|
+
|
94
|
+
function createFee(NftId productNftId, IComponents.FeeInfo memory info) external restricted() {
|
95
|
+
Key32 key = _toNftKey32(productNftId, FEE());
|
96
|
+
_createMetadata(key);
|
97
|
+
_fees[key] = info;
|
98
|
+
// solhint-disable-next-line avoid-tx-origin
|
99
|
+
emit LogProductStoreFeeInfoCreated(productNftId, getState(key), msg.sender, tx.origin);
|
100
|
+
}
|
101
|
+
|
102
|
+
// Fee only has one state, so no change change possible
|
103
|
+
function updateFee(NftId productNftId, IComponents.FeeInfo memory info) external restricted() {
|
104
|
+
Key32 key = _toNftKey32(productNftId, FEE());
|
105
|
+
(Blocknumber lastUpdatedIn,) = _updateState(key, KEEP_STATE());
|
106
|
+
_fees[key] = info;
|
107
|
+
// solhint-disable-next-line avoid-tx-origin
|
108
|
+
emit LogProductStoreFeeInfoUpdated(productNftId, msg.sender, tx.origin, lastUpdatedIn);
|
109
|
+
}
|
110
|
+
|
111
|
+
function getFeeInfo(NftId productNftId) external view returns (IComponents.FeeInfo memory info) {
|
112
|
+
return _fees[_toNftKey32(productNftId, FEE())];
|
113
|
+
}
|
114
|
+
|
115
|
+
//--- Risk --------------------------------------------------------------//
|
116
|
+
function createRisk(RiskId riskId, IRisk.RiskInfo memory info) external restricted() {
|
117
|
+
Key32 key = riskId.toKey32();
|
118
|
+
_createMetadata(key);
|
119
|
+
_risks[key] = info;
|
120
|
+
// solhint-disable-next-line avoid-tx-origin
|
121
|
+
emit LogProductStoreRiskInfoCreated(riskId, getState(key), msg.sender, tx.origin);
|
122
|
+
}
|
123
|
+
|
124
|
+
function updateRisk(RiskId riskId, IRisk.RiskInfo memory info, StateId newState) external restricted() {
|
125
|
+
Key32 key = riskId.toKey32();
|
126
|
+
(Blocknumber lastUpdatedIn, StateId oldState) = _updateState(key, newState);
|
127
|
+
_risks[key] = info;
|
128
|
+
// solhint-disable-next-line avoid-tx-origin
|
129
|
+
emit LogProductStoreRiskInfoUpdated(riskId, oldState, newState, msg.sender, tx.origin, lastUpdatedIn);
|
130
|
+
}
|
131
|
+
|
132
|
+
function updateRiskState(RiskId riskId, StateId newState) external restricted() {
|
133
|
+
// _updateState(riskId.toKey32(), newState);
|
134
|
+
Key32 key = riskId.toKey32();
|
135
|
+
(Blocknumber lastUpdatedIn, StateId oldState) = _updateState(key, newState);
|
136
|
+
// solhint-disable-next-line avoid-tx-origin
|
137
|
+
emit LogProductStoreRiskInfoUpdated(riskId, oldState, newState, msg.sender, tx.origin, lastUpdatedIn);
|
138
|
+
}
|
139
|
+
|
140
|
+
function getRiskInfo(RiskId riskId) external view returns (IRisk.RiskInfo memory info) {
|
141
|
+
return _risks[riskId.toKey32()];
|
142
|
+
}
|
143
|
+
|
144
|
+
//--- Application (Policy) ----------------------------------------------//
|
145
|
+
|
146
|
+
function createApplication(NftId applicationNftId, IPolicy.PolicyInfo memory policy) external restricted() {
|
147
|
+
_registerBalanceTarget(applicationNftId);
|
148
|
+
Key32 key = _toNftKey32(applicationNftId, POLICY());
|
149
|
+
_createMetadata(key);
|
150
|
+
_policies[key] = policy;
|
151
|
+
// solhint-disable-next-line avoid-tx-origin
|
152
|
+
emit LogProductStorePolicyInfoCreated(applicationNftId, getState(key), msg.sender, tx.origin);
|
153
|
+
}
|
154
|
+
|
155
|
+
function updateApplication(NftId applicationNftId, IPolicy.PolicyInfo memory policy, StateId newState) external restricted() {
|
156
|
+
Key32 key = _toNftKey32(applicationNftId, POLICY());
|
157
|
+
(Blocknumber lastUpdatedIn, StateId oldState) = _updateState(key, newState);
|
158
|
+
_policies[key] = policy;
|
159
|
+
// solhint-disable-next-line avoid-tx-origin
|
160
|
+
emit LogProductStorePolicyInfoUpdated(applicationNftId, oldState, newState, msg.sender, tx.origin, lastUpdatedIn);
|
161
|
+
}
|
162
|
+
|
163
|
+
function updateApplicationState(NftId applicationNftId, StateId newState) external restricted() {
|
164
|
+
Key32 key = _toNftKey32(applicationNftId, POLICY());
|
165
|
+
(Blocknumber lastUpdatedIn, StateId oldState) = _updateState(key, newState);
|
166
|
+
// solhint-disable-next-line avoid-tx-origin
|
167
|
+
emit LogProductStorePolicyInfoUpdated(applicationNftId, oldState, newState, msg.sender, tx.origin, lastUpdatedIn);
|
168
|
+
}
|
169
|
+
|
170
|
+
//--- Policy ------------------------------------------------------------//
|
171
|
+
|
172
|
+
function updatePolicy(NftId policyNftId, IPolicy.PolicyInfo memory policy, StateId newState) external restricted() {
|
173
|
+
Key32 key = _toNftKey32(policyNftId, POLICY());
|
174
|
+
(Blocknumber lastUpdatedIn, StateId oldState) = _updateState(key, newState);
|
175
|
+
_policies[key] = policy;
|
176
|
+
// solhint-disable-next-line avoid-tx-origin
|
177
|
+
emit LogProductStorePolicyInfoUpdated(policyNftId, oldState, newState, msg.sender, tx.origin, lastUpdatedIn);
|
178
|
+
}
|
179
|
+
|
180
|
+
function updatePolicyClaims(NftId policyNftId, IPolicy.PolicyInfo memory policy, StateId newState) external restricted() {
|
181
|
+
Key32 key = _toNftKey32(policyNftId, POLICY());
|
182
|
+
(Blocknumber lastUpdatedIn, StateId oldState) = _updateState(key, newState);
|
183
|
+
_policies[key] = policy;
|
184
|
+
// solhint-disable-next-line avoid-tx-origin
|
185
|
+
emit LogProductStorePolicyInfoUpdated(policyNftId, oldState, newState, msg.sender, tx.origin, lastUpdatedIn);
|
186
|
+
}
|
187
|
+
|
188
|
+
function updatePolicyState(NftId policyNftId, StateId newState) external restricted() {
|
189
|
+
Key32 key = _toNftKey32(policyNftId, POLICY());
|
190
|
+
(Blocknumber lastUpdatedIn, StateId oldState) = _updateState(key, newState);
|
191
|
+
// solhint-disable-next-line avoid-tx-origin
|
192
|
+
emit LogProductStorePolicyInfoUpdated(policyNftId, oldState, newState, msg.sender, tx.origin, lastUpdatedIn);
|
193
|
+
}
|
194
|
+
|
195
|
+
function getPolicyInfo(NftId policyNftId) external view returns (IPolicy.PolicyInfo memory policy) {
|
196
|
+
return _policies[_toNftKey32(policyNftId, POLICY())];
|
197
|
+
}
|
198
|
+
|
199
|
+
//--- Premium (Policy) ----------------------------------------------//
|
200
|
+
|
201
|
+
function createPremium(NftId policyNftId, IPolicy.PremiumInfo memory premium) external restricted() {
|
202
|
+
Key32 key = _toNftKey32(policyNftId, PREMIUM());
|
203
|
+
_createMetadata(key);
|
204
|
+
_premiums[key] = premium;
|
205
|
+
// solhint-disable-next-line avoid-tx-origin
|
206
|
+
emit LogProductStorePremiumInfoCreated(policyNftId, getState(key), msg.sender, tx.origin);
|
207
|
+
}
|
208
|
+
|
209
|
+
function updatePremiumState(NftId policyNftId, StateId newState) external restricted() {
|
210
|
+
Key32 key = _toNftKey32(policyNftId, PREMIUM());
|
211
|
+
(Blocknumber lastUpdatedIn, StateId oldState) = _updateState(key, newState);
|
212
|
+
// solhint-disable-next-line avoid-tx-origin
|
213
|
+
emit LogProductStorePremiumInfoUpdated(policyNftId, oldState, newState, msg.sender, tx.origin, lastUpdatedIn);
|
214
|
+
}
|
215
|
+
|
216
|
+
function getPremiumInfo(NftId policyNftId) external view returns (IPolicy.PremiumInfo memory premium) {
|
217
|
+
return _premiums[_toNftKey32(policyNftId, PREMIUM())];
|
218
|
+
}
|
219
|
+
|
220
|
+
//--- Claim -------------------------------------------------------------//
|
221
|
+
|
222
|
+
function createClaim(NftId policyNftId, ClaimId claimId, IPolicy.ClaimInfo memory claim) external restricted() {
|
223
|
+
Key32 key = _toClaimKey32(policyNftId, claimId);
|
224
|
+
_createMetadata(key);
|
225
|
+
_claims[key] = claim;
|
226
|
+
// solhint-disable-next-line avoid-tx-origin
|
227
|
+
emit LogProductStoreClaimInfoCreated(policyNftId, claimId, getState(key), msg.sender, tx.origin);
|
228
|
+
}
|
229
|
+
|
230
|
+
function updateClaim(NftId policyNftId, ClaimId claimId, IPolicy.ClaimInfo memory claim, StateId newState) external restricted() {
|
231
|
+
Key32 key = _toClaimKey32(policyNftId, claimId);
|
232
|
+
(Blocknumber lastUpdatedIn, StateId oldState) = _updateState(key, newState);
|
233
|
+
_claims[key] = claim;
|
234
|
+
// solhint-disable-next-line avoid-tx-origin
|
235
|
+
emit LogProductStoreClaimInfoUpdated(policyNftId, claimId, oldState, newState, msg.sender, tx.origin, lastUpdatedIn);
|
236
|
+
}
|
237
|
+
|
238
|
+
function updateClaimState(NftId policyNftId, ClaimId claimId, StateId newState) external restricted() {
|
239
|
+
Key32 key = _toClaimKey32(policyNftId, claimId);
|
240
|
+
(Blocknumber lastUpdatedIn, StateId oldState) = _updateState(key, newState);
|
241
|
+
// solhint-disable-next-line avoid-tx-origin
|
242
|
+
emit LogProductStoreClaimInfoUpdated(policyNftId, claimId, oldState, newState, msg.sender, tx.origin, lastUpdatedIn);
|
243
|
+
}
|
244
|
+
|
245
|
+
function getClaimInfo(NftId policyNftId, ClaimId claimId) external view returns (IPolicy.ClaimInfo memory claim) {
|
246
|
+
return _claims[_toClaimKey32(policyNftId, claimId)];
|
247
|
+
}
|
248
|
+
|
249
|
+
//--- Payout ------------------------------------------------------------//
|
250
|
+
|
251
|
+
function createPayout(NftId policyNftId, PayoutId payoutId, IPolicy.PayoutInfo memory payout) external restricted() {
|
252
|
+
Key32 key = _toPayoutKey32(policyNftId, payoutId);
|
253
|
+
_createMetadata(key);
|
254
|
+
_payouts[key] = payout;
|
255
|
+
// solhint-disable-next-line avoid-tx-origin
|
256
|
+
emit LogProductStorePayoutInfoCreated(policyNftId, payoutId, getState(key), msg.sender, tx.origin);
|
257
|
+
}
|
258
|
+
|
259
|
+
function updatePayout(NftId policyNftId, PayoutId payoutId, IPolicy.PayoutInfo memory payout, StateId newState) external restricted() {
|
260
|
+
Key32 key = _toPayoutKey32(policyNftId, payoutId);
|
261
|
+
(Blocknumber lastUpdatedIn, StateId oldState) = _updateState(key, newState);
|
262
|
+
_payouts[key] = payout;
|
263
|
+
// solhint-disable-next-line avoid-tx-origin
|
264
|
+
emit LogProductStorePayoutInfoUpdated(policyNftId, payoutId, oldState, newState, msg.sender, tx.origin, lastUpdatedIn);
|
265
|
+
}
|
266
|
+
|
267
|
+
function updatePayoutState(NftId policyNftId, PayoutId payoutId, StateId newState) external restricted() {
|
268
|
+
Key32 key = _toPayoutKey32(policyNftId, payoutId);
|
269
|
+
(Blocknumber lastUpdatedIn, StateId oldState) = _updateState(key, newState);
|
270
|
+
// solhint-disable-next-line avoid-tx-origin
|
271
|
+
emit LogProductStorePayoutInfoUpdated(policyNftId, payoutId, oldState, newState, msg.sender, tx.origin, lastUpdatedIn);
|
272
|
+
}
|
273
|
+
|
274
|
+
function getPayoutInfo(NftId policyNftId, PayoutId payoutId) external view returns (IPolicy.PayoutInfo memory payout) {
|
275
|
+
return _payouts[_toPayoutKey32(policyNftId, payoutId)];
|
276
|
+
}
|
277
|
+
|
278
|
+
//--- internal view/pure functions --------------------------------------//
|
279
|
+
function _toNftKey32(NftId nftId, ObjectType objectType) private pure returns (Key32) {
|
280
|
+
return nftId.toKey32(objectType);
|
281
|
+
}
|
282
|
+
|
283
|
+
function _toClaimKey32(NftId policyNftId, ClaimId claimId) private pure returns (Key32) {
|
284
|
+
return claimId.toKey32(policyNftId);
|
285
|
+
}
|
286
|
+
|
287
|
+
function _toPayoutKey32(NftId policyNftId, PayoutId payoutId) private pure returns (Key32) {
|
288
|
+
return payoutId.toKey32(policyNftId);
|
289
|
+
}
|
290
|
+
}
|
@@ -19,7 +19,6 @@ contract RiskSet is
|
|
19
19
|
event LogRiskSetRiskAdded(NftId productNftId, RiskId riskId);
|
20
20
|
event LogRiskSetRiskActive(NftId poolNftId, RiskId riskId);
|
21
21
|
event LogRiskSetRiskPaused(NftId poolNftId, RiskId riskId);
|
22
|
-
event LogRiskSetRiskArchived(NftId poolNftId, RiskId riskId);
|
23
22
|
|
24
23
|
error ErrorRiskSetRiskLocked(RiskId riskId, NftId policyNftId);
|
25
24
|
error ErrorRiskSetRiskUnknown(RiskId riskId);
|
@@ -73,7 +72,7 @@ contract RiskSet is
|
|
73
72
|
}
|
74
73
|
|
75
74
|
/// @dev Applications linked to paused/archived risks may not be underwritten
|
76
|
-
function
|
75
|
+
function deactivate(RiskId riskId) external restricted() {
|
77
76
|
NftId productNftId = ObjectSetHelperLib.getProductNftId(_instanceAddress, riskId);
|
78
77
|
_deactivate(productNftId, riskId.toKey32());
|
79
78
|
emit LogRiskSetRiskPaused(productNftId, riskId);
|
@@ -92,6 +91,15 @@ contract RiskSet is
|
|
92
91
|
}
|
93
92
|
}
|
94
93
|
|
94
|
+
function hasRisk(NftId productNftId, RiskId riskId)
|
95
|
+
public
|
96
|
+
view
|
97
|
+
returns (bool)
|
98
|
+
{
|
99
|
+
Key32 riskKey32 = riskId.toKey32();
|
100
|
+
return _contains(productNftId, riskKey32);
|
101
|
+
}
|
102
|
+
|
95
103
|
function risks(NftId productNftId) external view returns(uint256) {
|
96
104
|
return _objects(productNftId);
|
97
105
|
}
|
@@ -0,0 +1,10 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
string constant INSTANCE_TARGET_NAME = "Instance";
|
5
|
+
string constant INSTANCE_ADMIN_TARGET_NAME = "InstanceAdmin";
|
6
|
+
string constant INSTANCE_STORE_TARGET_NAME = "InstanceStore";
|
7
|
+
string constant PRODUCT_STORE_TARGET_NAME = "ProductStore";
|
8
|
+
string constant BUNDLE_SET_TARGET_NAME = "BundleSet";
|
9
|
+
string constant RISK_SET_TARGET_NAME = "RiskSet";
|
10
|
+
|
@@ -24,13 +24,12 @@ contract BalanceStore {
|
|
24
24
|
mapping(NftId nftId => Amount balance) private _balanceAmount;
|
25
25
|
mapping(NftId nftId => Amount locked) private _lockedAmount;
|
26
26
|
mapping(NftId nftId => Amount fees) private _feeAmount;
|
27
|
-
mapping(NftId nftId => bool isRegistered) private _isRegistered;
|
28
27
|
|
29
|
-
//
|
28
|
+
// used to indicate if the target has been registered as well as when it was last updated (not used externally atm)
|
30
29
|
mapping(NftId nftId => Blocknumber lastUpdatedIn) private _lastUpdatedIn;
|
31
30
|
|
32
31
|
modifier onlyRegisteredTarget(NftId targetNftId) {
|
33
|
-
if (!
|
32
|
+
if (!_lastUpdatedIn[targetNftId].gtz()) {
|
34
33
|
revert ErrorBalanceStoreTargetNotRegistered(targetNftId);
|
35
34
|
}
|
36
35
|
_;
|
@@ -55,11 +54,10 @@ contract BalanceStore {
|
|
55
54
|
}
|
56
55
|
|
57
56
|
function _registerBalanceTarget(NftId targetNftId) internal {
|
58
|
-
if (
|
57
|
+
if (_lastUpdatedIn[targetNftId].gtz()) {
|
59
58
|
revert ErrorBalanceStoreTargetAlreadyRegistered(targetNftId);
|
60
59
|
}
|
61
60
|
|
62
|
-
_isRegistered[targetNftId] = true;
|
63
61
|
_setLastUpdatedIn(targetNftId);
|
64
62
|
|
65
63
|
emit LogBalanceStoreTargetRegistered(targetNftId);
|
@@ -118,6 +116,6 @@ contract BalanceStore {
|
|
118
116
|
|
119
117
|
//--- internal/private functions ----------------------------------------//
|
120
118
|
function _setLastUpdatedIn(NftId targetNftId) internal {
|
121
|
-
_lastUpdatedIn[targetNftId] = BlocknumberLib.
|
119
|
+
_lastUpdatedIn[targetNftId] = BlocknumberLib.current();
|
122
120
|
}
|
123
121
|
}
|
@@ -44,10 +44,7 @@ contract ObjectLifecycle is
|
|
44
44
|
|
45
45
|
function _setupBundleLifecycle() private {
|
46
46
|
setInitialState(BUNDLE(), ACTIVE());
|
47
|
-
setStateTransition(BUNDLE(), ACTIVE(), PAUSED());
|
48
47
|
setStateTransition(BUNDLE(), ACTIVE(), CLOSED());
|
49
|
-
setStateTransition(BUNDLE(), PAUSED(), ACTIVE());
|
50
|
-
setStateTransition(BUNDLE(), PAUSED(), CLOSED());
|
51
48
|
}
|
52
49
|
|
53
50
|
function _setupPolicyLifecycle() private {
|
@@ -69,6 +66,7 @@ contract ObjectLifecycle is
|
|
69
66
|
setStateTransition(CLAIM(), SUBMITTED(), CONFIRMED());
|
70
67
|
setStateTransition(CLAIM(), SUBMITTED(), DECLINED());
|
71
68
|
setStateTransition(CLAIM(), CONFIRMED(), CLOSED());
|
69
|
+
setStateTransition(CLAIM(), CONFIRMED(), CANCELLED());
|
72
70
|
}
|
73
71
|
|
74
72
|
function _setupPayoutLifecycle() private {
|
@@ -79,9 +77,7 @@ contract ObjectLifecycle is
|
|
79
77
|
|
80
78
|
function _setupRiskLifecycle() private {
|
81
79
|
setInitialState(RISK(), ACTIVE());
|
82
|
-
setStateTransition(RISK(), ACTIVE(),
|
83
|
-
setStateTransition(RISK(), PAUSED(), ACTIVE());
|
84
|
-
setStateTransition(RISK(), PAUSED(), ARCHIVED());
|
80
|
+
setStateTransition(RISK(), ACTIVE(), CLOSED());
|
85
81
|
}
|
86
82
|
|
87
83
|
function _setupRequestLifecycle() private {
|
@@ -14,8 +14,6 @@ interface IComponents {
|
|
14
14
|
string name; // component name (needs to be unique per instance)
|
15
15
|
// slot 1
|
16
16
|
TokenHandler tokenHandler;
|
17
|
-
// slot 2
|
18
|
-
bytes data; // will hold component type specific additional info (eg encoded pool info)
|
19
17
|
}
|
20
18
|
|
21
19
|
struct ProductInfo {
|
@@ -14,10 +14,26 @@ contract BasicOracleAuthorization
|
|
14
14
|
is Authorization
|
15
15
|
{
|
16
16
|
|
17
|
-
constructor(
|
18
|
-
|
17
|
+
constructor(
|
18
|
+
string memory componentName,
|
19
|
+
string memory commitHash
|
20
|
+
)
|
21
|
+
Authorization(
|
22
|
+
componentName,
|
23
|
+
ORACLE(),
|
24
|
+
3,
|
25
|
+
commitHash,
|
26
|
+
TargetType.Component,
|
27
|
+
false)
|
19
28
|
{}
|
20
29
|
|
30
|
+
function _setupServiceTargets()
|
31
|
+
internal
|
32
|
+
virtual override
|
33
|
+
{
|
34
|
+
_authorizeServiceDomain(ORACLE(), address(15));
|
35
|
+
}
|
36
|
+
|
21
37
|
function _setupTargetAuthorizations()
|
22
38
|
internal
|
23
39
|
virtual override
|
@@ -75,27 +75,25 @@ abstract contract Oracle is
|
|
75
75
|
}
|
76
76
|
|
77
77
|
|
78
|
-
function
|
78
|
+
function __Oracle_init(
|
79
79
|
address registry,
|
80
80
|
NftId productNftId,
|
81
81
|
IAuthorization authorization,
|
82
82
|
address initialOwner,
|
83
|
-
string memory name
|
84
|
-
bytes memory componentData // component specifidc data
|
83
|
+
string memory name
|
85
84
|
)
|
86
85
|
internal
|
87
86
|
virtual
|
88
87
|
onlyInitializing()
|
89
88
|
{
|
90
|
-
|
89
|
+
__InstanceLinkedComponent_init(
|
91
90
|
registry,
|
92
91
|
productNftId,
|
93
92
|
name,
|
94
93
|
ORACLE(),
|
95
94
|
authorization,
|
96
95
|
true,
|
97
|
-
initialOwner
|
98
|
-
componentData);
|
96
|
+
initialOwner);
|
99
97
|
|
100
98
|
OracleStorage storage $ = _getOracleStorage();
|
101
99
|
$._componentService = IComponentService(_getServiceAddress(COMPONENT()));
|
@@ -48,7 +48,7 @@ contract OracleService is
|
|
48
48
|
)
|
49
49
|
external
|
50
50
|
virtual
|
51
|
-
|
51
|
+
restricted()
|
52
52
|
onlyNftOfType(oracleNftId, ORACLE())
|
53
53
|
returns (RequestId requestId)
|
54
54
|
{
|
@@ -104,7 +104,7 @@ contract OracleService is
|
|
104
104
|
)
|
105
105
|
external
|
106
106
|
virtual
|
107
|
-
|
107
|
+
restricted()
|
108
108
|
returns (bool success)
|
109
109
|
{
|
110
110
|
(
|
@@ -118,7 +118,7 @@ contract OracleService is
|
|
118
118
|
bool callerIsOracle = true;
|
119
119
|
IOracle.RequestInfo memory request = _checkAndGetRequestInfo(instance, requestId, oracleNftId, callerIsOracle);
|
120
120
|
request.responseData = responseData;
|
121
|
-
request.respondedAt = TimestampLib.
|
121
|
+
request.respondedAt = TimestampLib.current();
|
122
122
|
|
123
123
|
instance.getInstanceStore().updateRequest(
|
124
124
|
requestId, request, KEEP_STATE());
|
@@ -153,7 +153,7 @@ contract OracleService is
|
|
153
153
|
function resend(RequestId requestId)
|
154
154
|
external
|
155
155
|
virtual
|
156
|
-
|
156
|
+
restricted()
|
157
157
|
{
|
158
158
|
(
|
159
159
|
IRegistry.ObjectInfo memory info,
|
@@ -192,7 +192,7 @@ contract OracleService is
|
|
192
192
|
function cancel(RequestId requestId)
|
193
193
|
external
|
194
194
|
virtual
|
195
|
-
|
195
|
+
restricted()
|
196
196
|
{
|
197
197
|
(
|
198
198
|
IRegistry.ObjectInfo memory info,
|
@@ -253,8 +253,8 @@ contract OracleService is
|
|
253
253
|
}
|
254
254
|
|
255
255
|
// check expiriyAt >= now
|
256
|
-
if (expiryAt < TimestampLib.
|
257
|
-
revert ErrorOracleServiceExpiryInThePast(TimestampLib.
|
256
|
+
if (expiryAt < TimestampLib.current()) {
|
257
|
+
revert ErrorOracleServiceExpiryInThePast(TimestampLib.current(), expiryAt);
|
258
258
|
}
|
259
259
|
|
260
260
|
// check callbackMethodName.length > 0
|
@@ -298,7 +298,7 @@ contract OracleService is
|
|
298
298
|
}
|
299
299
|
|
300
300
|
// check expiry
|
301
|
-
if (info.expiredAt < TimestampLib.
|
301
|
+
if (info.expiredAt < TimestampLib.current()) {
|
302
302
|
revert ErrorOracleServiceRequestExpired(requestId, info.expiredAt);
|
303
303
|
}
|
304
304
|
}
|
@@ -29,14 +29,13 @@ abstract contract BasicPool is
|
|
29
29
|
virtual
|
30
30
|
onlyInitializing()
|
31
31
|
{
|
32
|
-
|
32
|
+
__Pool_init(
|
33
33
|
registry,
|
34
34
|
productNftId,
|
35
35
|
name,
|
36
36
|
poolInfo,
|
37
37
|
authorization,
|
38
|
-
initialOwner
|
39
|
-
""); // componentData
|
38
|
+
initialOwner);
|
40
39
|
}
|
41
40
|
|
42
41
|
function stake(
|
@@ -82,25 +81,14 @@ abstract contract BasicPool is
|
|
82
81
|
}
|
83
82
|
|
84
83
|
|
85
|
-
function
|
84
|
+
function setBundleLocked(NftId bundleNftId, bool locked)
|
86
85
|
public
|
87
86
|
virtual
|
88
87
|
restricted()
|
89
88
|
onlyBundleOwner(bundleNftId)
|
90
89
|
onlyNftOfType(bundleNftId, BUNDLE())
|
91
90
|
{
|
92
|
-
|
93
|
-
}
|
94
|
-
|
95
|
-
|
96
|
-
function unlockBundle(NftId bundleNftId)
|
97
|
-
public
|
98
|
-
virtual
|
99
|
-
restricted()
|
100
|
-
onlyBundleOwner(bundleNftId)
|
101
|
-
onlyNftOfType(bundleNftId, BUNDLE())
|
102
|
-
{
|
103
|
-
_unlockBundle(bundleNftId);
|
91
|
+
_setBundleLocked(bundleNftId, locked);
|
104
92
|
}
|
105
93
|
|
106
94
|
|
@@ -18,15 +18,21 @@ contract BasicPoolAuthorization
|
|
18
18
|
{
|
19
19
|
|
20
20
|
constructor(string memory poolName)
|
21
|
-
Authorization(
|
21
|
+
Authorization(
|
22
|
+
poolName,
|
23
|
+
POOL(),
|
24
|
+
3,
|
25
|
+
COMMIT_HASH,
|
26
|
+
TargetType.Component,
|
27
|
+
true)
|
22
28
|
{}
|
23
29
|
|
24
30
|
function _setupServiceTargets()
|
25
31
|
internal
|
26
32
|
virtual override
|
27
33
|
{
|
28
|
-
|
29
|
-
|
34
|
+
_authorizeServiceDomain(COMPONENT(), address(11));
|
35
|
+
_authorizeServiceDomain(POOL(), address(12));
|
30
36
|
}
|
31
37
|
|
32
38
|
function _setupTokenHandlerAuthorizations() internal virtual override {
|
@@ -54,8 +60,7 @@ contract BasicPoolAuthorization
|
|
54
60
|
_authorize(functions, BasicPool.stake.selector, "stake");
|
55
61
|
_authorize(functions, BasicPool.unstake.selector, "unstake");
|
56
62
|
_authorize(functions, BasicPool.extend.selector, "extend");
|
57
|
-
_authorize(functions, BasicPool.
|
58
|
-
_authorize(functions, BasicPool.unlockBundle.selector, "unlockBundle");
|
63
|
+
_authorize(functions, BasicPool.setBundleLocked.selector, "setBundleLocked");
|
59
64
|
_authorize(functions, BasicPool.closeBundle.selector, "closeBundle");
|
60
65
|
_authorize(functions, BasicPool.setBundleFee.selector, "setBundleFee");
|
61
66
|
|