@etherisc/gif-next 0.0.2-de7c770-422 → 0.0.2-de9ede4-391
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 +28 -7
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.dbg.json +4 -0
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.json +1000 -0
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.json +746 -0
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.dbg.json +4 -0
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.json +767 -0
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +103 -63
- 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/Authorization.sol/Authorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +67 -11
- 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 +60 -32
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +40 -3
- 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/ReleaseAccessManager.sol/ReleaseAccessManager.dbg.json +4 -0
- package/artifacts/contracts/authorization/ReleaseAccessManager.sol/ReleaseAccessManager.json +1196 -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 +159 -209
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +82 -22
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +99 -125
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +180 -86
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +139 -64
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +87 -108
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +52 -0
- package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.json +22 -0
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.json +1441 -0
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +502 -0
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +1991 -0
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +470 -0
- package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.json +376 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.json +187 -169
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.json +470 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +131 -157
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +282 -194
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.json +502 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +564 -249
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.json +470 -0
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +147 -42
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +116 -48
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +53 -101
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +149 -60
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +196 -138
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +58 -85
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +687 -84
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +118 -148
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +107 -44
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +475 -116
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.dbg.json +4 -0
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.json +810 -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 +2 -2
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
- 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 +119 -169
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +84 -24
- 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 +82 -103
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +43 -9
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +95 -121
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +147 -79
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +127 -40
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +115 -141
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +114 -22
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +148 -150
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +121 -70
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +48 -33
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +102 -134
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +272 -185
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +115 -152
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +413 -263
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +144 -45
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +119 -45
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +103 -40
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +158 -138
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +82 -22
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +200 -86
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +144 -61
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +63 -7
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +64 -8
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +178 -19
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +80 -51
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +141 -116
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +1 -1
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.json +29 -0
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +328 -119
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +150 -55
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +170 -107
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +119 -48
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +154 -134
- package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +1 -1
- package/artifacts/contracts/product/RiskService.sol/RiskService.json +81 -26
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +101 -34
- 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 +91 -15
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +114 -35
- 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 +135 -51
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +220 -182
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +94 -172
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +99 -32
- 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 +123 -225
- 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 +2 -2
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +72 -80
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +483 -477
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +141 -76
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +47 -0
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +488 -0
- 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/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +61 -64
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +425 -261
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +82 -103
- 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/IPolicyHolder.sol/IPolicyHolder.json +16 -6
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +29 -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 +94 -120
- 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 +18 -8
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +66 -8
- 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 +47 -0
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +388 -35
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.dbg.json +4 -0
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.json +395 -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 +79 -100
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +29 -21
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +3 -3
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +158 -170
- 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 +120 -54
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +7 -12
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +87 -53
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +103 -36
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +145 -104
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +3 -3
- 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 +33 -9
- 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 +28 -4
- 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 +19 -19
- 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 +99 -5
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +2 -2
- 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/SelectorSetLib.dbg.json +1 -1
- 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/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +16 -3
- 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/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +79 -27
- 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 +263 -0
- package/contracts/accounting/AccountingServiceManager.sol +38 -0
- package/contracts/accounting/IAccountingService.sol +45 -0
- package/contracts/authorization/AccessAdmin.sol +82 -56
- package/contracts/authorization/Authorization.sol +111 -39
- package/contracts/authorization/IAccess.sol +1 -0
- package/contracts/authorization/IAccessAdmin.sol +4 -3
- package/contracts/authorization/IAuthorization.sol +13 -7
- package/contracts/authorization/IServiceAuthorization.sol +3 -1
- package/contracts/authorization/ReleaseAccessManager.sol +38 -0
- package/contracts/authorization/ServiceAuthorization.sol +26 -10
- package/contracts/distribution/BasicDistribution.sol +8 -7
- package/contracts/distribution/BasicDistributionAuthorization.sol +1 -1
- package/contracts/distribution/Distribution.sol +32 -40
- package/contracts/distribution/DistributionService.sol +86 -65
- package/contracts/distribution/DistributionServiceManager.sol +6 -6
- package/contracts/distribution/IDistributionComponent.sol +1 -1
- package/contracts/distribution/IDistributionService.sol +5 -6
- package/contracts/examples/fire/DamageLevel.sol +59 -0
- package/contracts/examples/fire/FirePool.sol +90 -0
- package/contracts/examples/fire/FirePoolAuthorization.sol +35 -0
- package/contracts/examples/fire/FireProduct.sol +436 -0
- package/contracts/examples/fire/FireProductAuthorization.sol +45 -0
- package/contracts/examples/fire/FireUSD.sol +26 -0
- package/contracts/examples/unpermissioned/SimpleDistribution.sol +11 -4
- package/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol +28 -0
- package/contracts/examples/unpermissioned/SimpleOracle.sol +4 -4
- package/contracts/examples/unpermissioned/SimplePool.sol +37 -6
- package/contracts/examples/unpermissioned/SimplePoolAuthorization.sol +28 -0
- package/contracts/examples/unpermissioned/SimpleProduct.sol +24 -23
- package/contracts/examples/unpermissioned/SimpleProductAuthorization.sol +28 -0
- package/contracts/instance/BundleSet.sol +38 -34
- package/contracts/instance/IInstance.sol +11 -3
- package/contracts/instance/IInstanceService.sol +7 -29
- package/contracts/instance/Instance.sol +36 -26
- package/contracts/instance/InstanceAdmin.sol +57 -54
- package/contracts/instance/InstanceAuthorizationV3.sol +50 -32
- package/contracts/instance/InstanceReader.sol +187 -21
- package/contracts/instance/InstanceService.sol +54 -129
- package/contracts/instance/InstanceServiceManager.sol +6 -7
- package/contracts/instance/InstanceStore.sol +12 -2
- package/contracts/instance/RiskSet.sol +119 -0
- package/contracts/instance/base/ObjectCounter.sol +1 -2
- package/contracts/instance/base/ObjectLifecycle.sol +2 -1
- package/contracts/instance/base/ObjectSet.sol +24 -25
- package/contracts/instance/module/IComponents.sol +20 -7
- package/contracts/instance/module/IPolicy.sol +4 -3
- package/contracts/instance/module/IRisk.sol +1 -0
- package/contracts/oracle/BasicOracle.sol +0 -1
- package/contracts/oracle/IOracleService.sol +2 -1
- package/contracts/oracle/Oracle.sol +4 -15
- package/contracts/oracle/OracleService.sol +110 -80
- package/contracts/oracle/OracleServiceManager.sol +6 -6
- package/contracts/pool/BasicPool.sol +33 -24
- package/contracts/pool/BasicPoolAuthorization.sol +12 -2
- package/contracts/pool/BundleService.sol +74 -87
- package/contracts/pool/BundleServiceManager.sol +6 -6
- package/contracts/pool/IBundleService.sol +2 -15
- package/contracts/pool/IPoolComponent.sol +19 -15
- package/contracts/pool/IPoolService.sol +30 -37
- package/contracts/pool/Pool.sol +141 -122
- package/contracts/pool/PoolService.sol +263 -157
- package/contracts/pool/PoolServiceManager.sol +4 -4
- package/contracts/product/ApplicationService.sol +31 -20
- package/contracts/product/ApplicationServiceManager.sol +4 -4
- package/contracts/product/BasicProduct.sol +8 -12
- package/contracts/product/BasicProductAuthorization.sol +1 -3
- package/contracts/product/ClaimService.sol +233 -106
- package/contracts/product/ClaimServiceManager.sol +4 -4
- package/contracts/product/IApplicationService.sol +5 -2
- package/contracts/product/IClaimService.sol +3 -2
- package/contracts/product/IPolicyService.sol +25 -8
- package/contracts/product/IPricingService.sol +9 -9
- package/contracts/product/IProductComponent.sol +23 -3
- package/contracts/product/PolicyService.sol +361 -198
- package/contracts/product/PolicyServiceManager.sol +4 -4
- package/contracts/product/PricingService.sol +10 -11
- package/contracts/product/PricingServiceManager.sol +3 -3
- package/contracts/product/Product.sol +76 -74
- package/contracts/product/RiskService.sol +16 -6
- package/contracts/product/RiskServiceManager.sol +4 -4
- package/contracts/registry/ChainNft.sol +10 -11
- package/contracts/registry/IRegistry.sol +8 -3
- package/contracts/registry/IRegistryService.sol +5 -12
- package/contracts/registry/ITransferInterceptor.sol +1 -2
- package/contracts/registry/Registry.sol +29 -6
- package/contracts/registry/RegistryAdmin.sol +29 -36
- package/contracts/registry/RegistryService.sol +33 -44
- package/contracts/registry/RegistryServiceManager.sol +2 -2
- package/contracts/registry/ReleaseLifecycle.sol +6 -3
- package/contracts/registry/ReleaseRegistry.sol +205 -210
- package/contracts/registry/ServiceAuthorizationV3.sol +58 -50
- package/contracts/shared/Component.sol +56 -105
- package/contracts/shared/ComponentService.sol +384 -329
- package/contracts/shared/ComponentServiceManager.sol +8 -5
- package/contracts/shared/ComponentVerifyingService.sol +27 -16
- package/contracts/shared/ContractLib.sol +224 -0
- package/contracts/shared/IComponent.sol +6 -14
- package/contracts/shared/IComponentService.sol +45 -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/IPolicyHolder.sol +12 -13
- package/contracts/shared/IRegisterable.sol +11 -0
- package/contracts/shared/InstanceLinkedComponent.sol +68 -43
- package/contracts/shared/KeyValueStore.sol +1 -1
- package/contracts/shared/Lifecycle.sol +15 -4
- package/contracts/shared/NftOwnable.sol +23 -3
- package/contracts/shared/PolicyHolder.sol +11 -5
- package/contracts/shared/Registerable.sol +15 -7
- package/contracts/shared/RegistryLinked.sol +6 -12
- package/contracts/shared/Service.sol +16 -14
- package/contracts/shared/TokenHandler.sol +316 -66
- package/contracts/shared/TokenHandlerDeployerLib.sol +10 -2
- package/contracts/staking/IStaking.sol +9 -4
- package/contracts/staking/IStakingService.sol +0 -3
- package/contracts/staking/Staking.sol +42 -25
- package/contracts/staking/StakingManager.sol +8 -6
- package/contracts/staking/StakingReader.sol +12 -5
- package/contracts/staking/StakingService.sol +56 -23
- package/contracts/staking/StakingServiceManager.sol +2 -2
- package/contracts/type/Amount.sol +15 -0
- package/contracts/type/ClaimId.sol +6 -1
- package/contracts/type/Key32.sol +2 -2
- package/contracts/type/Key32Set.sol +62 -0
- package/contracts/type/NftId.sol +7 -0
- package/contracts/type/ObjectType.sol +14 -0
- package/contracts/type/PayoutId.sol +10 -10
- package/contracts/type/RiskId.sol +30 -4
- package/contracts/type/RoleId.sol +0 -12
- package/contracts/type/StateId.sol +14 -1
- package/contracts/type/UFixed.sol +13 -119
- package/contracts/upgradeability/ProxyManager.sol +68 -34
- package/contracts/upgradeability/Versionable.sol +2 -2
- package/package.json +4 -3
- 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/shared/InitializableCustom.sol/InitializableCustom.dbg.json +0 -4
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.json +0 -39
- 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/shared/InitializableCustom.sol +0 -177
@@ -3,46 +3,40 @@ pragma solidity ^0.8.20;
|
|
3
3
|
|
4
4
|
import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
|
5
5
|
|
6
|
-
import {
|
7
|
-
import {
|
6
|
+
import {IAccountingService} from "../accounting/IAccountingService.sol";
|
7
|
+
import {IComponentService} from "../shared/IComponentService.sol";
|
8
8
|
import {IComponents} from "../instance/module/IComponents.sol";
|
9
|
+
import {IDistributionService} from "../distribution/IDistributionService.sol";
|
10
|
+
import {InstanceReader} from "../instance/InstanceReader.sol";
|
11
|
+
import {InstanceStore} from "../instance/InstanceStore.sol";
|
9
12
|
import {IInstance} from "../instance/IInstance.sol";
|
10
13
|
import {IPolicy} from "../instance/module/IPolicy.sol";
|
14
|
+
import {IPolicyHolder} from "../shared/IPolicyHolder.sol";
|
15
|
+
import {IPolicyService} from "./IPolicyService.sol";
|
16
|
+
import {IPoolService} from "../pool/IPoolService.sol";
|
17
|
+
import {IPricingService} from "./IPricingService.sol";
|
18
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
11
19
|
|
12
|
-
import {
|
13
|
-
|
14
|
-
import {Amount, AmountLib} from "../type/Amount.sol";
|
15
|
-
import {Timestamp, TimestampLib, zeroTimestamp} from "../type/Timestamp.sol";
|
16
|
-
import {ObjectType, APPLICATION, COMPONENT, DISTRIBUTION, PRODUCT, POOL, POLICY, BUNDLE, CLAIM, PRICE} from "../type/ObjectType.sol";
|
20
|
+
import {Amount} from "../type/Amount.sol";
|
17
21
|
import {APPLIED, COLLATERALIZED, KEEP_STATE, CLOSED, DECLINED, PAID} from "../type/StateId.sol";
|
18
|
-
import {
|
22
|
+
import {ContractLib} from "../shared/ContractLib.sol";
|
23
|
+
import {NftId} from "../type/NftId.sol";
|
24
|
+
import {ObjectType, ACCOUNTING, COMPONENT, DISTRIBUTION, PRODUCT, POOL, POLICY, PRICE} from "../type/ObjectType.sol";
|
19
25
|
import {ReferralId} from "../type/Referral.sol";
|
26
|
+
import {RiskId} from "../type/RiskId.sol";
|
27
|
+
import {Service} from "../shared/Service.sol";
|
20
28
|
import {StateId} from "../type/StateId.sol";
|
29
|
+
import {Timestamp, TimestampLib} from "../type/Timestamp.sol";
|
30
|
+
import {TokenHandler} from "../shared/TokenHandler.sol";
|
21
31
|
import {VersionPart} from "../type/Version.sol";
|
22
32
|
|
23
|
-
import {ComponentVerifyingService} from "../shared/ComponentVerifyingService.sol";
|
24
|
-
import {IApplicationService} from "./IApplicationService.sol";
|
25
|
-
import {IBundleService} from "../pool/IBundleService.sol";
|
26
|
-
import {IClaimService} from "./IClaimService.sol";
|
27
|
-
import {IComponentService} from "../shared/IComponentService.sol";
|
28
|
-
import {IDistributionService} from "../distribution/IDistributionService.sol";
|
29
|
-
import {InstanceReader} from "../instance/InstanceReader.sol";
|
30
|
-
import {InstanceStore} from "../instance/InstanceStore.sol";
|
31
|
-
import {IPolicyService} from "./IPolicyService.sol";
|
32
|
-
import {IPoolService} from "../pool/IPoolService.sol";
|
33
|
-
import {IPricingService} from "./IPricingService.sol";
|
34
33
|
|
35
34
|
contract PolicyService is
|
36
|
-
|
35
|
+
Service,
|
37
36
|
IPolicyService
|
38
37
|
{
|
39
|
-
|
40
|
-
using TimestampLib for Timestamp;
|
41
|
-
|
42
|
-
IApplicationService internal _applicationService;
|
38
|
+
IAccountingService private _accountingService;
|
43
39
|
IComponentService internal _componentService;
|
44
|
-
IBundleService internal _bundleService;
|
45
|
-
IClaimService internal _claimService;
|
46
40
|
IDistributionService internal _distributionService;
|
47
41
|
IPoolService internal _poolService;
|
48
42
|
IPricingService internal _pricingService;
|
@@ -56,18 +50,15 @@ contract PolicyService is
|
|
56
50
|
initializer
|
57
51
|
{
|
58
52
|
(
|
59
|
-
address registryAddress
|
60
|
-
//address managerAddress
|
53
|
+
address registryAddress,
|
61
54
|
address authority
|
62
|
-
) = abi.decode(data, (address, address
|
55
|
+
) = abi.decode(data, (address, address));
|
63
56
|
|
64
57
|
_initializeService(registryAddress, authority, owner);
|
65
58
|
|
66
59
|
VersionPart majorVersion = getVersion().toMajorPart();
|
67
|
-
|
68
|
-
_bundleService = IBundleService(getRegistry().getServiceAddress(BUNDLE(), majorVersion));
|
60
|
+
_accountingService = IAccountingService(getRegistry().getServiceAddress(ACCOUNTING(), majorVersion));
|
69
61
|
_componentService = IComponentService(getRegistry().getServiceAddress(COMPONENT(), majorVersion));
|
70
|
-
_claimService = IClaimService(getRegistry().getServiceAddress(CLAIM(), majorVersion));
|
71
62
|
_poolService = IPoolService(getRegistry().getServiceAddress(POOL(), majorVersion));
|
72
63
|
_distributionService = IDistributionService(getRegistry().getServiceAddress(DISTRIBUTION(), majorVersion));
|
73
64
|
_pricingService = IPricingService(getRegistry().getServiceAddress(PRICE(), majorVersion));
|
@@ -80,26 +71,18 @@ contract PolicyService is
|
|
80
71
|
NftId applicationNftId // = policyNftId
|
81
72
|
)
|
82
73
|
external
|
83
|
-
virtual
|
74
|
+
virtual
|
75
|
+
nonReentrant()
|
84
76
|
{
|
85
|
-
|
86
|
-
|
77
|
+
// checks
|
78
|
+
(IInstance instance,,) = _getAndVerifyCallerForPolicy(applicationNftId);
|
87
79
|
|
88
80
|
// check policy is in state applied
|
89
|
-
if (
|
81
|
+
if (instance.getInstanceReader().getPolicyState(applicationNftId) != APPLIED()) {
|
90
82
|
revert ErrorPolicyServicePolicyStateNotApplied(applicationNftId);
|
91
83
|
}
|
92
84
|
|
93
|
-
//
|
94
|
-
IPolicy.PolicyInfo memory applicationInfo = instanceReader.getPolicyInfo(applicationNftId);
|
95
|
-
if(applicationInfo.productNftId != productNftId) {
|
96
|
-
revert ErrorPolicyServicePolicyProductMismatch(
|
97
|
-
applicationNftId,
|
98
|
-
applicationInfo.productNftId,
|
99
|
-
productNftId);
|
100
|
-
}
|
101
|
-
|
102
|
-
|
85
|
+
// effects
|
103
86
|
// store updated policy info
|
104
87
|
instance.getInstanceStore().updatePolicyState(
|
105
88
|
applicationNftId,
|
@@ -115,26 +98,24 @@ contract PolicyService is
|
|
115
98
|
Timestamp activateAt
|
116
99
|
)
|
117
100
|
external
|
118
|
-
virtual
|
101
|
+
virtual
|
102
|
+
nonReentrant()
|
103
|
+
returns (Amount premiumAmount)
|
119
104
|
{
|
120
|
-
//
|
121
|
-
(
|
122
|
-
|
105
|
+
// checks
|
106
|
+
(
|
107
|
+
IInstance instance,
|
108
|
+
NftId productNftId,
|
109
|
+
IPolicy.PolicyInfo memory applicationInfo
|
110
|
+
) = _getAndVerifyCallerForPolicy(applicationNftId);
|
123
111
|
|
124
112
|
// check policy is in state applied
|
113
|
+
InstanceReader instanceReader = instance.getInstanceReader();
|
125
114
|
if (instanceReader.getPolicyState(applicationNftId) != APPLIED()) {
|
126
115
|
revert ErrorPolicyServicePolicyStateNotApplied(applicationNftId);
|
127
116
|
}
|
128
117
|
|
129
|
-
//
|
130
|
-
IPolicy.PolicyInfo memory applicationInfo = instanceReader.getPolicyInfo(applicationNftId);
|
131
|
-
if(applicationInfo.productNftId != productNftId) {
|
132
|
-
revert ErrorPolicyServicePolicyProductMismatch(
|
133
|
-
applicationNftId,
|
134
|
-
applicationInfo.productNftId,
|
135
|
-
productNftId);
|
136
|
-
}
|
137
|
-
|
118
|
+
// effects
|
138
119
|
// actual collateralizaion
|
139
120
|
_poolService.lockCollateral(
|
140
121
|
instance,
|
@@ -145,11 +126,8 @@ contract PolicyService is
|
|
145
126
|
applicationInfo.sumInsuredAmount);
|
146
127
|
|
147
128
|
// optional activation of policy
|
148
|
-
if(activateAt >
|
149
|
-
applicationInfo = _activate(
|
150
|
-
applicationNftId,
|
151
|
-
applicationInfo,
|
152
|
-
activateAt);
|
129
|
+
if(activateAt > TimestampLib.zero()) {
|
130
|
+
applicationInfo = _activate(applicationNftId, applicationInfo, activateAt);
|
153
131
|
}
|
154
132
|
|
155
133
|
// update policy and set state to collateralized
|
@@ -159,32 +137,44 @@ contract PolicyService is
|
|
159
137
|
COLLATERALIZED());
|
160
138
|
|
161
139
|
// calculate and store premium
|
140
|
+
RiskId riskId = applicationInfo.riskId;
|
141
|
+
NftId bundleNftId = applicationInfo.bundleNftId;
|
142
|
+
|
162
143
|
IPolicy.PremiumInfo memory premium = _pricingService.calculatePremium(
|
163
144
|
productNftId,
|
164
|
-
|
145
|
+
riskId,
|
165
146
|
applicationInfo.sumInsuredAmount,
|
166
147
|
applicationInfo.lifetime,
|
167
148
|
applicationInfo.applicationData,
|
168
|
-
|
149
|
+
bundleNftId,
|
169
150
|
applicationInfo.referralId);
|
170
151
|
|
152
|
+
premiumAmount = premium.fullPremiumAmount;
|
171
153
|
instance.getInstanceStore().createPremium(
|
172
154
|
applicationNftId,
|
173
155
|
premium);
|
174
156
|
|
175
|
-
// update referral counter
|
157
|
+
// update referral counter if product has linked distributino component
|
176
158
|
{
|
177
159
|
IComponents.ProductInfo memory productInfo = instanceReader.getProductInfo(productNftId);
|
178
|
-
|
179
|
-
|
180
|
-
|
160
|
+
if (productInfo.hasDistribution) {
|
161
|
+
_distributionService.processReferral(
|
162
|
+
productInfo.distributionNftId,
|
163
|
+
applicationInfo.referralId);
|
164
|
+
}
|
181
165
|
}
|
182
|
-
|
183
|
-
// TODO add calling pool contract if it needs to validate application
|
184
166
|
|
185
|
-
//
|
167
|
+
// link policy to risk and bundle
|
168
|
+
NftId poolNftId = getRegistry().getObjectInfo(bundleNftId).parentNftId;
|
169
|
+
instance.getRiskSet().linkPolicy(productNftId, riskId, applicationNftId);
|
170
|
+
instance.getBundleSet().linkPolicy(poolNftId, bundleNftId, applicationNftId);
|
171
|
+
|
172
|
+
// log policy creation before interactions with token and policy holder
|
173
|
+
emit LogPolicyServicePolicyCreated(applicationNftId, premium.premiumAmount, activateAt);
|
186
174
|
|
187
|
-
//
|
175
|
+
// interactions
|
176
|
+
// callback to policy holder if applicable
|
177
|
+
_policyHolderPolicyActivated(applicationNftId, activateAt);
|
188
178
|
}
|
189
179
|
|
190
180
|
|
@@ -195,29 +185,42 @@ contract PolicyService is
|
|
195
185
|
)
|
196
186
|
external
|
197
187
|
virtual
|
188
|
+
nonReentrant()
|
198
189
|
{
|
199
|
-
//
|
200
|
-
(
|
201
|
-
|
202
|
-
|
190
|
+
// checks
|
191
|
+
(
|
192
|
+
IInstance instance,
|
193
|
+
NftId productNftId,
|
194
|
+
IPolicy.PolicyInfo memory policyInfo
|
195
|
+
) = _getAndVerifyCallerForPolicy(policyNftId);
|
203
196
|
|
204
|
-
// check policy is in state collateralized
|
205
|
-
|
197
|
+
// check policy is in state collateralized
|
198
|
+
InstanceReader instanceReader = instance.getInstanceReader();
|
199
|
+
if (instanceReader.getPolicyState(policyNftId) != COLLATERALIZED()) {
|
206
200
|
revert ErrorPolicyServicePolicyStateNotCollateralized(policyNftId);
|
207
201
|
}
|
208
202
|
|
209
|
-
// check if premium
|
203
|
+
// check if premium has already been collected
|
210
204
|
if (instanceReader.getPremiumInfoState(policyNftId) == PAID()) {
|
211
205
|
revert ErrorPolicyServicePremiumAlreadyPaid(policyNftId);
|
212
206
|
}
|
213
207
|
|
214
|
-
|
215
|
-
IPolicy.PremiumInfo memory premium = instanceReader.getPremiumInfo(policyNftId);
|
216
|
-
|
217
|
-
|
218
|
-
|
219
|
-
|
220
|
-
|
208
|
+
// check funds and allowance of policy holder
|
209
|
+
IPolicy.PremiumInfo memory premium = instanceReader.getPremiumInfo(policyNftId);
|
210
|
+
TokenHandler tokenHandler = _getTokenHandler(instanceReader, policyInfo.productNftId);
|
211
|
+
_checkPremiumBalanceAndAllowance(
|
212
|
+
tokenHandler.TOKEN(),
|
213
|
+
address(tokenHandler),
|
214
|
+
getRegistry().ownerOf(policyNftId),
|
215
|
+
premium.premiumAmount);
|
216
|
+
|
217
|
+
// effects
|
218
|
+
_processSale(
|
219
|
+
instanceReader,
|
220
|
+
instance.getInstanceStore(),
|
221
|
+
productNftId,
|
222
|
+
policyInfo.bundleNftId,
|
223
|
+
policyInfo.referralId,
|
221
224
|
premium);
|
222
225
|
|
223
226
|
// optionally activate policy
|
@@ -228,27 +231,36 @@ contract PolicyService is
|
|
228
231
|
instance.getInstanceStore().updatePolicy(policyNftId, policyInfo, KEEP_STATE());
|
229
232
|
instance.getInstanceStore().updatePremiumState(policyNftId, PAID());
|
230
233
|
|
231
|
-
//
|
234
|
+
// log premium collection before interactions with token
|
235
|
+
emit LogPolicyServicePolicyPremiumCollected(policyNftId, premium.premiumAmount);
|
232
236
|
|
237
|
+
// interactions
|
233
238
|
_transferFunds(instanceReader, policyNftId, policyInfo.productNftId, premium);
|
234
|
-
|
235
|
-
// TODO: add callback IPolicyHolder.policyActivated() if applicable
|
236
239
|
}
|
237
240
|
|
241
|
+
|
238
242
|
/// @inheritdoc IPolicyService
|
239
|
-
function activate(NftId policyNftId, Timestamp activateAt)
|
240
|
-
|
241
|
-
|
242
|
-
|
243
|
+
function activate(NftId policyNftId, Timestamp activateAt)
|
244
|
+
external
|
245
|
+
virtual
|
246
|
+
nonReentrant()
|
247
|
+
{
|
248
|
+
// checks
|
249
|
+
(
|
250
|
+
IInstance instance,,
|
251
|
+
IPolicy.PolicyInfo memory policyInfo
|
252
|
+
) = _getAndVerifyCallerForPolicy(policyNftId);
|
243
253
|
|
244
|
-
|
254
|
+
// effects
|
245
255
|
policyInfo = _activate(policyNftId, policyInfo, activateAt);
|
246
|
-
|
247
256
|
instance.getInstanceStore().updatePolicy(policyNftId, policyInfo, KEEP_STATE());
|
248
257
|
|
249
|
-
//
|
258
|
+
// log policy activation before interactions with policy holder
|
259
|
+
emit LogPolicyServicePolicyActivated(policyNftId, activateAt);
|
250
260
|
|
251
|
-
//
|
261
|
+
// interactions
|
262
|
+
// callback to policy holder if applicable
|
263
|
+
_policyHolderPolicyActivated(policyNftId, activateAt);
|
252
264
|
}
|
253
265
|
|
254
266
|
|
@@ -258,90 +270,86 @@ contract PolicyService is
|
|
258
270
|
Timestamp expireAt
|
259
271
|
)
|
260
272
|
external
|
261
|
-
override
|
262
273
|
virtual
|
274
|
+
nonReentrant()
|
263
275
|
returns (Timestamp expiredAt)
|
264
276
|
{
|
265
|
-
|
266
|
-
|
267
|
-
|
268
|
-
|
269
|
-
|
270
|
-
if(policyInfo.productNftId != productNftId) {
|
271
|
-
revert ErrorPolicyServicePolicyProductMismatch(
|
272
|
-
policyNftId,
|
273
|
-
policyInfo.productNftId,
|
274
|
-
productNftId);
|
275
|
-
}
|
276
|
-
|
277
|
-
// check policy is active
|
278
|
-
StateId policyState = instanceReader.getPolicyState(policyNftId);
|
279
|
-
if (!_policyHasBeenActivated(policyState, policyInfo)) {
|
280
|
-
revert ErrorPolicyServicePolicyNotActive(policyNftId, policyState);
|
281
|
-
}
|
282
|
-
|
283
|
-
// set return value to provided timestamp
|
284
|
-
expiredAt = expireAt;
|
285
|
-
|
286
|
-
// update expiredAt to current block timestamp if not set
|
287
|
-
if (expiredAt.eqz()) {
|
288
|
-
expiredAt = TimestampLib.blockTimestamp();
|
289
|
-
}
|
277
|
+
// checks
|
278
|
+
(
|
279
|
+
IInstance instance,,
|
280
|
+
IPolicy.PolicyInfo memory policyInfo
|
281
|
+
) = _getAndVerifyCallerForPolicy(policyNftId);
|
290
282
|
|
291
|
-
//
|
292
|
-
|
293
|
-
|
294
|
-
|
295
|
-
|
296
|
-
|
297
|
-
|
283
|
+
// more checks, effects + interactions
|
284
|
+
return _expire(
|
285
|
+
instance,
|
286
|
+
policyNftId,
|
287
|
+
policyInfo,
|
288
|
+
expireAt
|
289
|
+
);
|
290
|
+
}
|
298
291
|
|
299
|
-
// update policyInfo with new expiredAt timestamp
|
300
|
-
policyInfo.expiredAt = expiredAt;
|
301
|
-
instance.getInstanceStore().updatePolicy(policyNftId, policyInfo, KEEP_STATE());
|
302
292
|
|
303
|
-
|
293
|
+
/// @inheritdoc IPolicyService
|
294
|
+
function expirePolicy(
|
295
|
+
IInstance instance,
|
296
|
+
NftId policyNftId,
|
297
|
+
Timestamp expireAt
|
298
|
+
)
|
299
|
+
external
|
300
|
+
virtual
|
301
|
+
nonReentrant()
|
302
|
+
returns (Timestamp expiredAt)
|
303
|
+
{
|
304
|
+
// checks
|
305
|
+
_checkNftType(policyNftId, POLICY());
|
306
|
+
IPolicy.PolicyInfo memory policyInfo = instance.getInstanceReader().getPolicyInfo(
|
307
|
+
policyNftId);
|
304
308
|
|
305
|
-
//
|
309
|
+
// more checks, effects + interactions
|
310
|
+
return _expire(
|
311
|
+
instance,
|
312
|
+
policyNftId,
|
313
|
+
policyInfo,
|
314
|
+
expireAt
|
315
|
+
);
|
306
316
|
}
|
307
317
|
|
308
318
|
|
319
|
+
/// @inheritdoc IPolicyService
|
309
320
|
function close(
|
310
321
|
NftId policyNftId
|
311
322
|
)
|
312
323
|
external
|
313
|
-
|
324
|
+
virtual
|
325
|
+
nonReentrant()
|
314
326
|
{
|
315
|
-
|
327
|
+
// checks
|
328
|
+
(
|
329
|
+
IInstance instance,
|
330
|
+
NftId productNftId,
|
331
|
+
IPolicy.PolicyInfo memory policyInfo
|
332
|
+
) = _getAndVerifyCallerForPolicy(policyNftId);
|
316
333
|
InstanceReader instanceReader = instance.getInstanceReader();
|
317
334
|
|
318
|
-
// check
|
319
|
-
|
320
|
-
|
321
|
-
if (!_policyHasBeenActivated(policyState, policyInfo)) {
|
322
|
-
revert ErrorPolicyServicePolicyNotActive(policyNftId, policyState);
|
335
|
+
// check policy is in a closeable state
|
336
|
+
if (!policyIsCloseable(instanceReader, policyNftId)) {
|
337
|
+
revert ErrorPolicyServicePolicyNotCloseable(policyNftId);
|
323
338
|
}
|
324
339
|
|
325
|
-
// check that policy has
|
326
|
-
|
327
|
-
|
328
|
-
}
|
329
|
-
|
330
|
-
// check that policy does not have any open claims
|
331
|
-
if (policyInfo.openClaimsCount > 0) {
|
332
|
-
revert ErrorPolicyServiceOpenClaims(policyNftId, policyInfo.openClaimsCount);
|
333
|
-
}
|
340
|
+
// check that policy has been activated
|
341
|
+
RiskId riskId = policyInfo.riskId;
|
342
|
+
NftId bundleNftId = policyInfo.bundleNftId;
|
334
343
|
|
335
|
-
|
336
|
-
// TODO consider to remove requirement for fully paid premiums altogether
|
337
|
-
if (! instanceReader.getPremiumInfoState(policyNftId).eq(PAID())) {
|
344
|
+
if (instanceReader.getPremiumInfoState(policyNftId) != PAID()) {
|
338
345
|
revert ErrorPolicyServicePremiumNotPaid(policyNftId, policyInfo.premiumAmount);
|
339
346
|
}
|
340
347
|
|
348
|
+
// effects
|
341
349
|
// release (remaining) collateral that was blocked by policy
|
342
350
|
_poolService.releaseCollateral(
|
343
351
|
instance,
|
344
|
-
address(instanceReader.getComponentInfo(
|
352
|
+
address(instanceReader.getComponentInfo(productNftId).token),
|
345
353
|
policyNftId,
|
346
354
|
policyInfo);
|
347
355
|
|
@@ -351,45 +359,111 @@ contract PolicyService is
|
|
351
359
|
policyInfo.closedAt = TimestampLib.blockTimestamp();
|
352
360
|
instance.getInstanceStore().updatePolicy(policyNftId, policyInfo, CLOSED());
|
353
361
|
|
354
|
-
//
|
362
|
+
// unlink policy from risk and bundle
|
363
|
+
NftId poolNftId = getRegistry().getObjectInfo(bundleNftId).parentNftId;
|
364
|
+
instance.getRiskSet().unlinkPolicy(productNftId, riskId, policyNftId);
|
365
|
+
instance.getBundleSet().unlinkPolicy(poolNftId, bundleNftId, policyNftId);
|
366
|
+
|
367
|
+
emit LogPolicyServicePolicyClosed(policyNftId);
|
355
368
|
}
|
356
369
|
|
357
370
|
|
358
|
-
|
359
|
-
|
371
|
+
function policyIsCloseable(InstanceReader instanceReader, NftId policyNftId)
|
372
|
+
public
|
373
|
+
view
|
374
|
+
returns (bool isCloseable)
|
375
|
+
{
|
376
|
+
// policy already closed
|
377
|
+
if (instanceReader.getPolicyState(policyNftId) == CLOSED()) {
|
378
|
+
return false;
|
379
|
+
}
|
380
|
+
|
381
|
+
IPolicy.PolicyInfo memory info = instanceReader.getPolicyInfo(policyNftId);
|
382
|
+
|
383
|
+
if (info.productNftId.eqz()) { return false; } // not closeable: policy does not exist (or does not belong to this instance)
|
384
|
+
if (info.activatedAt.eqz()) { return false; } // not closeable: not yet activated
|
385
|
+
if (info.openClaimsCount > 0) { return false; } // not closeable: has open claims
|
386
|
+
|
387
|
+
// closeable: if sum of claims matches sum insured a policy may be closed prior to the expiry date
|
388
|
+
if (info.claimAmount == info.sumInsuredAmount) { return true; }
|
389
|
+
|
390
|
+
// not closeable: not yet expired
|
391
|
+
if (TimestampLib.blockTimestamp() < info.expiredAt) { return false; }
|
392
|
+
|
393
|
+
// all conditions to close the policy are met
|
394
|
+
return true;
|
395
|
+
}
|
396
|
+
|
397
|
+
/// @dev shared functionality for expire() and policyExpire().
|
398
|
+
function _expire(
|
360
399
|
IInstance instance,
|
361
|
-
NftId
|
362
|
-
IPolicy.PolicyInfo memory
|
363
|
-
|
400
|
+
NftId policyNftId,
|
401
|
+
IPolicy.PolicyInfo memory policyInfo,
|
402
|
+
Timestamp expireAt
|
364
403
|
)
|
365
404
|
internal
|
366
|
-
|
405
|
+
returns (Timestamp expiredAt)
|
367
406
|
{
|
368
|
-
|
369
|
-
|
407
|
+
// checks
|
408
|
+
// check policy is active
|
409
|
+
StateId policyState = instance.getInstanceReader().getPolicyState(policyNftId);
|
410
|
+
if (!_policyHasBeenActivated(policyState, policyInfo)) {
|
411
|
+
revert ErrorPolicyServicePolicyNotActive(policyNftId, policyState);
|
412
|
+
}
|
370
413
|
|
371
|
-
//
|
372
|
-
|
373
|
-
|
374
|
-
|
375
|
-
|
376
|
-
|
377
|
-
tokenHandler.getToken(),
|
378
|
-
address(tokenHandler),
|
379
|
-
policyHolder,
|
380
|
-
premium.premiumAmount);
|
414
|
+
// set return value to provided timestamp
|
415
|
+
expiredAt = expireAt;
|
416
|
+
|
417
|
+
// update expiredAt to current block timestamp if not set
|
418
|
+
if (expiredAt.eqz()) {
|
419
|
+
expiredAt = TimestampLib.blockTimestamp();
|
381
420
|
}
|
382
421
|
|
383
|
-
//
|
384
|
-
|
385
|
-
|
386
|
-
|
387
|
-
|
388
|
-
|
389
|
-
|
390
|
-
|
422
|
+
// check expiredAt represents a valid expiry time
|
423
|
+
if (expiredAt >= policyInfo.expiredAt) {
|
424
|
+
revert ErrorPolicyServicePolicyExpirationTooLate(policyNftId, policyInfo.expiredAt, expireAt);
|
425
|
+
}
|
426
|
+
|
427
|
+
if (expiredAt < TimestampLib.blockTimestamp()) {
|
428
|
+
revert ErrorPolicyServicePolicyExpirationTooEarly(policyNftId, TimestampLib.blockTimestamp(), expireAt);
|
429
|
+
}
|
430
|
+
|
431
|
+
// effects
|
432
|
+
// update policyInfo with new expiredAt timestamp
|
433
|
+
Timestamp originalExpiredAt = policyInfo.expiredAt;
|
434
|
+
policyInfo.expiredAt = expiredAt;
|
435
|
+
instance.getInstanceStore().updatePolicy(policyNftId, policyInfo, KEEP_STATE());
|
436
|
+
|
437
|
+
emit LogPolicyServicePolicyExpirationUpdated(policyNftId, originalExpiredAt, expiredAt);
|
438
|
+
|
439
|
+
// interactions
|
440
|
+
// callback to policy holder if applicable
|
441
|
+
_policyHolderPolicyExpired(policyNftId, expiredAt);
|
391
442
|
}
|
392
443
|
|
444
|
+
// TODO cleanup
|
445
|
+
// /// @dev Calculates the premium and updates all counters in the other services.
|
446
|
+
// /// Only book keeping, no token transfers.
|
447
|
+
// function _processPremium(
|
448
|
+
// IInstance instance,
|
449
|
+
// NftId applicationNftId,
|
450
|
+
// IPolicy.PolicyInfo memory applicationInfo,
|
451
|
+
// IPolicy.PremiumInfo memory premium
|
452
|
+
// )
|
453
|
+
// internal
|
454
|
+
// virtual
|
455
|
+
// {
|
456
|
+
// // update the counters
|
457
|
+
// _processSale(
|
458
|
+
// instanceReader,
|
459
|
+
// instance.getInstanceStore(),
|
460
|
+
// productNftId,
|
461
|
+
// applicationInfo.bundleNftId,
|
462
|
+
// applicationInfo.referralId,
|
463
|
+
// premium);
|
464
|
+
// }
|
465
|
+
|
466
|
+
|
393
467
|
function _activate(
|
394
468
|
NftId policyNftId,
|
395
469
|
IPolicy.PolicyInfo memory policyInfo,
|
@@ -428,21 +502,23 @@ contract PolicyService is
|
|
428
502
|
internal
|
429
503
|
virtual
|
430
504
|
{
|
431
|
-
(NftId distributionNftId
|
505
|
+
(NftId distributionNftId,,,) = _getDistributionNftAndWallets(
|
432
506
|
instanceReader,
|
433
507
|
productNftId);
|
434
508
|
|
435
509
|
// update product fees, distribution and pool fees
|
436
|
-
|
510
|
+
_accountingService.increaseProductFees(
|
437
511
|
instanceStore,
|
438
512
|
productNftId,
|
439
513
|
premium.productFeeVarAmount + premium.productFeeFixAmount);
|
440
514
|
|
441
515
|
// update distribution fees and distributor commission and pool fees
|
442
|
-
|
443
|
-
|
444
|
-
|
445
|
-
|
516
|
+
if (!distributionNftId.eqz()) { // only call distribution service if a distribution component is connected to the product
|
517
|
+
_distributionService.processSale(
|
518
|
+
distributionNftId,
|
519
|
+
referralId,
|
520
|
+
premium);
|
521
|
+
}
|
446
522
|
|
447
523
|
// update pool and bundle fees
|
448
524
|
_poolService.processSale(
|
@@ -525,6 +601,64 @@ contract PolicyService is
|
|
525
601
|
}
|
526
602
|
|
527
603
|
|
604
|
+
function _policyHolderPolicyActivated(
|
605
|
+
NftId policyNftId,
|
606
|
+
Timestamp activateAt
|
607
|
+
)
|
608
|
+
internal
|
609
|
+
virtual
|
610
|
+
{
|
611
|
+
// immediately return if policy is not activated
|
612
|
+
if (activateAt.eqz()) {
|
613
|
+
return;
|
614
|
+
}
|
615
|
+
|
616
|
+
// get policy holder address
|
617
|
+
IPolicyHolder policyHolder = _getPolicyHolder(policyNftId);
|
618
|
+
|
619
|
+
// execute callback if policy holder implements IPolicyHolder
|
620
|
+
if (address(policyHolder) != address(0)) {
|
621
|
+
policyHolder.policyActivated(policyNftId, activateAt);
|
622
|
+
}
|
623
|
+
}
|
624
|
+
|
625
|
+
|
626
|
+
function _policyHolderPolicyExpired(
|
627
|
+
NftId policyNftId,
|
628
|
+
Timestamp expiredAt
|
629
|
+
)
|
630
|
+
internal
|
631
|
+
virtual
|
632
|
+
{
|
633
|
+
// immediately return if policy is not activated
|
634
|
+
if (expiredAt.eqz()) {
|
635
|
+
return;
|
636
|
+
}
|
637
|
+
|
638
|
+
// get policy holder address
|
639
|
+
IPolicyHolder policyHolder = _getPolicyHolder(policyNftId);
|
640
|
+
|
641
|
+
// execute callback if policy holder implements IPolicyHolder
|
642
|
+
if (address(policyHolder) != address(0)) {
|
643
|
+
policyHolder.policyExpired(policyNftId, expiredAt);
|
644
|
+
}
|
645
|
+
}
|
646
|
+
|
647
|
+
|
648
|
+
function _getPolicyHolder(NftId policyNftId)
|
649
|
+
internal
|
650
|
+
view
|
651
|
+
returns (IPolicyHolder policyHolder)
|
652
|
+
{
|
653
|
+
address policyHolderAddress = getRegistry().ownerOf(policyNftId);
|
654
|
+
policyHolder = IPolicyHolder(policyHolderAddress);
|
655
|
+
|
656
|
+
if (!ContractLib.isPolicyHolder(policyHolderAddress)) {
|
657
|
+
policyHolder = IPolicyHolder(address(0));
|
658
|
+
}
|
659
|
+
}
|
660
|
+
|
661
|
+
|
528
662
|
function _getTokenHandler(
|
529
663
|
InstanceReader instanceReader,
|
530
664
|
NftId productNftId
|
@@ -539,6 +673,7 @@ contract PolicyService is
|
|
539
673
|
tokenHandler = instanceReader.getComponentInfo(productNftId).tokenHandler;
|
540
674
|
}
|
541
675
|
|
676
|
+
|
542
677
|
function _getDistributionNftAndWallets(
|
543
678
|
InstanceReader instanceReader,
|
544
679
|
NftId productNftId
|
@@ -553,17 +688,45 @@ contract PolicyService is
|
|
553
688
|
)
|
554
689
|
{
|
555
690
|
IComponents.ProductInfo memory productInfo = instanceReader.getProductInfo(productNftId);
|
556
|
-
|
557
|
-
|
558
|
-
|
559
|
-
|
691
|
+
productWallet = instanceReader.getComponentInfo(productNftId).tokenHandler.getWallet();
|
692
|
+
poolWallet = instanceReader.getComponentInfo(productInfo.poolNftId).tokenHandler.getWallet();
|
693
|
+
|
694
|
+
if (productInfo.hasDistribution) {
|
695
|
+
distributionNftId = productInfo.distributionNftId;
|
696
|
+
distributionWallet = instanceReader.getComponentInfo(distributionNftId).tokenHandler.getWallet();
|
697
|
+
}
|
560
698
|
}
|
561
699
|
|
562
700
|
|
563
|
-
function
|
564
|
-
|
565
|
-
|
566
|
-
|
701
|
+
function _getAndVerifyCallerForPolicy(NftId policyNftId)
|
702
|
+
internal
|
703
|
+
virtual
|
704
|
+
view
|
705
|
+
returns (
|
706
|
+
IInstance instance,
|
707
|
+
NftId productNftId,
|
708
|
+
IPolicy.PolicyInfo memory policyInfo
|
709
|
+
)
|
710
|
+
{
|
711
|
+
(
|
712
|
+
IRegistry.ObjectInfo memory productInfo,
|
713
|
+
address instanceAddress
|
714
|
+
) = ContractLib.getAndVerifyComponent(
|
715
|
+
getRegistry(),
|
716
|
+
msg.sender, // caller contract
|
717
|
+
PRODUCT(), // caller must be product
|
718
|
+
true); // only active caller
|
719
|
+
|
720
|
+
productNftId = productInfo.nftId;
|
721
|
+
instance = IInstance(instanceAddress);
|
722
|
+
policyInfo = instance.getInstanceReader().getPolicyInfo(policyNftId);
|
723
|
+
|
724
|
+
if (policyInfo.productNftId != productNftId) {
|
725
|
+
revert ErrorPolicyServicePolicyProductMismatch(
|
726
|
+
policyNftId,
|
727
|
+
productNftId,
|
728
|
+
policyInfo.productNftId);
|
729
|
+
}
|
567
730
|
}
|
568
731
|
|
569
732
|
|