@etherisc/gif-next 0.0.2-9306579-093 → 0.0.2-9356555-232
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 +27 -6
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.dbg.json +4 -0
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.json +1007 -0
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.json +744 -0
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.dbg.json +4 -0
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.json +791 -0
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +211 -66
- package/artifacts/contracts/authorization/AccessAdmin.sol/IAccessManagedChecker.dbg.json +4 -0
- package/artifacts/contracts/authorization/AccessAdmin.sol/IAccessManagedChecker.json +24 -0
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.json +233 -5
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +200 -16
- 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 +142 -25
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +107 -15
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.json +19 -0
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +68 -5
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +175 -216
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +206 -27
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +113 -130
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +334 -159
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +115 -65
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +100 -112
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +205 -66
- 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 +158 -195
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +206 -27
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +351 -318
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +203 -28
- 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 +259 -168
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.json +589 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +156 -153
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +282 -193
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.json +589 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +714 -283
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.json +589 -0
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +193 -45
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +158 -57
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +105 -103
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +211 -82
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +434 -128
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +150 -90
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +627 -207
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +129 -157
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +75 -45
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +469 -338
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.dbg.json +4 -0
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.json +853 -0
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +2 -2
- 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 +46 -5
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.json +16 -5
- package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.json +168 -0
- 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 +132 -173
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +180 -29
- 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 +94 -106
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +69 -11
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +108 -125
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +151 -81
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +95 -41
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +107 -152
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +206 -27
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +156 -326
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +79 -101
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +84 -135
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +94 -145
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +192 -229
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +107 -163
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.json +456 -0
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +330 -368
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +119 -69
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +190 -48
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +80 -38
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +228 -186
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +206 -27
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +272 -173
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +100 -78
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +131 -9
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +170 -19
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +139 -54
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +117 -43
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +211 -164
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +1 -1
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.json +86 -6
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +235 -170
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.json +293 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +102 -64
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +200 -106
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +93 -51
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +224 -182
- package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +1 -1
- package/artifacts/contracts/product/RiskService.sol/RiskService.json +167 -67
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +92 -38
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +2 -2
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +98 -17
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +144 -41
- package/artifacts/contracts/registry/IRelease.sol/IRelease.dbg.json +4 -0
- package/artifacts/contracts/registry/IRelease.sol/IRelease.json +24 -0
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +5 -18
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +142 -53
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +331 -261
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +181 -74
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +67 -33
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.json +1849 -0
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +47 -6
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +414 -250
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +66 -8
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +4 -4
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +105 -104
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +483 -485
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +99 -73
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +55 -2
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +1 -1
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +454 -5
- package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.json +24 -0
- package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.json +30 -0
- package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.json +40 -0
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +92 -86
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +446 -276
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +94 -106
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.json +36 -0
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.json +36 -0
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +16 -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 +148 -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 +55 -2
- 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 +107 -124
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +42 -1
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +42 -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 +18 -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 +152 -38
- 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 +55 -2
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +327 -73
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.dbg.json +4 -0
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.json +484 -0
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +88 -24
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +110 -122
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +77 -16
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +33 -33
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +192 -192
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.json +46 -5
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +89 -51
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +4 -4
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +120 -55
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +73 -39
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +171 -130
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +23 -23
- 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 +3 -3
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- 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 +3 -3
- 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 +4 -0
- package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.json +33 -0
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +23 -4
- 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 +2 -2
- 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 +69 -7
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +79 -15
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorLib.json +21 -2
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +2 -2
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/StateId.sol/StateIdLib.json +15 -2
- package/artifacts/contracts/type/String.sol/StrLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +2 -2
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +3 -3
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionLib.json +2 -21
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionPartLib.json +47 -2
- package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +44 -12
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +1 -1
- package/contracts/accounting/AccountingService.sol +262 -0
- package/contracts/accounting/AccountingServiceManager.sol +38 -0
- package/contracts/accounting/IAccountingService.sol +45 -0
- package/contracts/authorization/AccessAdmin.sol +237 -140
- package/contracts/authorization/AccessManagerCloneable.sol +136 -3
- package/contracts/authorization/Authorization.sol +321 -205
- package/contracts/authorization/IAccess.sol +1 -0
- package/contracts/authorization/IAccessAdmin.sol +17 -9
- package/contracts/authorization/IAuthorization.sol +27 -7
- package/contracts/authorization/IServiceAuthorization.sol +3 -1
- package/contracts/authorization/ServiceAuthorization.sol +26 -10
- package/contracts/distribution/BasicDistribution.sol +15 -12
- package/contracts/distribution/BasicDistributionAuthorization.sol +22 -9
- package/contracts/distribution/Distribution.sol +41 -47
- package/contracts/distribution/DistributionService.sol +127 -78
- package/contracts/distribution/DistributionServiceManager.sol +1 -1
- package/contracts/distribution/IDistributionComponent.sol +1 -1
- package/contracts/distribution/IDistributionService.sol +22 -20
- package/contracts/examples/fire/FirePool.sol +25 -10
- package/contracts/examples/fire/FirePoolAuthorization.sol +2 -1
- package/contracts/examples/fire/FireProduct.sol +66 -41
- package/contracts/examples/fire/FireProductAuthorization.sol +3 -3
- package/contracts/examples/unpermissioned/SimpleDistribution.sol +39 -4
- package/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol +28 -0
- package/contracts/examples/unpermissioned/SimpleOracle.sol +4 -4
- package/contracts/examples/unpermissioned/SimplePool.sol +37 -7
- package/contracts/examples/unpermissioned/SimplePoolAuthorization.sol +28 -0
- package/contracts/examples/unpermissioned/SimpleProduct.sol +53 -27
- package/contracts/examples/unpermissioned/SimpleProductAuthorization.sol +28 -0
- package/contracts/instance/BundleSet.sol +42 -38
- package/contracts/instance/IInstance.sol +17 -10
- package/contracts/instance/IInstanceService.sol +9 -29
- package/contracts/instance/Instance.sol +52 -34
- package/contracts/instance/InstanceAdmin.sol +249 -100
- package/contracts/instance/InstanceAuthorizationV3.sol +54 -45
- package/contracts/instance/InstanceReader.sol +187 -32
- package/contracts/instance/InstanceService.sol +85 -146
- package/contracts/instance/InstanceServiceManager.sol +1 -1
- package/contracts/instance/InstanceStore.sol +13 -2
- package/contracts/instance/RiskSet.sol +118 -0
- package/contracts/instance/base/ObjectCounter.sol +1 -2
- package/contracts/instance/base/ObjectLifecycle.sol +4 -2
- package/contracts/instance/base/ObjectSet.sol +31 -33
- package/contracts/instance/base/ObjectSetHelperLib.sol +30 -0
- package/contracts/instance/module/IComponents.sol +10 -7
- package/contracts/instance/module/IDistribution.sol +5 -2
- package/contracts/instance/module/IPolicy.sol +2 -1
- package/contracts/instance/module/IRisk.sol +3 -0
- package/contracts/oracle/BasicOracle.sol +0 -1
- package/contracts/oracle/BasicOracleAuthorization.sol +3 -12
- package/contracts/oracle/IOracleService.sol +2 -1
- package/contracts/oracle/Oracle.sol +5 -16
- package/contracts/oracle/OracleService.sol +107 -78
- package/contracts/oracle/OracleServiceManager.sol +1 -1
- package/contracts/pool/BasicPool.sol +33 -24
- package/contracts/pool/BasicPoolAuthorization.sol +27 -9
- package/contracts/pool/BundleService.sol +88 -154
- package/contracts/pool/BundleServiceManager.sol +1 -1
- package/contracts/pool/IBundleService.sol +15 -43
- package/contracts/pool/IPoolComponent.sol +1 -7
- package/contracts/pool/IPoolService.sol +58 -64
- package/contracts/pool/Pool.sol +112 -120
- package/contracts/pool/PoolLib.sol +216 -0
- package/contracts/pool/PoolService.sol +436 -242
- package/contracts/pool/PoolServiceManager.sol +1 -1
- package/contracts/product/ApplicationService.sol +39 -16
- package/contracts/product/ApplicationServiceManager.sol +1 -1
- package/contracts/product/BasicProduct.sol +10 -12
- package/contracts/product/BasicProductAuthorization.sol +24 -11
- package/contracts/product/ClaimService.sol +202 -151
- package/contracts/product/ClaimServiceManager.sol +1 -1
- package/contracts/product/IApplicationService.sol +8 -2
- package/contracts/product/IClaimService.sol +14 -2
- package/contracts/product/IPolicyService.sol +26 -11
- package/contracts/product/IPricingService.sol +10 -9
- package/contracts/product/IProductComponent.sol +10 -1
- package/contracts/product/IRiskService.sol +7 -7
- package/contracts/product/PolicyService.sol +248 -252
- package/contracts/product/PolicyServiceLib.sol +65 -0
- package/contracts/product/PolicyServiceManager.sol +1 -1
- package/contracts/product/PricingService.sol +35 -26
- package/contracts/product/PricingServiceManager.sol +3 -3
- package/contracts/product/Product.sol +100 -63
- package/contracts/product/RiskService.sol +89 -31
- package/contracts/product/RiskServiceManager.sol +1 -1
- package/contracts/registry/ChainNft.sol +10 -11
- package/contracts/registry/IRegistry.sol +14 -18
- package/contracts/registry/IRegistryService.sol +6 -4
- package/contracts/registry/IRelease.sol +26 -0
- package/contracts/registry/ITransferInterceptor.sol +1 -2
- package/contracts/registry/Registry.sol +29 -6
- package/contracts/registry/RegistryAdmin.sol +132 -242
- package/contracts/registry/RegistryService.sol +40 -58
- package/contracts/registry/RegistryServiceManager.sol +1 -1
- package/contracts/registry/ReleaseAdmin.sol +245 -0
- package/contracts/registry/ReleaseLifecycle.sol +8 -3
- package/contracts/registry/ReleaseRegistry.sol +257 -237
- package/contracts/registry/ServiceAuthorizationV3.sol +97 -48
- package/contracts/registry/TokenRegistry.sol +6 -8
- package/contracts/shared/Component.sol +69 -118
- package/contracts/shared/ComponentService.sol +422 -371
- package/contracts/shared/ComponentServiceManager.sol +1 -1
- package/contracts/shared/ComponentVerifyingService.sol +27 -15
- package/contracts/shared/ContractLib.sol +224 -9
- package/contracts/shared/IComponent.sol +8 -20
- package/contracts/shared/IComponentService.sol +41 -37
- package/contracts/shared/IInstanceLinkedComponent.sol +3 -22
- package/contracts/shared/ILifecycle.sol +3 -1
- package/contracts/shared/INftOwnable.sol +2 -0
- package/contracts/shared/IRegisterable.sol +23 -1
- package/contracts/shared/IService.sol +3 -5
- package/contracts/shared/InstanceLinkedComponent.sol +68 -42
- package/contracts/shared/KeyValueStore.sol +1 -1
- package/contracts/shared/Lifecycle.sol +15 -4
- package/contracts/shared/NftOwnable.sol +26 -6
- package/contracts/shared/PolicyHolder.sol +1 -1
- package/contracts/shared/Registerable.sol +53 -19
- package/contracts/shared/RegistryLinked.sol +7 -13
- package/contracts/shared/Service.sol +9 -31
- package/contracts/shared/TokenHandler.sol +274 -72
- package/contracts/shared/TokenHandlerDeployerLib.sol +10 -2
- package/contracts/staking/IStaking.sol +5 -8
- package/contracts/staking/IStakingService.sol +8 -3
- package/contracts/staking/StakeManagerLib.sol +1 -1
- package/contracts/staking/Staking.sol +63 -35
- package/contracts/staking/StakingReader.sol +1 -1
- package/contracts/staking/StakingService.sol +45 -22
- package/contracts/staking/StakingServiceManager.sol +5 -4
- package/contracts/type/Key32.sol +2 -2
- package/contracts/type/Key32Set.sol +62 -0
- package/contracts/type/NftId.sol +6 -0
- package/contracts/type/ObjectType.sol +48 -21
- package/contracts/type/RiskId.sol +26 -8
- package/contracts/type/RoleId.sol +23 -15
- package/contracts/type/Selector.sol +5 -0
- package/contracts/type/StateId.sol +14 -1
- package/contracts/type/Timestamp.sol +0 -5
- package/contracts/type/UFixed.sol +9 -119
- package/contracts/type/Version.sol +15 -5
- package/contracts/upgradeability/ProxyManager.sol +2 -1
- package/package.json +5 -4
- package/artifacts/contracts/authorization/IModuleAuthorization.sol/IModuleAuthorization.dbg.json +0 -4
- package/artifacts/contracts/authorization/IModuleAuthorization.sol/IModuleAuthorization.json +0 -290
- package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.dbg.json +0 -4
- package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.json +0 -390
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +0 -4
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +0 -129
- package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +0 -4
- package/artifacts/contracts/type/UFixed.sol/MathLib.json +0 -16
- package/contracts/authorization/IModuleAuthorization.sol +0 -21
- package/contracts/authorization/ModuleAuthorization.sol +0 -78
- package/contracts/instance/module/IAccess.sol +0 -46
@@ -0,0 +1,65 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {InstanceReader} from "../instance/InstanceReader.sol";
|
5
|
+
import {IPolicy} from "../instance/module/IPolicy.sol";
|
6
|
+
import {IPolicyService} from "../product/IPolicyService.sol";
|
7
|
+
import {NftId} from "../type/NftId.sol";
|
8
|
+
import {StateId, CLOSED, COLLATERALIZED} from "../type/StateId.sol";
|
9
|
+
import {Timestamp, TimestampLib} from "../type/Timestamp.sol";
|
10
|
+
|
11
|
+
library PolicyServiceLib {
|
12
|
+
|
13
|
+
function checkExpiration(
|
14
|
+
Timestamp newExpiredAt,
|
15
|
+
NftId policyNftId,
|
16
|
+
StateId policyState,
|
17
|
+
IPolicy.PolicyInfo memory policyInfo
|
18
|
+
)
|
19
|
+
external
|
20
|
+
view
|
21
|
+
{
|
22
|
+
if (policyState != COLLATERALIZED()) {
|
23
|
+
revert IPolicyService.ErrorPolicyServicePolicyNotActive(policyNftId, policyState);
|
24
|
+
}
|
25
|
+
if (TimestampLib.blockTimestamp() < policyInfo.activatedAt) {
|
26
|
+
revert IPolicyService.ErrorPolicyServicePolicyNotActive(policyNftId, policyState);
|
27
|
+
}
|
28
|
+
|
29
|
+
// check expiredAt represents a valid expiry time
|
30
|
+
if (newExpiredAt >= policyInfo.expiredAt) {
|
31
|
+
revert IPolicyService.ErrorPolicyServicePolicyExpirationTooLate(policyNftId, policyInfo.expiredAt, newExpiredAt);
|
32
|
+
}
|
33
|
+
|
34
|
+
if (newExpiredAt.gtz() && newExpiredAt < TimestampLib.blockTimestamp()) {
|
35
|
+
revert IPolicyService.ErrorPolicyServicePolicyExpirationTooEarly(policyNftId, TimestampLib.blockTimestamp(), newExpiredAt);
|
36
|
+
}
|
37
|
+
}
|
38
|
+
|
39
|
+
function policyIsCloseable(InstanceReader instanceReader, NftId policyNftId)
|
40
|
+
external
|
41
|
+
view
|
42
|
+
returns (bool isCloseable)
|
43
|
+
{
|
44
|
+
// policy already closed
|
45
|
+
if (instanceReader.getPolicyState(policyNftId) == CLOSED()) {
|
46
|
+
return false;
|
47
|
+
}
|
48
|
+
|
49
|
+
IPolicy.PolicyInfo memory info = instanceReader.getPolicyInfo(policyNftId);
|
50
|
+
|
51
|
+
if (info.productNftId.eqz()) { return false; } // not closeable: policy does not exist (or does not belong to this instance)
|
52
|
+
if (info.activatedAt.eqz()) { return false; } // not closeable: not yet activated
|
53
|
+
if (info.openClaimsCount > 0) { return false; } // not closeable: has open claims
|
54
|
+
|
55
|
+
// closeable: if sum of claims matches sum insured a policy may be closed prior to the expiry date
|
56
|
+
if (info.claimAmount == info.sumInsuredAmount) { return true; }
|
57
|
+
|
58
|
+
// not closeable: not yet expired
|
59
|
+
if (TimestampLib.blockTimestamp() < info.expiredAt) { return false; }
|
60
|
+
|
61
|
+
// all conditions to close the policy are met
|
62
|
+
return true;
|
63
|
+
}
|
64
|
+
|
65
|
+
}
|
@@ -17,7 +17,7 @@ contract PolicyServiceManager is ProxyManager {
|
|
17
17
|
)
|
18
18
|
{
|
19
19
|
PolicyService svc = new PolicyService{salt: salt}();
|
20
|
-
bytes memory data = abi.encode(
|
20
|
+
bytes memory data = abi.encode(authority, registry);
|
21
21
|
IVersionable versionable = initialize(
|
22
22
|
registry,
|
23
23
|
address(svc),
|
@@ -9,7 +9,7 @@ import {NftId} from "../type/NftId.sol";
|
|
9
9
|
import {Fee} from "../type/Fee.sol";
|
10
10
|
import {ReferralId} from "../type/Referral.sol";
|
11
11
|
import {RiskId} from "../type/RiskId.sol";
|
12
|
-
import {PRODUCT, DISTRIBUTION, PRICE} from "../type/ObjectType.sol";
|
12
|
+
import {PRODUCT, BUNDLE, DISTRIBUTION, PRICE} from "../type/ObjectType.sol";
|
13
13
|
import {IRegistry} from "../registry/IRegistry.sol";
|
14
14
|
|
15
15
|
import {IProductComponent} from "./IProductComponent.sol";
|
@@ -31,11 +31,8 @@ contract PricingService is
|
|
31
31
|
ComponentVerifyingService,
|
32
32
|
IPricingService
|
33
33
|
{
|
34
|
-
using UFixedLib for UFixed;
|
35
|
-
|
36
34
|
IDistributionService internal _distributionService;
|
37
35
|
|
38
|
-
|
39
36
|
function _initialize(
|
40
37
|
address owner,
|
41
38
|
bytes memory data
|
@@ -45,14 +42,15 @@ contract PricingService is
|
|
45
42
|
initializer()
|
46
43
|
{
|
47
44
|
(
|
48
|
-
address
|
49
|
-
address
|
45
|
+
address authority,
|
46
|
+
address registry
|
50
47
|
) = abi.decode(data, (address, address));
|
51
48
|
|
52
|
-
|
53
|
-
_registerInterface(type(IPricingService).interfaceId);
|
49
|
+
__Service_init(authority, registry, owner);
|
54
50
|
|
55
51
|
_distributionService = IDistributionService(_getServiceAddress(DISTRIBUTION()));
|
52
|
+
|
53
|
+
_registerInterface(type(IPricingService).interfaceId);
|
56
54
|
}
|
57
55
|
|
58
56
|
/// @dev calculates the premium amount for the specified attributes
|
@@ -73,6 +71,9 @@ contract PricingService is
|
|
73
71
|
IPolicy.PremiumInfo memory premium
|
74
72
|
)
|
75
73
|
{
|
74
|
+
_checkNftType(productNftId, PRODUCT());
|
75
|
+
_checkNftType(bundleNftId, BUNDLE());
|
76
|
+
|
76
77
|
InstanceReader reader;
|
77
78
|
Amount netPremiumAmount;
|
78
79
|
|
@@ -86,6 +87,11 @@ contract PricingService is
|
|
86
87
|
// get instance reader from local instance variable
|
87
88
|
reader = instance.getInstanceReader();
|
88
89
|
|
90
|
+
NftId riskProductNftId = reader.getRiskInfo(riskId).productNftId;
|
91
|
+
if (!productNftId.eq(riskProductNftId)) {
|
92
|
+
revert ErrorPricingServiceRiskProductMismatch(riskId, riskProductNftId, productNftId);
|
93
|
+
}
|
94
|
+
|
89
95
|
// calculate net premium
|
90
96
|
netPremiumAmount = IProductComponent(registryInfo.objectAddress).calculateNetPremium(
|
91
97
|
sumInsuredAmount,
|
@@ -98,30 +104,32 @@ contract PricingService is
|
|
98
104
|
{
|
99
105
|
// get configurations for all involed objects
|
100
106
|
IComponents.ProductInfo memory productInfo = reader.getProductInfo(productNftId);
|
107
|
+
IComponents.FeeInfo memory feeInfo = reader.getFeeInfo(productNftId);
|
101
108
|
|
102
109
|
IBundle.BundleInfo memory bundleInfo = reader.getBundleInfo(bundleNftId);
|
103
110
|
if(bundleInfo.poolNftId != productInfo.poolNftId) {
|
104
|
-
revert
|
111
|
+
revert ErrorPricingServiceBundlePoolMismatch(bundleNftId, bundleInfo.poolNftId, productInfo.poolNftId);
|
105
112
|
}
|
106
113
|
|
107
114
|
// calculate fixed fees for product, pool, bundle
|
108
115
|
premium = _getFixedFeeAmounts(
|
109
116
|
netPremiumAmount,
|
110
|
-
|
117
|
+
feeInfo,
|
111
118
|
bundleInfo
|
112
119
|
);
|
113
120
|
|
114
121
|
// calculate variable fees for product, pool, bundle
|
115
122
|
premium = _calculateVariableFeeAmounts(
|
116
123
|
premium,
|
117
|
-
|
124
|
+
feeInfo,
|
118
125
|
bundleInfo
|
119
126
|
);
|
120
127
|
|
121
128
|
// calculate distribution fee and (if applicable) commission
|
122
129
|
premium = _calculateDistributionOwnerFeeAmount(
|
123
130
|
premium,
|
124
|
-
|
131
|
+
feeInfo,
|
132
|
+
productInfo.distributionNftId,
|
125
133
|
referralId,
|
126
134
|
reader
|
127
135
|
);
|
@@ -137,8 +145,8 @@ contract PricingService is
|
|
137
145
|
revert ErrorPricingServiceTargetWalletAmountsMismatch();
|
138
146
|
}
|
139
147
|
|
140
|
-
if (premium.distributionOwnerFeeFixAmount.toInt() <
|
141
|
-
revert
|
148
|
+
if (premium.distributionOwnerFeeFixAmount.toInt() < feeInfo.minDistributionOwnerFee.fixedFee) {
|
149
|
+
revert ErrorPricingServiceFeeCalculationMismatch(
|
142
150
|
premium.distributionFeeFixAmount,
|
143
151
|
premium.distributionFeeVarAmount,
|
144
152
|
premium.distributionOwnerFeeFixAmount,
|
@@ -149,7 +157,7 @@ contract PricingService is
|
|
149
157
|
}
|
150
158
|
|
151
159
|
if ((premium.distributionFeeVarAmount) != (premium.discountAmount + premium.distributionOwnerFeeVarAmount + premium.commissionAmount)) {
|
152
|
-
revert
|
160
|
+
revert ErrorPricingServiceFeeCalculationMismatch(
|
153
161
|
premium.distributionFeeFixAmount,
|
154
162
|
premium.distributionFeeVarAmount,
|
155
163
|
premium.distributionOwnerFeeFixAmount,
|
@@ -164,7 +172,7 @@ contract PricingService is
|
|
164
172
|
// internal functions
|
165
173
|
function _getFixedFeeAmounts(
|
166
174
|
Amount netPremiumAmount,
|
167
|
-
IComponents.
|
175
|
+
IComponents.FeeInfo memory feeInfo,
|
168
176
|
IBundle.BundleInfo memory bundleInfo
|
169
177
|
)
|
170
178
|
internal
|
@@ -177,11 +185,11 @@ contract PricingService is
|
|
177
185
|
premium.netPremiumAmount = netPremiumAmount;
|
178
186
|
premium.fullPremiumAmount = netPremiumAmount;
|
179
187
|
|
180
|
-
Amount t = AmountLib.toAmount(
|
188
|
+
Amount t = AmountLib.toAmount(feeInfo.productFee.fixedFee);
|
181
189
|
premium.productFeeFixAmount = t;
|
182
190
|
premium.fullPremiumAmount = premium.fullPremiumAmount + t;
|
183
191
|
|
184
|
-
t = AmountLib.toAmount(
|
192
|
+
t = AmountLib.toAmount(feeInfo.poolFee.fixedFee);
|
185
193
|
premium.poolFeeFixAmount = t;
|
186
194
|
premium.fullPremiumAmount = premium.fullPremiumAmount + t;
|
187
195
|
|
@@ -189,14 +197,14 @@ contract PricingService is
|
|
189
197
|
premium.bundleFeeFixAmount = t;
|
190
198
|
premium.fullPremiumAmount = premium.fullPremiumAmount + t;
|
191
199
|
|
192
|
-
t = AmountLib.toAmount(
|
200
|
+
t = AmountLib.toAmount(feeInfo.distributionFee.fixedFee);
|
193
201
|
premium.distributionFeeFixAmount = t;
|
194
202
|
premium.fullPremiumAmount = premium.fullPremiumAmount + t;
|
195
203
|
}
|
196
204
|
|
197
205
|
function _calculateVariableFeeAmounts(
|
198
206
|
IPolicy.PremiumInfo memory premium,
|
199
|
-
IComponents.
|
207
|
+
IComponents.FeeInfo memory feeInfo,
|
200
208
|
IBundle.BundleInfo memory bundleInfo
|
201
209
|
)
|
202
210
|
internal
|
@@ -207,11 +215,11 @@ contract PricingService is
|
|
207
215
|
{
|
208
216
|
Amount netPremiumAmount = premium.netPremiumAmount;
|
209
217
|
|
210
|
-
Amount t = netPremiumAmount.multiplyWith(
|
218
|
+
Amount t = netPremiumAmount.multiplyWith(feeInfo.productFee.fractionalFee);
|
211
219
|
premium.productFeeVarAmount = t;
|
212
220
|
premium.fullPremiumAmount = premium.fullPremiumAmount + t;
|
213
221
|
|
214
|
-
t = netPremiumAmount.multiplyWith(
|
222
|
+
t = netPremiumAmount.multiplyWith(feeInfo.poolFee.fractionalFee);
|
215
223
|
premium.poolFeeVarAmount = t;
|
216
224
|
premium.fullPremiumAmount = premium.fullPremiumAmount + t;
|
217
225
|
|
@@ -219,7 +227,7 @@ contract PricingService is
|
|
219
227
|
premium.bundleFeeVarAmount = t;
|
220
228
|
premium.fullPremiumAmount = premium.fullPremiumAmount + t;
|
221
229
|
|
222
|
-
t = netPremiumAmount.multiplyWith(
|
230
|
+
t = netPremiumAmount.multiplyWith(feeInfo.distributionFee.fractionalFee);
|
223
231
|
premium.distributionFeeVarAmount = t;
|
224
232
|
premium.fullPremiumAmount = premium.fullPremiumAmount + t;
|
225
233
|
|
@@ -228,7 +236,8 @@ contract PricingService is
|
|
228
236
|
|
229
237
|
function _calculateDistributionOwnerFeeAmount(
|
230
238
|
IPolicy.PremiumInfo memory premium,
|
231
|
-
IComponents.
|
239
|
+
IComponents.FeeInfo memory feeInfo,
|
240
|
+
NftId distributionNftId,
|
232
241
|
// ISetup.DistributionSetupInfo memory distInfo,
|
233
242
|
ReferralId referralId,
|
234
243
|
InstanceReader reader
|
@@ -239,14 +248,14 @@ contract PricingService is
|
|
239
248
|
{
|
240
249
|
|
241
250
|
// if the referral is not valid, then the distribution owner gets everything
|
242
|
-
if (! _distributionService.referralIsValid(
|
251
|
+
if (distributionNftId.eqz() || ! _distributionService.referralIsValid(distributionNftId, referralId)) {
|
243
252
|
premium.distributionOwnerFeeFixAmount = premium.distributionFeeFixAmount;
|
244
253
|
premium.distributionOwnerFeeVarAmount = premium.distributionFeeVarAmount;
|
245
254
|
premium.premiumAmount = premium.fullPremiumAmount;
|
246
255
|
return premium;
|
247
256
|
}
|
248
257
|
|
249
|
-
Fee memory minDistributionOwnerFee =
|
258
|
+
Fee memory minDistributionOwnerFee = feeInfo.minDistributionOwnerFee;
|
250
259
|
|
251
260
|
// if the referral is valid, the the commission and discount are calculated based in the full premium
|
252
261
|
// the remaing amount goes to the distribution owner
|
@@ -12,14 +12,14 @@ contract PricingServiceManager is ProxyManager {
|
|
12
12
|
/// @dev initializes proxy manager with pricing service implementation and deploys instance
|
13
13
|
constructor(
|
14
14
|
address authority,
|
15
|
-
address
|
15
|
+
address registry,
|
16
16
|
bytes32 salt
|
17
17
|
)
|
18
18
|
{
|
19
19
|
PricingService pricingSrv = new PricingService{salt: salt}();
|
20
|
-
bytes memory data = abi.encode(
|
20
|
+
bytes memory data = abi.encode(authority, registry);
|
21
21
|
IVersionable versionable = initialize(
|
22
|
-
|
22
|
+
registry,
|
23
23
|
address(pricingSrv),
|
24
24
|
data,
|
25
25
|
salt);
|
@@ -3,20 +3,20 @@ pragma solidity ^0.8.20;
|
|
3
3
|
|
4
4
|
import {Amount, AmountLib} from "../type/Amount.sol";
|
5
5
|
import {ClaimId} from "../type/ClaimId.sol";
|
6
|
-
import {
|
7
|
-
import {Fee, FeeLib} from "../type/Fee.sol";
|
8
|
-
import {IRisk} from "../instance/module/IRisk.sol";
|
6
|
+
import {Fee} from "../type/Fee.sol";
|
9
7
|
import {IApplicationService} from "./IApplicationService.sol";
|
10
8
|
import {IAuthorization} from "../authorization/IAuthorization.sol";
|
11
9
|
import {IComponentService} from "../shared/IComponentService.sol";
|
10
|
+
import {InstanceLinkedComponent} from "../shared/InstanceLinkedComponent.sol";
|
12
11
|
import {IPolicyService} from "./IPolicyService.sol";
|
13
12
|
import {IRiskService} from "./IRiskService.sol";
|
14
13
|
import {IClaimService} from "./IClaimService.sol";
|
15
14
|
import {IPricingService} from "./IPricingService.sol";
|
16
15
|
import {IProductComponent} from "./IProductComponent.sol";
|
17
16
|
import {NftId} from "../type/NftId.sol";
|
17
|
+
import {COMPONENT, PRODUCT, BUNDLE, APPLICATION, POLICY, CLAIM, PRICE } from "../type/ObjectType.sol";
|
18
18
|
import {PayoutId} from "../type/PayoutId.sol";
|
19
|
-
import {COMPONENT, PRODUCT, APPLICATION, POLICY, CLAIM, PRICE } from "../type/ObjectType.sol";
|
19
|
+
import {COMPONENT, PRODUCT, APPLICATION, POLICY, CLAIM, PRICE, BUNDLE, RISK } from "../type/ObjectType.sol";
|
20
20
|
import {ReferralId} from "../type/Referral.sol";
|
21
21
|
import {RiskId, RiskIdLib} from "../type/RiskId.sol";
|
22
22
|
import {Seconds} from "../type/Seconds.sol";
|
@@ -25,8 +25,6 @@ import {Timestamp} from "../type/Timestamp.sol";
|
|
25
25
|
|
26
26
|
import {IPolicy} from "../instance/module/IPolicy.sol";
|
27
27
|
import {IComponents} from "../instance/module/IComponents.sol";
|
28
|
-
import {Pool} from "../pool/Pool.sol";
|
29
|
-
import {Distribution} from "../distribution/Distribution.sol";
|
30
28
|
|
31
29
|
abstract contract Product is
|
32
30
|
InstanceLinkedComponent,
|
@@ -36,26 +34,24 @@ abstract contract Product is
|
|
36
34
|
bytes32 public constant PRODUCT_STORAGE_LOCATION_V1 = 0x0bb7aafdb8e380f81267337bc5b5dfdf76e6d3a380ecadb51ec665246d9d6800;
|
37
35
|
|
38
36
|
struct ProductStorage {
|
37
|
+
IComponents.ProductInfo _productInfo;
|
38
|
+
IComponents.FeeInfo _feeInfo;
|
39
|
+
IComponentService _componentService;
|
39
40
|
IRiskService _riskService;
|
40
41
|
IApplicationService _applicationService;
|
41
42
|
IPolicyService _policyService;
|
42
43
|
IClaimService _claimService;
|
43
44
|
IPricingService _pricingService;
|
44
|
-
IComponentService _componentService;
|
45
|
-
NftId _poolNftId;
|
46
|
-
NftId _distributionNftId;
|
47
|
-
Pool _pool;
|
48
|
-
Distribution _distribution;
|
49
45
|
}
|
50
46
|
|
51
47
|
|
52
|
-
function
|
48
|
+
function registerComponent(address component)
|
53
49
|
external
|
54
50
|
virtual
|
55
51
|
onlyOwner()
|
52
|
+
returns (NftId componentNftId)
|
56
53
|
{
|
57
|
-
_getProductStorage()._componentService.
|
58
|
-
_approveTokenHandler(type(uint256).max);
|
54
|
+
return _getProductStorage()._componentService.registerComponent(component);
|
59
55
|
}
|
60
56
|
|
61
57
|
|
@@ -67,6 +63,7 @@ abstract contract Product is
|
|
67
63
|
external
|
68
64
|
virtual
|
69
65
|
restricted() // pool service role
|
66
|
+
onlyNftOfType(policyNftId, POLICY())
|
70
67
|
{
|
71
68
|
// default implementation does nothing
|
72
69
|
}
|
@@ -83,6 +80,7 @@ abstract contract Product is
|
|
83
80
|
public
|
84
81
|
view
|
85
82
|
override
|
83
|
+
onlyNftOfType(bundleNftId, BUNDLE())
|
86
84
|
returns (Amount premiumAmount)
|
87
85
|
{
|
88
86
|
IPolicy.PremiumInfo memory premium = _getProductStorage()._pricingService.calculatePremium(
|
@@ -120,35 +118,28 @@ abstract contract Product is
|
|
120
118
|
view
|
121
119
|
returns (IComponents.ProductInfo memory poolInfo)
|
122
120
|
{
|
123
|
-
|
121
|
+
return _getProductStorage()._productInfo;
|
122
|
+
}
|
124
123
|
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
minDistributionOwnerFee: FeeLib.zero(),
|
133
|
-
poolFee: FeeLib.zero(),
|
134
|
-
stakingFee: FeeLib.zero(),
|
135
|
-
performanceFee: FeeLib.zero()
|
136
|
-
});
|
124
|
+
function getInitialFeeInfo()
|
125
|
+
public
|
126
|
+
virtual
|
127
|
+
view
|
128
|
+
returns (IComponents.FeeInfo memory feeInfo)
|
129
|
+
{
|
130
|
+
return _getProductStorage()._feeInfo;
|
137
131
|
}
|
138
132
|
|
139
133
|
|
140
134
|
function _initializeProduct(
|
141
135
|
address registry,
|
142
136
|
NftId instanceNftId,
|
143
|
-
IAuthorization authorization,
|
144
|
-
address initialOwner,
|
145
137
|
string memory name,
|
146
138
|
address token,
|
147
|
-
|
148
|
-
|
149
|
-
|
150
|
-
|
151
|
-
bytes memory registryData, // writeonly data that will saved in the object info record of the registry
|
139
|
+
IComponents.ProductInfo memory productInfo,
|
140
|
+
IComponents.FeeInfo memory feeInfo,
|
141
|
+
IAuthorization authorization,
|
142
|
+
address initialOwner,
|
152
143
|
bytes memory componentData // writeonly data that will saved in the object info record of the registry
|
153
144
|
)
|
154
145
|
internal
|
@@ -162,24 +153,19 @@ abstract contract Product is
|
|
162
153
|
token,
|
163
154
|
PRODUCT(),
|
164
155
|
authorization,
|
165
|
-
|
156
|
+
productInfo.isInterceptingPolicyTransfers,
|
166
157
|
initialOwner,
|
167
|
-
registryData,
|
168
158
|
componentData);
|
169
159
|
|
170
160
|
ProductStorage storage $ = _getProductStorage();
|
171
|
-
|
172
|
-
|
173
|
-
$._riskService = IRiskService(_getServiceAddress(
|
161
|
+
$._productInfo = productInfo;
|
162
|
+
$._feeInfo = feeInfo;
|
163
|
+
$._riskService = IRiskService(_getServiceAddress(RISK()));
|
174
164
|
$._applicationService = IApplicationService(_getServiceAddress(APPLICATION()));
|
175
165
|
$._policyService = IPolicyService(_getServiceAddress(POLICY()));
|
176
166
|
$._claimService = IClaimService(_getServiceAddress(CLAIM()));
|
177
167
|
$._pricingService = IPricingService(_getServiceAddress(PRICE()));
|
178
168
|
$._componentService = IComponentService(_getServiceAddress(COMPONENT()));
|
179
|
-
$._pool = Pool(pool);
|
180
|
-
$._distribution = Distribution(distribution);
|
181
|
-
$._poolNftId = getRegistry().getNftIdForAddress(pool);
|
182
|
-
$._distributionNftId = getRegistry().getNftIdForAddress(distribution);
|
183
169
|
|
184
170
|
_registerInterface(type(IProductComponent).interfaceId);
|
185
171
|
}
|
@@ -197,10 +183,14 @@ abstract contract Product is
|
|
197
183
|
|
198
184
|
|
199
185
|
function _createRisk(
|
200
|
-
|
186
|
+
bytes32 id,
|
201
187
|
bytes memory data
|
202
|
-
)
|
203
|
-
|
188
|
+
)
|
189
|
+
internal
|
190
|
+
virtual
|
191
|
+
returns (RiskId riskId)
|
192
|
+
{
|
193
|
+
return _getProductStorage()._riskService.createRisk(
|
204
194
|
id,
|
205
195
|
data
|
206
196
|
);
|
@@ -209,8 +199,11 @@ abstract contract Product is
|
|
209
199
|
function _updateRisk(
|
210
200
|
RiskId id,
|
211
201
|
bytes memory data
|
212
|
-
)
|
213
|
-
|
202
|
+
)
|
203
|
+
internal
|
204
|
+
virtual
|
205
|
+
{
|
206
|
+
_getProductStorage()._riskService.updateRisk(
|
214
207
|
id,
|
215
208
|
data
|
216
209
|
);
|
@@ -219,19 +212,17 @@ abstract contract Product is
|
|
219
212
|
function _updateRiskState(
|
220
213
|
RiskId id,
|
221
214
|
StateId state
|
222
|
-
)
|
223
|
-
|
215
|
+
)
|
216
|
+
internal
|
217
|
+
virtual
|
218
|
+
{
|
219
|
+
_getProductStorage()._riskService.updateRiskState(
|
224
220
|
id,
|
225
221
|
state
|
226
222
|
);
|
227
223
|
}
|
228
224
|
|
229
225
|
|
230
|
-
function _getRiskInfo(RiskId id) internal view returns (IRisk.RiskInfo memory info) {
|
231
|
-
return getInstance().getInstanceReader().getRiskInfo(id);
|
232
|
-
}
|
233
|
-
|
234
|
-
|
235
226
|
function _createApplication(
|
236
227
|
address applicationOwner,
|
237
228
|
RiskId riskId,
|
@@ -243,6 +234,7 @@ abstract contract Product is
|
|
243
234
|
bytes memory applicationData
|
244
235
|
)
|
245
236
|
internal
|
237
|
+
virtual
|
246
238
|
returns (NftId applicationNftId)
|
247
239
|
{
|
248
240
|
return _getProductStorage()._applicationService.create(
|
@@ -262,8 +254,10 @@ abstract contract Product is
|
|
262
254
|
Timestamp activateAt
|
263
255
|
)
|
264
256
|
internal
|
257
|
+
virtual
|
258
|
+
returns (Amount premiumAmount)
|
265
259
|
{
|
266
|
-
_getProductStorage()._policyService.createPolicy(
|
260
|
+
premiumAmount = _getProductStorage()._policyService.createPolicy(
|
267
261
|
applicationNftId,
|
268
262
|
activateAt);
|
269
263
|
}
|
@@ -272,6 +266,7 @@ abstract contract Product is
|
|
272
266
|
NftId policyNftId
|
273
267
|
)
|
274
268
|
internal
|
269
|
+
virtual
|
275
270
|
{
|
276
271
|
_getProductStorage()._policyService.decline(
|
277
272
|
policyNftId);
|
@@ -282,16 +277,33 @@ abstract contract Product is
|
|
282
277
|
Timestamp expireAt
|
283
278
|
)
|
284
279
|
internal
|
280
|
+
virtual
|
285
281
|
returns (Timestamp expiredAt)
|
286
282
|
{
|
287
283
|
expiredAt = _getProductStorage()._policyService.expire(policyNftId, expireAt);
|
288
284
|
}
|
289
285
|
|
286
|
+
/// @dev adjust the activation date of the policy.
|
287
|
+
/// The policy must already have an activation date set.
|
288
|
+
/// Allowed values are from the current blocktime to the expiration date of the policy.
|
289
|
+
function _adjustActivation(
|
290
|
+
NftId policyNftId,
|
291
|
+
Timestamp activateAt
|
292
|
+
)
|
293
|
+
internal
|
294
|
+
virtual
|
295
|
+
{
|
296
|
+
_getProductStorage()._policyService.adjustActivation(
|
297
|
+
policyNftId,
|
298
|
+
activateAt);
|
299
|
+
}
|
300
|
+
|
290
301
|
function _collectPremium(
|
291
302
|
NftId policyNftId,
|
292
303
|
Timestamp activateAt
|
293
304
|
)
|
294
305
|
internal
|
306
|
+
virtual
|
295
307
|
{
|
296
308
|
_getProductStorage()._policyService.collectPremium(
|
297
309
|
policyNftId,
|
@@ -303,6 +315,7 @@ abstract contract Product is
|
|
303
315
|
Timestamp activateAt
|
304
316
|
)
|
305
317
|
internal
|
318
|
+
virtual
|
306
319
|
{
|
307
320
|
_getProductStorage()._policyService.activate(
|
308
321
|
policyNftId,
|
@@ -313,6 +326,7 @@ abstract contract Product is
|
|
313
326
|
NftId policyNftId
|
314
327
|
)
|
315
328
|
internal
|
329
|
+
virtual
|
316
330
|
{
|
317
331
|
_getProductStorage()._policyService.close(
|
318
332
|
policyNftId);
|
@@ -324,6 +338,7 @@ abstract contract Product is
|
|
324
338
|
bytes memory claimData
|
325
339
|
)
|
326
340
|
internal
|
341
|
+
virtual
|
327
342
|
returns(ClaimId)
|
328
343
|
{
|
329
344
|
return _getProductStorage()._claimService.submit(
|
@@ -332,6 +347,18 @@ abstract contract Product is
|
|
332
347
|
claimData);
|
333
348
|
}
|
334
349
|
|
350
|
+
function _revokeClaim(
|
351
|
+
NftId policyNftId,
|
352
|
+
ClaimId claimId
|
353
|
+
)
|
354
|
+
internal
|
355
|
+
virtual
|
356
|
+
{
|
357
|
+
_getProductStorage()._claimService.revoke(
|
358
|
+
policyNftId,
|
359
|
+
claimId);
|
360
|
+
}
|
361
|
+
|
335
362
|
function _confirmClaim(
|
336
363
|
NftId policyNftId,
|
337
364
|
ClaimId claimId,
|
@@ -339,6 +366,7 @@ abstract contract Product is
|
|
339
366
|
bytes memory data
|
340
367
|
)
|
341
368
|
internal
|
369
|
+
virtual
|
342
370
|
{
|
343
371
|
_getProductStorage()._claimService.confirm(
|
344
372
|
policyNftId,
|
@@ -353,6 +381,7 @@ abstract contract Product is
|
|
353
381
|
bytes memory data
|
354
382
|
)
|
355
383
|
internal
|
384
|
+
virtual
|
356
385
|
{
|
357
386
|
_getProductStorage()._claimService.decline(
|
358
387
|
policyNftId,
|
@@ -365,6 +394,7 @@ abstract contract Product is
|
|
365
394
|
ClaimId claimId
|
366
395
|
)
|
367
396
|
internal
|
397
|
+
virtual
|
368
398
|
{
|
369
399
|
_getProductStorage()._claimService.close(
|
370
400
|
policyNftId,
|
@@ -378,6 +408,7 @@ abstract contract Product is
|
|
378
408
|
bytes memory data
|
379
409
|
)
|
380
410
|
internal
|
411
|
+
virtual
|
381
412
|
returns (PayoutId)
|
382
413
|
{
|
383
414
|
return _getProductStorage()._claimService.createPayout(
|
@@ -395,6 +426,7 @@ abstract contract Product is
|
|
395
426
|
bytes memory data
|
396
427
|
)
|
397
428
|
internal
|
429
|
+
virtual
|
398
430
|
returns (PayoutId)
|
399
431
|
{
|
400
432
|
return _getProductStorage()._claimService.createPayoutForBeneficiary(
|
@@ -410,23 +442,28 @@ abstract contract Product is
|
|
410
442
|
PayoutId payoutId
|
411
443
|
)
|
412
444
|
internal
|
445
|
+
virtual
|
413
446
|
{
|
414
447
|
_getProductStorage()._claimService.processPayout(
|
415
448
|
policyNftId,
|
416
449
|
payoutId);
|
417
450
|
}
|
418
451
|
|
419
|
-
function
|
420
|
-
|
452
|
+
function _cancelPayout(
|
453
|
+
NftId policyNftId,
|
454
|
+
PayoutId payoutId
|
455
|
+
)
|
456
|
+
internal
|
457
|
+
virtual
|
458
|
+
{
|
459
|
+
_getProductStorage()._claimService.cancelPayout(
|
460
|
+
policyNftId,
|
461
|
+
payoutId);
|
421
462
|
}
|
422
463
|
|
423
|
-
function _getProductStorage() internal pure returns (ProductStorage storage $) {
|
464
|
+
function _getProductStorage() internal virtual pure returns (ProductStorage storage $) {
|
424
465
|
assembly {
|
425
466
|
$.slot := PRODUCT_STORAGE_LOCATION_V1
|
426
467
|
}
|
427
468
|
}
|
428
|
-
|
429
|
-
function _getRiskService() internal view returns (IRiskService) {
|
430
|
-
return _getProductStorage()._riskService;
|
431
|
-
}
|
432
469
|
}
|