@etherisc/gif-next 0.0.2-a714036-117 → 0.0.2-a755cba-731
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 +32 -8
- 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 +105 -65
- 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 +156 -412
- 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 +96 -344
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +229 -292
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +125 -117
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +84 -142
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +101 -62
- 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 +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.json +1429 -0
- 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 +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +1145 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +1605 -0
- 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 +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +2329 -0
- 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 +141 -141
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +197 -139
- 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 +746 -134
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +118 -260
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +99 -87
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +339 -140
- 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 +109 -365
- 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 +72 -130
- 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 +85 -333
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +147 -191
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +119 -83
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +108 -356
- 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 +160 -334
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +111 -131
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +60 -65
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +94 -163
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +277 -205
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +105 -364
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +385 -418
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +120 -100
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +124 -181
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +89 -89
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +147 -349
- 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 +433 -193
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +141 -105
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +68 -7
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +292 -6
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +281 -142
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +114 -85
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +131 -143
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +4 -0
- package/artifacts/contracts/product/{IProductService.sol/IProductService.json → IRiskService.sol/IRiskService.json} +31 -2
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +351 -338
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +126 -98
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +215 -309
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +117 -117
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +145 -347
- package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +4 -0
- package/artifacts/contracts/product/RiskService.sol/RiskService.json +638 -0
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +718 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +59 -16
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +310 -34
- 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 +516 -95
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +296 -143
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +94 -284
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +91 -75
- 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 +131 -223
- 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 +69 -288
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +471 -593
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +133 -127
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +47 -112
- 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 -90
- 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 +72 -130
- 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 +15 -47
- 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/InitializableERC165.sol/InitializableERC165.json +2 -22
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +84 -332
- 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 +22 -57
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +19 -141
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +58 -89
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -15
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +47 -112
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +697 -25
- 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 +4 -0
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +172 -0
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +106 -127
- 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 +64 -94
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +190 -379
- 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 +118 -99
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +6 -11
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +87 -165
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +95 -79
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +170 -129
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +55 -24
- 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/Seconds.sol/SecondsLib.json +26 -2
- package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +1 -1
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/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 +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 +71 -70
- 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 +83 -59
- package/contracts/authorization/Authorization.sol +111 -40
- 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 +33 -41
- package/contracts/distribution/DistributionService.sol +109 -89
- package/contracts/distribution/DistributionServiceManager.sol +6 -6
- package/contracts/distribution/IDistributionComponent.sol +1 -1
- package/contracts/distribution/IDistributionService.sol +14 -11
- 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 +57 -0
- package/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol +28 -0
- package/contracts/examples/unpermissioned/SimpleOracle.sol +137 -0
- package/contracts/examples/unpermissioned/SimplePool.sol +107 -0
- package/contracts/examples/unpermissioned/SimplePoolAuthorization.sol +28 -0
- package/contracts/examples/unpermissioned/SimpleProduct.sol +366 -0
- package/contracts/examples/unpermissioned/SimpleProductAuthorization.sol +28 -0
- package/contracts/instance/BundleSet.sol +38 -34
- package/contracts/instance/IInstance.sol +16 -31
- package/contracts/instance/IInstanceService.sol +7 -29
- package/contracts/instance/Instance.sol +44 -59
- package/contracts/instance/InstanceAdmin.sol +76 -54
- package/contracts/instance/InstanceAuthorizationV3.sol +53 -34
- package/contracts/instance/InstanceReader.sol +203 -27
- package/contracts/instance/InstanceService.sol +97 -148
- package/contracts/instance/InstanceServiceManager.sol +6 -7
- package/contracts/instance/InstanceStore.sol +11 -1
- package/contracts/instance/RiskSet.sol +119 -0
- package/contracts/instance/base/ObjectCounter.sol +1 -2
- package/contracts/instance/base/ObjectLifecycle.sol +10 -4
- package/contracts/instance/base/ObjectSet.sol +24 -25
- package/contracts/instance/module/IComponents.sol +11 -8
- package/contracts/instance/module/IPolicy.sol +26 -25
- 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 +6 -16
- package/contracts/oracle/OracleService.sol +112 -81
- package/contracts/oracle/OracleServiceManager.sol +6 -6
- package/contracts/pool/BasicPool.sol +35 -26
- package/contracts/pool/BasicPoolAuthorization.sol +14 -4
- package/contracts/pool/BundleService.sol +105 -118
- package/contracts/pool/BundleServiceManager.sol +6 -6
- package/contracts/pool/IBundleService.sol +8 -20
- package/contracts/pool/IPoolComponent.sol +19 -15
- package/contracts/pool/IPoolService.sol +52 -48
- package/contracts/pool/Pool.sol +145 -128
- package/contracts/pool/PoolService.sol +295 -208
- package/contracts/pool/PoolServiceManager.sol +4 -4
- package/contracts/product/ApplicationService.sol +71 -42
- package/contracts/product/ApplicationServiceManager.sol +4 -4
- package/contracts/product/BasicProduct.sol +9 -12
- package/contracts/product/BasicProductAuthorization.sol +1 -3
- package/contracts/product/ClaimService.sol +393 -127
- package/contracts/product/ClaimServiceManager.sol +4 -4
- package/contracts/product/IApplicationService.sol +6 -2
- package/contracts/product/IClaimService.sol +44 -7
- package/contracts/product/IPolicyService.sol +44 -38
- package/contracts/product/IPricingService.sol +10 -10
- package/contracts/product/IProductComponent.sol +23 -4
- package/contracts/product/{IProductService.sol → IRiskService.sol} +1 -1
- package/contracts/product/PolicyService.sol +501 -294
- package/contracts/product/PolicyServiceManager.sol +4 -4
- package/contracts/product/PricingService.sol +54 -54
- package/contracts/product/PricingServiceManager.sol +3 -3
- package/contracts/product/Product.sol +133 -93
- package/contracts/product/{ProductService.sol → RiskService.sol} +21 -13
- package/contracts/product/RiskServiceManager.sol +39 -0
- package/contracts/registry/ChainNft.sol +72 -40
- package/contracts/registry/IRegistry.sol +57 -18
- package/contracts/registry/IRegistryService.sol +5 -12
- package/contracts/registry/ITransferInterceptor.sol +1 -2
- package/contracts/registry/Registry.sol +350 -201
- package/contracts/registry/RegistryAdmin.sol +147 -55
- package/contracts/registry/RegistryService.sol +35 -46
- package/contracts/registry/RegistryServiceManager.sol +2 -2
- package/contracts/registry/ReleaseLifecycle.sol +6 -3
- package/contracts/registry/ReleaseRegistry.sol +207 -206
- package/contracts/registry/ServiceAuthorizationV3.sol +59 -52
- package/contracts/shared/Component.sol +60 -121
- package/contracts/shared/ComponentService.sol +390 -345
- package/contracts/shared/ComponentServiceManager.sol +8 -5
- package/contracts/shared/ComponentVerifyingService.sol +28 -17
- 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 +6 -32
- package/contracts/shared/ILifecycle.sol +3 -1
- package/contracts/shared/INftOwnable.sol +2 -0
- package/contracts/shared/IPolicyHolder.sol +12 -22
- package/contracts/shared/IRegisterable.sol +11 -0
- package/contracts/shared/InitializableERC165.sol +2 -2
- package/contracts/shared/InstanceLinkedComponent.sol +72 -47
- package/contracts/shared/KeyValueStore.sol +1 -1
- package/contracts/shared/Lifecycle.sol +15 -4
- package/contracts/shared/NftOwnable.sol +27 -7
- package/contracts/shared/PolicyHolder.sol +15 -52
- package/contracts/shared/Registerable.sol +19 -11
- package/contracts/shared/RegistryLinked.sol +9 -14
- package/contracts/shared/Service.sol +20 -18
- package/contracts/shared/TokenHandler.sol +358 -27
- package/contracts/shared/TokenHandlerDeployerLib.sol +20 -0
- package/contracts/staking/IStaking.sol +11 -5
- package/contracts/staking/IStakingService.sol +0 -3
- package/contracts/staking/StakeManagerLib.sol +18 -25
- package/contracts/staking/Staking.sol +49 -50
- package/contracts/staking/StakingManager.sol +8 -6
- package/contracts/staking/StakingReader.sol +12 -5
- package/contracts/staking/StakingService.sol +65 -36
- package/contracts/staking/StakingServiceManager.sol +2 -2
- package/contracts/staking/TargetManagerLib.sol +7 -3
- 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 +26 -11
- package/contracts/type/PayoutId.sol +10 -10
- package/contracts/type/RiskId.sol +30 -4
- package/contracts/type/RoleId.sol +0 -12
- package/contracts/type/Seconds.sol +8 -0
- package/contracts/type/StateId.sol +15 -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/product/IProductService.sol/IProductService.dbg.json +0 -4
- package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +0 -4
- package/artifacts/contracts/product/ProductService.sol/ProductService.json +0 -708
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +0 -702
- 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/product/ProductServiceManager.sol +0 -39
- package/contracts/shared/InitializableCustom.sol +0 -177
@@ -1,52 +1,46 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
-
import {
|
5
|
-
import {Product} from "./Product.sol";
|
6
|
-
import {IComponents} from "../instance/module/IComponents.sol";
|
7
|
-
import {IInstance} from "../instance/IInstance.sol";
|
8
|
-
import {IPolicy} from "../instance/module/IPolicy.sol";
|
9
|
-
|
10
|
-
import {TokenHandler} from "../shared/TokenHandler.sol";
|
11
|
-
|
12
|
-
import {Amount, AmountLib} from "../type/Amount.sol";
|
13
|
-
import {Timestamp, TimestampLib, zeroTimestamp} from "../type/Timestamp.sol";
|
14
|
-
import {ObjectType, APPLICATION, COMPONENT, DISTRIBUTION, PRODUCT, POOL, POLICY, BUNDLE, CLAIM, PRICE} from "../type/ObjectType.sol";
|
15
|
-
import {APPLIED, COLLATERALIZED, ACTIVE, KEEP_STATE, CLOSED, DECLINED} from "../type/StateId.sol";
|
16
|
-
import {NftId, NftIdLib} from "../type/NftId.sol";
|
17
|
-
import {ReferralId} from "../type/Referral.sol";
|
18
|
-
import {StateId} from "../type/StateId.sol";
|
19
|
-
import {VersionPart} from "../type/Version.sol";
|
4
|
+
import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
|
20
5
|
|
21
|
-
import {
|
22
|
-
import {IApplicationService} from "./IApplicationService.sol";
|
23
|
-
import {IBundleService} from "../pool/IBundleService.sol";
|
24
|
-
import {IClaimService} from "./IClaimService.sol";
|
6
|
+
import {IAccountingService} from "../accounting/IAccountingService.sol";
|
25
7
|
import {IComponentService} from "../shared/IComponentService.sol";
|
8
|
+
import {IComponents} from "../instance/module/IComponents.sol";
|
26
9
|
import {IDistributionService} from "../distribution/IDistributionService.sol";
|
27
10
|
import {InstanceReader} from "../instance/InstanceReader.sol";
|
28
11
|
import {InstanceStore} from "../instance/InstanceStore.sol";
|
12
|
+
import {IInstance} from "../instance/IInstance.sol";
|
13
|
+
import {IPolicy} from "../instance/module/IPolicy.sol";
|
14
|
+
import {IPolicyHolder} from "../shared/IPolicyHolder.sol";
|
29
15
|
import {IPolicyService} from "./IPolicyService.sol";
|
30
16
|
import {IPoolService} from "../pool/IPoolService.sol";
|
31
17
|
import {IPricingService} from "./IPricingService.sol";
|
18
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
19
|
+
|
20
|
+
import {Amount} from "../type/Amount.sol";
|
21
|
+
import {APPLIED, COLLATERALIZED, KEEP_STATE, CLOSED, DECLINED, PAID} from "../type/StateId.sol";
|
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";
|
25
|
+
import {ReferralId} from "../type/Referral.sol";
|
26
|
+
import {RiskId} from "../type/RiskId.sol";
|
27
|
+
import {Service} from "../shared/Service.sol";
|
28
|
+
import {StateId} from "../type/StateId.sol";
|
29
|
+
import {Timestamp, TimestampLib} from "../type/Timestamp.sol";
|
30
|
+
import {TokenHandler} from "../shared/TokenHandler.sol";
|
31
|
+
import {VersionPart} from "../type/Version.sol";
|
32
|
+
|
32
33
|
|
33
34
|
contract PolicyService is
|
34
|
-
|
35
|
+
Service,
|
35
36
|
IPolicyService
|
36
37
|
{
|
37
|
-
|
38
|
-
using TimestampLib for Timestamp;
|
39
|
-
|
40
|
-
IApplicationService internal _applicationService;
|
38
|
+
IAccountingService private _accountingService;
|
41
39
|
IComponentService internal _componentService;
|
42
|
-
IBundleService internal _bundleService;
|
43
|
-
IClaimService internal _claimService;
|
44
40
|
IDistributionService internal _distributionService;
|
45
41
|
IPoolService internal _poolService;
|
46
42
|
IPricingService internal _pricingService;
|
47
43
|
|
48
|
-
event LogProductServiceSender(address sender);
|
49
|
-
|
50
44
|
function _initialize(
|
51
45
|
address owner,
|
52
46
|
bytes memory data
|
@@ -56,57 +50,39 @@ 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));
|
74
65
|
|
75
|
-
|
66
|
+
_registerInterface(type(IPolicyService).interfaceId);
|
76
67
|
}
|
77
68
|
|
78
69
|
|
79
|
-
function _getAndVerifyInstanceAndProduct() internal view returns (Product product) {
|
80
|
-
IRegistry.ObjectInfo memory productInfo;
|
81
|
-
(, productInfo,) = _getAndVerifyActiveComponent(PRODUCT());
|
82
|
-
product = Product(productInfo.objectAddress);
|
83
|
-
}
|
84
|
-
|
85
|
-
|
86
70
|
function decline(
|
87
71
|
NftId applicationNftId // = policyNftId
|
88
72
|
)
|
89
73
|
external
|
90
|
-
virtual
|
74
|
+
virtual
|
75
|
+
nonReentrant()
|
91
76
|
{
|
92
|
-
|
93
|
-
|
77
|
+
// checks
|
78
|
+
(IInstance instance,,) = _getAndVerifyCallerForPolicy(applicationNftId);
|
94
79
|
|
95
80
|
// check policy is in state applied
|
96
|
-
if (
|
81
|
+
if (instance.getInstanceReader().getPolicyState(applicationNftId) != APPLIED()) {
|
97
82
|
revert ErrorPolicyServicePolicyStateNotApplied(applicationNftId);
|
98
83
|
}
|
99
84
|
|
100
|
-
//
|
101
|
-
IPolicy.PolicyInfo memory applicationInfo = instanceReader.getPolicyInfo(applicationNftId);
|
102
|
-
if(applicationInfo.productNftId != productNftId) {
|
103
|
-
revert ErrorPolicyServicePolicyProductMismatch(
|
104
|
-
applicationNftId,
|
105
|
-
applicationInfo.productNftId,
|
106
|
-
productNftId);
|
107
|
-
}
|
108
|
-
|
109
|
-
|
85
|
+
// effects
|
110
86
|
// store updated policy info
|
111
87
|
instance.getInstanceStore().updatePolicyState(
|
112
88
|
applicationNftId,
|
@@ -115,42 +91,33 @@ contract PolicyService is
|
|
115
91
|
emit LogPolicyServicePolicyDeclined(applicationNftId);
|
116
92
|
}
|
117
93
|
|
118
|
-
event LogDebug(uint idx, string message);
|
119
94
|
|
120
|
-
/// @
|
121
|
-
function
|
95
|
+
/// @inheritdoc IPolicyService
|
96
|
+
function createPolicy(
|
122
97
|
NftId applicationNftId, // = policyNftId
|
123
|
-
bool requirePremiumPayment,
|
124
98
|
Timestamp activateAt
|
125
99
|
)
|
126
100
|
external
|
127
|
-
virtual
|
101
|
+
virtual
|
102
|
+
nonReentrant()
|
103
|
+
returns (Amount premiumAmount)
|
128
104
|
{
|
129
|
-
//
|
130
|
-
(
|
131
|
-
|
105
|
+
// checks
|
106
|
+
(
|
107
|
+
IInstance instance,
|
108
|
+
NftId productNftId,
|
109
|
+
IPolicy.PolicyInfo memory applicationInfo
|
110
|
+
) = _getAndVerifyCallerForPolicy(applicationNftId);
|
132
111
|
|
133
112
|
// check policy is in state applied
|
113
|
+
InstanceReader instanceReader = instance.getInstanceReader();
|
134
114
|
if (instanceReader.getPolicyState(applicationNftId) != APPLIED()) {
|
135
115
|
revert ErrorPolicyServicePolicyStateNotApplied(applicationNftId);
|
136
116
|
}
|
137
117
|
|
138
|
-
//
|
139
|
-
IPolicy.PolicyInfo memory applicationInfo = instanceReader.getPolicyInfo(applicationNftId);
|
140
|
-
if(applicationInfo.productNftId != productNftId) {
|
141
|
-
revert ErrorPolicyServicePolicyProductMismatch(
|
142
|
-
applicationNftId,
|
143
|
-
applicationInfo.productNftId,
|
144
|
-
productNftId);
|
145
|
-
}
|
146
|
-
|
147
|
-
StateId newPolicyState = COLLATERALIZED();
|
148
|
-
|
118
|
+
// effects
|
149
119
|
// actual collateralizaion
|
150
|
-
(
|
151
|
-
Amount localCollateralAmount,
|
152
|
-
Amount totalCollateralAmount
|
153
|
-
) = _poolService.lockCollateral(
|
120
|
+
_poolService.lockCollateral(
|
154
121
|
instance,
|
155
122
|
address(instanceReader.getComponentInfo(productNftId).token),
|
156
123
|
productNftId,
|
@@ -159,336 +126,540 @@ contract PolicyService is
|
|
159
126
|
applicationInfo.sumInsuredAmount);
|
160
127
|
|
161
128
|
// optional activation of policy
|
162
|
-
if(activateAt >
|
163
|
-
|
164
|
-
applicationInfo.activatedAt = activateAt;
|
165
|
-
applicationInfo.expiredAt = activateAt.addSeconds(applicationInfo.lifetime);
|
166
|
-
}
|
167
|
-
|
168
|
-
// optional collection of premium
|
169
|
-
if(requirePremiumPayment) {
|
170
|
-
Amount premiumPaidAmount = _calculateAndCollectPremium(
|
171
|
-
instance,
|
172
|
-
applicationNftId,
|
173
|
-
applicationInfo);
|
174
|
-
|
175
|
-
applicationInfo.premiumPaidAmount = premiumPaidAmount;
|
129
|
+
if(activateAt > TimestampLib.zero()) {
|
130
|
+
applicationInfo = _activate(applicationNftId, applicationInfo, activateAt);
|
176
131
|
}
|
177
132
|
|
178
|
-
//
|
133
|
+
// update policy and set state to collateralized
|
179
134
|
instance.getInstanceStore().updatePolicy(
|
180
135
|
applicationNftId,
|
181
136
|
applicationInfo,
|
182
|
-
|
137
|
+
COLLATERALIZED());
|
183
138
|
|
184
|
-
//
|
139
|
+
// calculate and store premium
|
140
|
+
RiskId riskId = applicationInfo.riskId;
|
141
|
+
NftId bundleNftId = applicationInfo.bundleNftId;
|
142
|
+
|
143
|
+
IPolicy.PremiumInfo memory premium = _pricingService.calculatePremium(
|
144
|
+
productNftId,
|
145
|
+
riskId,
|
146
|
+
applicationInfo.sumInsuredAmount,
|
147
|
+
applicationInfo.lifetime,
|
148
|
+
applicationInfo.applicationData,
|
149
|
+
bundleNftId,
|
150
|
+
applicationInfo.referralId);
|
185
151
|
|
186
|
-
|
152
|
+
premiumAmount = premium.fullPremiumAmount;
|
153
|
+
instance.getInstanceStore().createPremium(
|
154
|
+
applicationNftId,
|
155
|
+
premium);
|
156
|
+
|
157
|
+
// update referral counter if product has linked distributino component
|
158
|
+
{
|
159
|
+
IComponents.ProductInfo memory productInfo = instanceReader.getProductInfo(productNftId);
|
160
|
+
if (productInfo.hasDistribution) {
|
161
|
+
_distributionService.processReferral(
|
162
|
+
productInfo.distributionNftId,
|
163
|
+
applicationInfo.referralId);
|
164
|
+
}
|
165
|
+
}
|
166
|
+
|
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);
|
174
|
+
|
175
|
+
// interactions
|
176
|
+
// callback to policy holder if applicable
|
177
|
+
_policyHolderPolicyActivated(applicationNftId, activateAt);
|
187
178
|
}
|
188
179
|
|
189
180
|
|
181
|
+
/// @inheritdoc IPolicyService
|
190
182
|
function collectPremium(
|
191
183
|
NftId policyNftId,
|
192
184
|
Timestamp activateAt
|
193
185
|
)
|
194
186
|
external
|
195
187
|
virtual
|
188
|
+
nonReentrant()
|
196
189
|
{
|
197
|
-
//
|
198
|
-
(
|
190
|
+
// checks
|
191
|
+
(
|
192
|
+
IInstance instance,
|
193
|
+
NftId productNftId,
|
194
|
+
IPolicy.PolicyInfo memory policyInfo
|
195
|
+
) = _getAndVerifyCallerForPolicy(policyNftId);
|
196
|
+
|
197
|
+
// check policy is in state collateralized
|
199
198
|
InstanceReader instanceReader = instance.getInstanceReader();
|
200
|
-
|
199
|
+
if (instanceReader.getPolicyState(policyNftId) != COLLATERALIZED()) {
|
200
|
+
revert ErrorPolicyServicePolicyStateNotCollateralized(policyNftId);
|
201
|
+
}
|
201
202
|
|
202
|
-
// check
|
203
|
-
if (
|
204
|
-
revert
|
203
|
+
// check if premium has already been collected
|
204
|
+
if (instanceReader.getPremiumInfoState(policyNftId) == PAID()) {
|
205
|
+
revert ErrorPolicyServicePremiumAlreadyPaid(policyNftId);
|
205
206
|
}
|
206
207
|
|
207
|
-
|
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);
|
208
216
|
|
209
|
-
//
|
210
|
-
|
211
|
-
|
212
|
-
|
217
|
+
// effects
|
218
|
+
_processSale(
|
219
|
+
instanceReader,
|
220
|
+
instance.getInstanceStore(),
|
221
|
+
productNftId,
|
222
|
+
policyInfo.bundleNftId,
|
223
|
+
policyInfo.referralId,
|
224
|
+
premium);
|
213
225
|
|
214
|
-
|
215
|
-
|
216
|
-
|
217
|
-
|
226
|
+
// optionally activate policy
|
227
|
+
if(activateAt.gtz()) {
|
228
|
+
policyInfo = _activate(policyNftId, policyInfo, activateAt);
|
229
|
+
}
|
218
230
|
|
219
231
|
instance.getInstanceStore().updatePolicy(policyNftId, policyInfo, KEEP_STATE());
|
232
|
+
instance.getInstanceStore().updatePremiumState(policyNftId, PAID());
|
220
233
|
|
221
|
-
|
222
|
-
|
223
|
-
}
|
234
|
+
// log premium collection before interactions with token
|
235
|
+
emit LogPolicyServicePolicyPremiumCollected(policyNftId, premium.premiumAmount);
|
224
236
|
|
225
|
-
//
|
237
|
+
// interactions
|
238
|
+
_transferFunds(instanceReader, policyNftId, policyInfo.productNftId, premium);
|
226
239
|
}
|
227
240
|
|
228
|
-
function activate(NftId policyNftId, Timestamp activateAt) public override {
|
229
|
-
// check caller is registered product
|
230
|
-
(,, IInstance instance) = _getAndVerifyActiveComponent(PRODUCT());
|
231
|
-
InstanceReader instanceReader = instance.getInstanceReader();
|
232
241
|
|
233
|
-
|
234
|
-
|
235
|
-
|
236
|
-
|
237
|
-
|
242
|
+
/// @inheritdoc IPolicyService
|
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);
|
238
253
|
|
239
|
-
|
240
|
-
policyInfo
|
254
|
+
// effects
|
255
|
+
policyInfo = _activate(policyNftId, policyInfo, activateAt);
|
256
|
+
instance.getInstanceStore().updatePolicy(policyNftId, policyInfo, KEEP_STATE());
|
241
257
|
|
242
|
-
|
258
|
+
// log policy activation before interactions with policy holder
|
259
|
+
emit LogPolicyServicePolicyActivated(policyNftId, activateAt);
|
243
260
|
|
244
|
-
//
|
261
|
+
// interactions
|
262
|
+
// callback to policy holder if applicable
|
263
|
+
_policyHolderPolicyActivated(policyNftId, activateAt);
|
245
264
|
}
|
246
265
|
|
266
|
+
|
247
267
|
/// @inheritdoc IPolicyService
|
248
268
|
function expire(
|
249
269
|
NftId policyNftId,
|
250
270
|
Timestamp expireAt
|
251
271
|
)
|
252
272
|
external
|
253
|
-
override
|
254
273
|
virtual
|
255
|
-
|
274
|
+
nonReentrant()
|
275
|
+
returns (Timestamp expiredAt)
|
256
276
|
{
|
257
|
-
|
258
|
-
|
259
|
-
|
260
|
-
|
261
|
-
|
262
|
-
revert ErrorIPolicyServicePolicyNotActive(policyNftId, instanceReader.getPolicyState(policyNftId));
|
263
|
-
}
|
264
|
-
|
265
|
-
// check policy matches with calling product
|
266
|
-
IPolicy.PolicyInfo memory policyInfo = instanceReader.getPolicyInfo(policyNftId);
|
267
|
-
if(policyInfo.productNftId != productNftId) {
|
268
|
-
revert ErrorPolicyServicePolicyProductMismatch(
|
269
|
-
policyNftId,
|
270
|
-
policyInfo.productNftId,
|
271
|
-
productNftId);
|
272
|
-
}
|
273
|
-
|
274
|
-
if (expireAt.eqz()) {
|
275
|
-
expireAt = TimestampLib.blockTimestamp();
|
276
|
-
}
|
277
|
+
// checks
|
278
|
+
(
|
279
|
+
IInstance instance,,
|
280
|
+
IPolicy.PolicyInfo memory policyInfo
|
281
|
+
) = _getAndVerifyCallerForPolicy(policyNftId);
|
277
282
|
|
278
|
-
//
|
279
|
-
|
280
|
-
|
281
|
-
|
282
|
-
|
283
|
-
|
284
|
-
|
285
|
-
|
286
|
-
revert ErrorIPolicyServiceOpenClaims(policyNftId, policyInfo.openClaimsCount);
|
287
|
-
}
|
283
|
+
// more checks, effects + interactions
|
284
|
+
return _expire(
|
285
|
+
instance,
|
286
|
+
policyNftId,
|
287
|
+
policyInfo,
|
288
|
+
expireAt
|
289
|
+
);
|
290
|
+
}
|
288
291
|
|
289
|
-
policyInfo.expiredAt = expireAt;
|
290
|
-
instance.getInstanceStore().updatePolicy(policyNftId, policyInfo, KEEP_STATE());
|
291
292
|
|
292
|
-
|
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);
|
293
308
|
|
294
|
-
|
309
|
+
// more checks, effects + interactions
|
310
|
+
return _expire(
|
311
|
+
instance,
|
312
|
+
policyNftId,
|
313
|
+
policyInfo,
|
314
|
+
expireAt
|
315
|
+
);
|
295
316
|
}
|
296
317
|
|
318
|
+
|
319
|
+
/// @inheritdoc IPolicyService
|
297
320
|
function close(
|
298
321
|
NftId policyNftId
|
299
322
|
)
|
300
323
|
external
|
301
|
-
|
324
|
+
virtual
|
325
|
+
nonReentrant()
|
302
326
|
{
|
303
|
-
|
327
|
+
// checks
|
328
|
+
(
|
329
|
+
IInstance instance,
|
330
|
+
NftId productNftId,
|
331
|
+
IPolicy.PolicyInfo memory policyInfo
|
332
|
+
) = _getAndVerifyCallerForPolicy(policyNftId);
|
304
333
|
InstanceReader instanceReader = instance.getInstanceReader();
|
305
334
|
|
306
|
-
|
307
|
-
|
308
|
-
|
309
|
-
revert ErrorIPolicyServicePolicyNotActivated(policyNftId);
|
335
|
+
// check policy is in a closeable state
|
336
|
+
if (!policyIsCloseable(instanceReader, policyNftId)) {
|
337
|
+
revert ErrorPolicyServicePolicyNotCloseable(policyNftId);
|
310
338
|
}
|
311
339
|
|
312
|
-
|
313
|
-
|
314
|
-
|
315
|
-
}
|
316
|
-
|
317
|
-
if (policyInfo.closedAt.gtz()) {
|
318
|
-
revert ErrorIPolicyServicePolicyAlreadyClosed(policyNftId);
|
319
|
-
}
|
320
|
-
|
321
|
-
// TODO consider to allow for underpaid premiums (with the effects of reducing max payouts accordingly)
|
322
|
-
if (!(policyInfo.premiumAmount == policyInfo.premiumPaidAmount)) {
|
323
|
-
revert ErrorPolicyServicePremiumNotFullyPaid(policyNftId, policyInfo.premiumAmount, policyInfo.premiumPaidAmount);
|
324
|
-
}
|
340
|
+
// check that policy has been activated
|
341
|
+
RiskId riskId = policyInfo.riskId;
|
342
|
+
NftId bundleNftId = policyInfo.bundleNftId;
|
325
343
|
|
326
|
-
if (
|
327
|
-
revert
|
344
|
+
if (instanceReader.getPremiumInfoState(policyNftId) != PAID()) {
|
345
|
+
revert ErrorPolicyServicePremiumNotPaid(policyNftId, policyInfo.premiumAmount);
|
328
346
|
}
|
329
347
|
|
330
|
-
|
331
|
-
|
348
|
+
// effects
|
349
|
+
// release (remaining) collateral that was blocked by policy
|
332
350
|
_poolService.releaseCollateral(
|
333
351
|
instance,
|
334
|
-
address(instanceReader.getComponentInfo(
|
352
|
+
address(instanceReader.getComponentInfo(productNftId).token),
|
335
353
|
policyNftId,
|
336
354
|
policyInfo);
|
337
355
|
|
356
|
+
// TODO consider to also set expiredAt to current block timestamp if that timestamp is still in the futue
|
357
|
+
|
358
|
+
// update policy state to closed
|
359
|
+
policyInfo.closedAt = TimestampLib.blockTimestamp();
|
338
360
|
instance.getInstanceStore().updatePolicy(policyNftId, policyInfo, CLOSED());
|
361
|
+
|
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);
|
339
368
|
}
|
340
369
|
|
341
370
|
|
342
|
-
function
|
343
|
-
|
344
|
-
|
345
|
-
|
346
|
-
)
|
347
|
-
internal
|
348
|
-
virtual
|
349
|
-
returns (
|
350
|
-
Amount premiumPaidAmount
|
351
|
-
)
|
371
|
+
function policyIsCloseable(InstanceReader instanceReader, NftId policyNftId)
|
372
|
+
public
|
373
|
+
view
|
374
|
+
returns (bool isCloseable)
|
352
375
|
{
|
353
|
-
|
376
|
+
// policy already closed
|
377
|
+
if (instanceReader.getPolicyState(policyNftId) == CLOSED()) {
|
378
|
+
return false;
|
379
|
+
}
|
354
380
|
|
355
|
-
|
356
|
-
|
357
|
-
|
358
|
-
|
359
|
-
|
360
|
-
applicationInfo.lifetime,
|
361
|
-
applicationInfo.applicationData,
|
362
|
-
applicationInfo.bundleNftId,
|
363
|
-
applicationInfo.referralId);
|
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
|
364
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; }
|
365
389
|
|
366
|
-
//
|
367
|
-
|
368
|
-
instance,
|
369
|
-
productNftId,
|
370
|
-
applicationNftId,
|
371
|
-
applicationInfo.premiumAmount,
|
372
|
-
applicationInfo.bundleNftId,
|
373
|
-
applicationInfo.referralId,
|
374
|
-
premium);
|
375
|
-
}
|
390
|
+
// not closeable: not yet expired
|
391
|
+
if (TimestampLib.blockTimestamp() < info.expiredAt) { return false; }
|
376
392
|
|
393
|
+
// all conditions to close the policy are met
|
394
|
+
return true;
|
395
|
+
}
|
377
396
|
|
378
|
-
|
397
|
+
/// @dev shared functionality for expire() and policyExpire().
|
398
|
+
function _expire(
|
379
399
|
IInstance instance,
|
380
|
-
NftId productNftId,
|
381
400
|
NftId policyNftId,
|
382
|
-
|
383
|
-
|
384
|
-
ReferralId referralId,
|
385
|
-
IPolicy.Premium memory premium
|
401
|
+
IPolicy.PolicyInfo memory policyInfo,
|
402
|
+
Timestamp expireAt
|
386
403
|
)
|
387
404
|
internal
|
388
|
-
|
389
|
-
returns (Amount premiumPaidAmount)
|
405
|
+
returns (Timestamp expiredAt)
|
390
406
|
{
|
391
|
-
|
392
|
-
|
393
|
-
|
394
|
-
|
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
|
+
}
|
395
413
|
|
396
|
-
|
397
|
-
|
398
|
-
policyHolder,
|
399
|
-
premiumExpectedAmount,
|
400
|
-
premiumPaidAmount);
|
414
|
+
// set return value to provided timestamp
|
415
|
+
expiredAt = expireAt;
|
401
416
|
|
402
|
-
|
403
|
-
|
404
|
-
|
405
|
-
|
406
|
-
policyHolder,
|
407
|
-
productNftId,
|
408
|
-
bundleNftId,
|
409
|
-
referralId,
|
410
|
-
premium);
|
411
|
-
}
|
417
|
+
// update expiredAt to current block timestamp if not set
|
418
|
+
if (expiredAt.eqz()) {
|
419
|
+
expiredAt = TimestampLib.blockTimestamp();
|
420
|
+
}
|
412
421
|
|
422
|
+
// check expiredAt represents a valid expiry time
|
423
|
+
if (expiredAt >= policyInfo.expiredAt) {
|
424
|
+
revert ErrorPolicyServicePolicyExpirationTooLate(policyNftId, policyInfo.expiredAt, expireAt);
|
425
|
+
}
|
413
426
|
|
414
|
-
|
415
|
-
|
416
|
-
|
417
|
-
|
418
|
-
|
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);
|
442
|
+
}
|
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
|
+
|
467
|
+
function _activate(
|
468
|
+
NftId policyNftId,
|
469
|
+
IPolicy.PolicyInfo memory policyInfo,
|
470
|
+
Timestamp activateAt
|
419
471
|
)
|
420
472
|
internal
|
421
473
|
virtual
|
422
|
-
view
|
474
|
+
view
|
475
|
+
returns (IPolicy.PolicyInfo memory)
|
423
476
|
{
|
424
|
-
//
|
425
|
-
|
426
|
-
|
427
|
-
revert ErrorPolicyServicePremiumHigherThanExpected(premiumExpectedAmount, premiumPaidAmount);
|
477
|
+
// fail if policy has already been activated and activateAt is different
|
478
|
+
if(! policyInfo.activatedAt.eqz() && activateAt != policyInfo.activatedAt) {
|
479
|
+
revert ErrorPolicyServicePolicyAlreadyActivated(policyNftId);
|
428
480
|
}
|
429
481
|
|
430
|
-
|
431
|
-
|
432
|
-
|
433
|
-
|
434
|
-
if (balance < premiumAmount) {
|
435
|
-
revert ErrorPolicyServiceBalanceInsufficient(policyHolder, premiumAmount, balance);
|
482
|
+
// ignore if policy has already been activated and activateAt is the same
|
483
|
+
if (policyInfo.activatedAt == activateAt) {
|
484
|
+
return policyInfo;
|
436
485
|
}
|
437
486
|
|
438
|
-
|
439
|
-
|
440
|
-
}
|
441
|
-
}
|
487
|
+
policyInfo.activatedAt = activateAt;
|
488
|
+
policyInfo.expiredAt = activateAt.addSeconds(policyInfo.lifetime);
|
442
489
|
|
490
|
+
return policyInfo;
|
491
|
+
}
|
443
492
|
|
444
|
-
|
493
|
+
/// @dev update counters by calling the involved services
|
494
|
+
function _processSale(
|
445
495
|
InstanceReader instanceReader,
|
446
496
|
InstanceStore instanceStore,
|
447
|
-
TokenHandler tokenHandler,
|
448
|
-
address policyHolder,
|
449
497
|
NftId productNftId,
|
450
498
|
NftId bundleNftId,
|
451
499
|
ReferralId referralId,
|
452
|
-
IPolicy.
|
500
|
+
IPolicy.PremiumInfo memory premium
|
453
501
|
)
|
454
502
|
internal
|
455
503
|
virtual
|
456
504
|
{
|
457
|
-
(
|
458
|
-
NftId distributionNftId,
|
459
|
-
address distributionWallet,
|
460
|
-
address poolWallet,
|
461
|
-
address productWallet
|
462
|
-
) = _getDistributionNftAndWallets(
|
505
|
+
(NftId distributionNftId,,,) = _getDistributionNftAndWallets(
|
463
506
|
instanceReader,
|
464
507
|
productNftId);
|
465
508
|
|
466
509
|
// update product fees, distribution and pool fees
|
467
|
-
|
510
|
+
_accountingService.increaseProductFees(
|
468
511
|
instanceStore,
|
469
512
|
productNftId,
|
470
|
-
|
513
|
+
premium.productFeeVarAmount + premium.productFeeFixAmount);
|
471
514
|
|
472
515
|
// update distribution fees and distributor commission and pool fees
|
473
|
-
|
474
|
-
|
475
|
-
|
476
|
-
|
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
|
+
}
|
477
522
|
|
478
523
|
// update pool and bundle fees
|
479
524
|
_poolService.processSale(
|
480
525
|
bundleNftId,
|
481
526
|
premium);
|
527
|
+
}
|
528
|
+
|
529
|
+
|
530
|
+
/// @dev transfer the premium to the wallets the premium is distributed to
|
531
|
+
function _transferFunds(
|
532
|
+
InstanceReader instanceReader,
|
533
|
+
NftId policyNftId,
|
534
|
+
NftId productNftId,
|
535
|
+
IPolicy.PremiumInfo memory premium
|
536
|
+
)
|
537
|
+
internal
|
538
|
+
virtual
|
539
|
+
{
|
540
|
+
TokenHandler tokenHandler = _getTokenHandler(instanceReader, productNftId);
|
541
|
+
address policyHolder = getRegistry().ownerOf(policyNftId);
|
542
|
+
|
543
|
+
(
|
544
|
+
,
|
545
|
+
address distributionWallet,
|
546
|
+
address poolWallet,
|
547
|
+
address productWallet
|
548
|
+
) = _getDistributionNftAndWallets(
|
549
|
+
instanceReader,
|
550
|
+
productNftId);
|
482
551
|
|
483
|
-
|
484
|
-
|
485
|
-
|
486
|
-
|
487
|
-
|
552
|
+
tokenHandler.collectTokensToThreeRecipients(
|
553
|
+
policyHolder,
|
554
|
+
productWallet,
|
555
|
+
premium.productFeeAmount,
|
556
|
+
distributionWallet,
|
557
|
+
premium.distributionFeeAndCommissionAmount,
|
558
|
+
poolWallet,
|
559
|
+
premium.poolPremiumAndFeeAmount);
|
488
560
|
}
|
489
561
|
|
490
562
|
|
491
|
-
|
563
|
+
/// @dev checks that policy has been collateralized and has been activated.
|
564
|
+
/// does not check if policy has been expired or closed.
|
565
|
+
function _policyHasBeenActivated(
|
566
|
+
StateId policyState,
|
567
|
+
IPolicy.PolicyInfo memory policyInfo
|
568
|
+
)
|
569
|
+
internal
|
570
|
+
view
|
571
|
+
returns (bool)
|
572
|
+
{
|
573
|
+
if (policyState != COLLATERALIZED()) { return false; }
|
574
|
+
if (TimestampLib.blockTimestamp() < policyInfo.activatedAt) { return false; }
|
575
|
+
return true;
|
576
|
+
}
|
577
|
+
|
578
|
+
|
579
|
+
/// @dev checks the balance and allowance of the policy holder
|
580
|
+
function _checkPremiumBalanceAndAllowance(
|
581
|
+
IERC20Metadata token,
|
582
|
+
address tokenHandlerAddress,
|
583
|
+
address policyHolder,
|
584
|
+
Amount premiumAmount
|
585
|
+
)
|
586
|
+
internal
|
587
|
+
virtual
|
588
|
+
view
|
589
|
+
{
|
590
|
+
uint256 premium = premiumAmount.toInt();
|
591
|
+
uint256 balance = token.balanceOf(policyHolder);
|
592
|
+
uint256 allowance = token.allowance(policyHolder, tokenHandlerAddress);
|
593
|
+
|
594
|
+
if (balance < premium) {
|
595
|
+
revert ErrorPolicyServiceBalanceInsufficient(policyHolder, premium, balance);
|
596
|
+
}
|
597
|
+
|
598
|
+
if (allowance < premium) {
|
599
|
+
revert ErrorPolicyServiceAllowanceInsufficient(policyHolder, tokenHandlerAddress, premium, allowance);
|
600
|
+
}
|
601
|
+
}
|
602
|
+
|
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
|
+
|
662
|
+
function _getTokenHandler(
|
492
663
|
InstanceReader instanceReader,
|
493
664
|
NftId productNftId
|
494
665
|
)
|
@@ -502,6 +673,7 @@ contract PolicyService is
|
|
502
673
|
tokenHandler = instanceReader.getComponentInfo(productNftId).tokenHandler;
|
503
674
|
}
|
504
675
|
|
676
|
+
|
505
677
|
function _getDistributionNftAndWallets(
|
506
678
|
InstanceReader instanceReader,
|
507
679
|
NftId productNftId
|
@@ -516,10 +688,45 @@ contract PolicyService is
|
|
516
688
|
)
|
517
689
|
{
|
518
690
|
IComponents.ProductInfo memory productInfo = instanceReader.getProductInfo(productNftId);
|
519
|
-
|
520
|
-
|
521
|
-
|
522
|
-
|
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
|
+
}
|
698
|
+
}
|
699
|
+
|
700
|
+
|
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
|
+
}
|
523
730
|
}
|
524
731
|
|
525
732
|
|