@etherisc/gif-next 0.0.2-b9366f5-670 → 0.0.2-b98b2b0-875
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 +1 -1
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +33 -52
- 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 +2 -2
- 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 +0 -19
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IModuleAuthorization.sol/IModuleAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.json +2 -2
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +2 -2
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +51 -177
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +16 -16
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +21 -147
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +85 -192
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +84 -104
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +21 -0
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- 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 +1512 -0
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +410 -0
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +1999 -0
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +414 -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 +1432 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +1192 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +1566 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +2001 -0
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +2 -2
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +10 -99
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +95 -98
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +2 -2
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +260 -67
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +39 -146
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +61 -81
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +71 -51
- 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 +2 -2
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.json +2 -2
- package/artifacts/contracts/instance/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 +41 -167
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +18 -18
- 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 +21 -0
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +21 -147
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +37 -144
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +60 -80
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +46 -144
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +16 -16
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +138 -181
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +102 -102
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +24 -0
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +49 -0
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +171 -102
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +46 -144
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +276 -245
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +95 -83
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +31 -138
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +57 -77
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +46 -170
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +16 -16
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +154 -194
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +101 -101
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +35 -8
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +111 -0
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +49 -26
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +212 -160
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +92 -88
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +55 -162
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +68 -88
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +46 -170
- package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +1 -1
- package/artifacts/contracts/product/RiskService.sol/RiskService.json +25 -132
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +54 -74
- 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 +239 -20
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +437 -81
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +244 -132
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +23 -313
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +52 -72
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +2 -2
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +24 -14
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +6 -6
- 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 +21 -147
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +75 -182
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +89 -99
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +5 -112
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +92 -0
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +21 -0
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +21 -0
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/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/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- 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 +21 -147
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.dbg.json +1 -1
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.json +2 -2
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +6 -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 +8 -97
- 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 +5 -112
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +2 -2
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +2 -2
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +21 -0
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +2 -2
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +65 -191
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.json +2 -2
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +70 -85
- 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 +31 -138
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +56 -76
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +2 -2
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +2 -2
- 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 +32 -8
- 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 +2 -2
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/type/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +2 -2
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +2 -2
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +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 +60 -4
- 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/String.sol/StrLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/MathLib.json +2 -2
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +15 -2
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +39 -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/authorization/AccessAdmin.sol +25 -24
- package/contracts/authorization/Authorization.sol +5 -1
- package/contracts/authorization/IAccessAdmin.sol +0 -1
- package/contracts/distribution/Distribution.sol +1 -1
- package/contracts/distribution/DistributionService.sol +9 -9
- package/contracts/distribution/DistributionServiceManager.sol +6 -6
- package/contracts/examples/fire/DamageLevel.sol +59 -0
- package/contracts/examples/fire/FirePool.sol +75 -0
- package/contracts/examples/fire/FirePoolAuthorization.sol +34 -0
- package/contracts/examples/fire/FireProduct.sol +413 -0
- package/contracts/examples/fire/FireProductAuthorization.sol +45 -0
- package/contracts/examples/fire/FireUSD.sol +26 -0
- package/contracts/instance/Instance.sol +2 -2
- package/contracts/instance/InstanceAdmin.sol +6 -3
- package/contracts/instance/InstanceReader.sol +83 -18
- package/contracts/instance/InstanceService.sol +6 -8
- package/contracts/instance/InstanceServiceManager.sol +6 -7
- package/contracts/instance/module/IComponents.sol +3 -1
- package/contracts/instance/module/IPolicy.sol +2 -2
- package/contracts/oracle/Oracle.sol +1 -1
- package/contracts/oracle/OracleService.sol +10 -8
- package/contracts/oracle/OracleServiceManager.sol +6 -6
- package/contracts/pool/BundleService.sol +32 -9
- package/contracts/pool/BundleServiceManager.sol +6 -6
- package/contracts/pool/IBundleService.sol +9 -0
- package/contracts/pool/IPoolComponent.sol +18 -8
- package/contracts/pool/IPoolService.sol +21 -10
- package/contracts/pool/Pool.sol +38 -11
- package/contracts/pool/PoolService.sol +81 -27
- package/contracts/pool/PoolServiceManager.sol +4 -4
- package/contracts/product/ApplicationService.sol +11 -8
- package/contracts/product/ApplicationServiceManager.sol +4 -4
- package/contracts/product/ClaimService.sol +164 -70
- package/contracts/product/ClaimServiceManager.sol +4 -4
- package/contracts/product/IClaimService.sol +3 -2
- package/contracts/product/IPolicyService.sol +10 -3
- package/contracts/product/IProductComponent.sol +17 -3
- package/contracts/product/PolicyService.sol +145 -32
- package/contracts/product/PolicyServiceManager.sol +4 -4
- package/contracts/product/PricingService.sol +4 -5
- package/contracts/product/PricingServiceManager.sol +3 -3
- package/contracts/product/Product.sol +26 -19
- package/contracts/product/RiskService.sol +4 -5
- package/contracts/product/RiskServiceManager.sol +4 -4
- package/contracts/registry/ChainNft.sol +65 -32
- package/contracts/registry/IRegistry.sol +50 -14
- package/contracts/registry/IRegistryService.sol +0 -9
- package/contracts/registry/Registry.sol +327 -196
- package/contracts/registry/RegistryAdmin.sol +140 -50
- package/contracts/registry/RegistryService.sol +55 -48
- package/contracts/registry/RegistryServiceManager.sol +2 -2
- package/contracts/registry/ReleaseRegistry.sol +11 -5
- package/contracts/registry/ServiceAuthorizationV3.sol +4 -5
- package/contracts/shared/Component.sol +13 -5
- package/contracts/shared/ComponentService.sol +6 -6
- package/contracts/shared/ComponentServiceManager.sol +8 -5
- package/contracts/shared/ComponentVerifyingService.sol +1 -2
- package/contracts/shared/ContractLib.sol +38 -0
- package/contracts/shared/IComponent.sol +3 -0
- package/contracts/shared/IPolicyHolder.sol +12 -22
- package/contracts/shared/InitializableERC165.sol +2 -2
- package/contracts/shared/InstanceLinkedComponent.sol +4 -5
- package/contracts/shared/NftOwnable.sol +4 -4
- package/contracts/shared/PolicyHolder.sol +15 -52
- package/contracts/shared/Registerable.sol +4 -4
- package/contracts/shared/RegistryLinked.sol +3 -2
- package/contracts/shared/Service.sol +16 -11
- package/contracts/staking/Staking.sol +3 -3
- package/contracts/staking/StakingManager.sol +8 -6
- package/contracts/staking/StakingReader.sol +12 -5
- package/contracts/staking/StakingService.sol +2 -2
- package/contracts/staking/StakingServiceManager.sol +2 -2
- package/contracts/type/Amount.sol +15 -0
- package/contracts/type/ClaimId.sol +6 -1
- package/contracts/type/NftId.sol +1 -0
- package/contracts/type/ObjectType.sol +1 -0
- package/contracts/type/PayoutId.sol +10 -10
- package/contracts/type/RiskId.sol +15 -1
- package/contracts/type/UFixed.sol +4 -0
- package/contracts/upgradeability/ProxyManager.sol +67 -34
- package/contracts/upgradeability/Versionable.sol +2 -2
- package/package.json +1 -1
- package/artifacts/contracts/example_components/unpermissioned/SimpleDistribution.sol/SimpleDistribution.dbg.json +0 -4
- package/artifacts/contracts/example_components/unpermissioned/SimpleDistribution.sol/SimpleDistribution.json +0 -1558
- package/artifacts/contracts/example_components/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +0 -4
- package/artifacts/contracts/example_components/unpermissioned/SimpleOracle.sol/SimpleOracle.json +0 -1318
- package/artifacts/contracts/example_components/unpermissioned/SimplePool.sol/SimplePool.dbg.json +0 -4
- package/artifacts/contracts/example_components/unpermissioned/SimplePool.sol/SimplePool.json +0 -1664
- package/artifacts/contracts/example_components/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +0 -4
- package/artifacts/contracts/example_components/unpermissioned/SimpleProduct.sol/SimpleProduct.json +0 -2125
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.dbg.json +0 -4
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.json +0 -39
- package/contracts/shared/InitializableCustom.sol +0 -177
- /package/contracts/{example_components → examples}/unpermissioned/SimpleDistribution.sol +0 -0
- /package/contracts/{example_components → examples}/unpermissioned/SimpleOracle.sol +0 -0
- /package/contracts/{example_components → examples}/unpermissioned/SimplePool.sol +0 -0
- /package/contracts/{example_components → examples}/unpermissioned/SimpleProduct.sol +0 -0
@@ -1,12 +1,9 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
-
import {IComponents} from "../instance/module/IComponents.sol";
|
5
|
-
import {IInstance} from "../instance/IInstance.sol";
|
6
|
-
import {IPolicy} from "../instance/module/IPolicy.sol";
|
7
4
|
import {Amount, AmountLib} from "../type/Amount.sol";
|
8
5
|
import {TimestampLib} from "../type/Timestamp.sol";
|
9
|
-
import {ObjectType, CLAIM,
|
6
|
+
import {ObjectType, CLAIM, POLICY, POOL, PRODUCT} from "../type/ObjectType.sol";
|
10
7
|
import {SUBMITTED, KEEP_STATE, DECLINED, REVOKED, CONFIRMED, CLOSED, PAID} from "../type/StateId.sol";
|
11
8
|
import {NftId} from "../type/NftId.sol";
|
12
9
|
import {FeeLib} from "../type/Fee.sol";
|
@@ -14,8 +11,15 @@ import {StateId} from "../type/StateId.sol";
|
|
14
11
|
import {ClaimId, ClaimIdLib} from "../type/ClaimId.sol";
|
15
12
|
import {PayoutId, PayoutIdLib} from "../type/PayoutId.sol";
|
16
13
|
import {ComponentVerifyingService} from "../shared/ComponentVerifyingService.sol";
|
14
|
+
import {ContractLib} from "../shared/ContractLib.sol";
|
17
15
|
import {InstanceReader} from "../instance/InstanceReader.sol";
|
18
16
|
import {IClaimService} from "./IClaimService.sol";
|
17
|
+
import {IComponents} from "../instance/module/IComponents.sol";
|
18
|
+
import {IInstance} from "../instance/IInstance.sol";
|
19
|
+
import {IPolicy} from "../instance/module/IPolicy.sol";
|
20
|
+
import {IPolicyHolder} from "../shared/IPolicyHolder.sol";
|
21
|
+
import {IPoolComponent} from "../pool/IPoolComponent.sol";
|
22
|
+
import {IPolicyService} from "../product/IPolicyService.sol";
|
19
23
|
import {IPoolService} from "../pool/IPoolService.sol";
|
20
24
|
|
21
25
|
|
@@ -24,6 +28,7 @@ contract ClaimService is
|
|
24
28
|
IClaimService
|
25
29
|
{
|
26
30
|
|
31
|
+
IPolicyService internal _policyService;
|
27
32
|
IPoolService internal _poolService;
|
28
33
|
|
29
34
|
function _initialize(
|
@@ -35,16 +40,16 @@ contract ClaimService is
|
|
35
40
|
initializer()
|
36
41
|
{
|
37
42
|
(
|
38
|
-
address registryAddress
|
39
|
-
//address managerAddress
|
43
|
+
address registryAddress,
|
40
44
|
address authority
|
41
|
-
) = abi.decode(data, (address, address
|
45
|
+
) = abi.decode(data, (address, address));
|
42
46
|
|
43
|
-
|
47
|
+
_initializeService(registryAddress, authority, owner);
|
44
48
|
|
49
|
+
_policyService = IPolicyService(getRegistry().getServiceAddress(POLICY(), getVersion().toMajorPart()));
|
45
50
|
_poolService = IPoolService(getRegistry().getServiceAddress(POOL(), getVersion().toMajorPart()));
|
46
51
|
|
47
|
-
|
52
|
+
_registerInterface(type(IClaimService).interfaceId);
|
48
53
|
}
|
49
54
|
|
50
55
|
function submit(
|
@@ -54,9 +59,11 @@ contract ClaimService is
|
|
54
59
|
)
|
55
60
|
external
|
56
61
|
virtual
|
62
|
+
// nonReentrant() // prevents creating a reinsurance claim in a single tx
|
57
63
|
returns (ClaimId claimId)
|
58
64
|
{
|
59
65
|
(
|
66
|
+
,
|
60
67
|
IInstance instance,
|
61
68
|
InstanceReader instanceReader,
|
62
69
|
IPolicy.PolicyInfo memory policyInfo
|
@@ -108,8 +115,10 @@ contract ClaimService is
|
|
108
115
|
)
|
109
116
|
external
|
110
117
|
virtual
|
118
|
+
// nonReentrant() // prevents creating a reinsurance claim in a single tx
|
111
119
|
{
|
112
120
|
(
|
121
|
+
NftId productNftId,
|
113
122
|
IInstance instance,
|
114
123
|
InstanceReader instanceReader,
|
115
124
|
IPolicy.PolicyInfo memory policyInfo
|
@@ -123,16 +132,25 @@ contract ClaimService is
|
|
123
132
|
claimInfo.processData = data;
|
124
133
|
instance.getInstanceStore().updateClaim(policyNftId, claimId, claimInfo, CONFIRMED());
|
125
134
|
|
126
|
-
// TODO test if claim results in total claim amount == sum insured amount
|
127
|
-
// should policy still be active it needs to automatically become expired
|
128
|
-
|
129
135
|
// update and save policy info with instance
|
130
136
|
policyInfo.claimAmount = policyInfo.claimAmount + confirmedAmount;
|
131
137
|
instance.getInstanceStore().updatePolicyClaims(policyNftId, policyInfo, KEEP_STATE());
|
132
138
|
|
139
|
+
// should policy still be active it needs to become expired
|
140
|
+
if (policyInfo.claimAmount >= policyInfo.sumInsuredAmount) {
|
141
|
+
_policyService.expirePolicy(instance, policyNftId, TimestampLib.blockTimestamp());
|
142
|
+
}
|
143
|
+
|
133
144
|
emit LogClaimServiceClaimConfirmed(policyNftId, claimId, confirmedAmount);
|
145
|
+
|
146
|
+
// callback to pool if applicable
|
147
|
+
_processConfirmedClaimByPool(instanceReader, productNftId, policyNftId, claimId, confirmedAmount);
|
148
|
+
|
149
|
+
// callback to policy holder if applicable
|
150
|
+
_policyHolderClaimConfirmed(policyNftId, claimId, confirmedAmount);
|
134
151
|
}
|
135
152
|
|
153
|
+
|
136
154
|
function decline(
|
137
155
|
NftId policyNftId,
|
138
156
|
ClaimId claimId,
|
@@ -140,8 +158,10 @@ contract ClaimService is
|
|
140
158
|
)
|
141
159
|
external
|
142
160
|
virtual
|
161
|
+
// nonReentrant() // prevents creating a reinsurance claim in a single tx
|
143
162
|
{
|
144
163
|
(
|
164
|
+
,
|
145
165
|
IInstance instance,
|
146
166
|
InstanceReader instanceReader,
|
147
167
|
IPolicy.PolicyInfo memory policyInfo
|
@@ -168,8 +188,10 @@ contract ClaimService is
|
|
168
188
|
)
|
169
189
|
external
|
170
190
|
virtual
|
191
|
+
// nonReentrant() // prevents creating a reinsurance claim in a single tx
|
171
192
|
{
|
172
193
|
(
|
194
|
+
,
|
173
195
|
IInstance instance,
|
174
196
|
InstanceReader instanceReader,
|
175
197
|
IPolicy.PolicyInfo memory policyInfo
|
@@ -194,8 +216,10 @@ contract ClaimService is
|
|
194
216
|
)
|
195
217
|
external
|
196
218
|
virtual
|
219
|
+
// nonReentrant() // prevents creating a reinsurance claim in a single tx
|
197
220
|
{
|
198
221
|
(
|
222
|
+
,
|
199
223
|
IInstance instance,
|
200
224
|
InstanceReader instanceReader,
|
201
225
|
IPolicy.PolicyInfo memory policyInfo
|
@@ -225,7 +249,7 @@ contract ClaimService is
|
|
225
249
|
instance.getInstanceStore().updateClaim(policyNftId, claimId, claimInfo, CLOSED());
|
226
250
|
}
|
227
251
|
|
228
|
-
|
252
|
+
|
229
253
|
function createPayoutForBeneficiary(
|
230
254
|
NftId policyNftId,
|
231
255
|
ClaimId claimId,
|
@@ -235,6 +259,7 @@ contract ClaimService is
|
|
235
259
|
)
|
236
260
|
external
|
237
261
|
virtual
|
262
|
+
// nonReentrant() // prevents creating a reinsurance claim in a single tx
|
238
263
|
returns (PayoutId payoutId)
|
239
264
|
{
|
240
265
|
if (beneficiary == address(0)) {
|
@@ -258,6 +283,7 @@ contract ClaimService is
|
|
258
283
|
)
|
259
284
|
external
|
260
285
|
virtual
|
286
|
+
// nonReentrant() // prevents creating a reinsurance payout in a single tx
|
261
287
|
returns (PayoutId payoutId)
|
262
288
|
{
|
263
289
|
return _createPayout(
|
@@ -268,56 +294,6 @@ contract ClaimService is
|
|
268
294
|
data);
|
269
295
|
}
|
270
296
|
|
271
|
-
function _createPayout(
|
272
|
-
NftId policyNftId,
|
273
|
-
ClaimId claimId,
|
274
|
-
Amount amount,
|
275
|
-
address beneficiary,
|
276
|
-
bytes memory data
|
277
|
-
)
|
278
|
-
internal
|
279
|
-
virtual
|
280
|
-
returns (PayoutId payoutId)
|
281
|
-
{
|
282
|
-
(
|
283
|
-
IInstance instance,
|
284
|
-
InstanceReader instanceReader,
|
285
|
-
IPolicy.PolicyInfo memory policyInfo
|
286
|
-
) = _verifyCallerWithPolicy(policyNftId);
|
287
|
-
|
288
|
-
IPolicy.ClaimInfo memory claimInfo = instanceReader.getClaimInfo(policyNftId, claimId);
|
289
|
-
StateId claimState = instanceReader.getClaimState(policyNftId, claimId);
|
290
|
-
|
291
|
-
// TODO add checks
|
292
|
-
// claim needs to be open
|
293
|
-
// claim.paidAmount + amount <= claim.claimAmount
|
294
|
-
|
295
|
-
// check/update claim info
|
296
|
-
// create payout info with instance
|
297
|
-
uint8 claimNo = claimInfo.payoutsCount + 1;
|
298
|
-
payoutId = PayoutIdLib.toPayoutId(claimId, claimNo);
|
299
|
-
instance.getInstanceStore().createPayout(
|
300
|
-
policyNftId,
|
301
|
-
payoutId,
|
302
|
-
IPolicy.PayoutInfo({
|
303
|
-
claimId: payoutId.toClaimId(),
|
304
|
-
amount: amount,
|
305
|
-
beneficiary: beneficiary,
|
306
|
-
data: data,
|
307
|
-
paidAt: TimestampLib.zero()}));
|
308
|
-
|
309
|
-
// update and save claim info with instance
|
310
|
-
claimInfo.payoutsCount += 1;
|
311
|
-
claimInfo.openPayoutsCount += 1;
|
312
|
-
instance.getInstanceStore().updateClaim(policyNftId, claimId, claimInfo, KEEP_STATE());
|
313
|
-
|
314
|
-
// update and save policy info with instance
|
315
|
-
policyInfo.payoutAmount.add(amount);
|
316
|
-
instance.getInstanceStore().updatePolicyClaims(policyNftId, policyInfo, KEEP_STATE());
|
317
|
-
|
318
|
-
emit LogClaimServicePayoutCreated(policyNftId, payoutId, amount);
|
319
|
-
}
|
320
|
-
|
321
297
|
|
322
298
|
function processPayout(
|
323
299
|
NftId policyNftId,
|
@@ -325,8 +301,10 @@ contract ClaimService is
|
|
325
301
|
)
|
326
302
|
external
|
327
303
|
virtual
|
304
|
+
// nonReentrant() // prevents creating a reinsurance payout in a single tx
|
328
305
|
{
|
329
306
|
(
|
307
|
+
,
|
330
308
|
IInstance instance,
|
331
309
|
InstanceReader instanceReader,
|
332
310
|
IPolicy.PolicyInfo memory policyInfo
|
@@ -339,7 +317,6 @@ contract ClaimService is
|
|
339
317
|
payoutInfo.paidAt = TimestampLib.blockTimestamp();
|
340
318
|
instance.getInstanceStore().updatePayout(policyNftId, payoutId, payoutInfo, PAID());
|
341
319
|
|
342
|
-
// TODO update and save claim info with instance
|
343
320
|
ClaimId claimId = payoutId.toClaimId();
|
344
321
|
Amount payoutAmount = payoutInfo.amount;
|
345
322
|
IPolicy.ClaimInfo memory claimInfo = instanceReader.getClaimInfo(policyNftId, claimId);
|
@@ -349,7 +326,7 @@ contract ClaimService is
|
|
349
326
|
// check if this payout is closing the linked claim
|
350
327
|
// update claim and policy info accordingly
|
351
328
|
if(claimInfo.openPayoutsCount == 0 && claimInfo.paidAmount == claimInfo.claimAmount) {
|
352
|
-
claimInfo.closedAt
|
329
|
+
claimInfo.closedAt = TimestampLib.blockTimestamp();
|
353
330
|
instance.getInstanceStore().updateClaim(policyNftId, claimId, claimInfo, CLOSED());
|
354
331
|
|
355
332
|
policyInfo.openClaimsCount -= 1;
|
@@ -362,13 +339,13 @@ contract ClaimService is
|
|
362
339
|
instance.getInstanceStore().updatePolicyClaims(policyNftId, policyInfo, KEEP_STATE());
|
363
340
|
|
364
341
|
// inform pool about payout
|
365
|
-
_poolService.
|
342
|
+
_poolService.processPayout(
|
366
343
|
instance,
|
367
344
|
address(instanceReader.getComponentInfo(policyInfo.productNftId).token),
|
368
345
|
policyNftId,
|
369
346
|
policyInfo,
|
370
347
|
payoutAmount);
|
371
|
-
|
348
|
+
|
372
349
|
// transfer payout token and fee
|
373
350
|
(
|
374
351
|
Amount netPayoutAmount,
|
@@ -390,9 +367,68 @@ contract ClaimService is
|
|
390
367
|
// TODO add 2nd token tx if processingFeeAmount > 0
|
391
368
|
}
|
392
369
|
|
393
|
-
//
|
370
|
+
// callback to policy holder if applicable
|
371
|
+
_policyHolderPayoutExecuted(policyNftId, payoutId, beneficiary, payoutAmount);
|
394
372
|
}
|
395
373
|
|
374
|
+
// internal functions
|
375
|
+
|
376
|
+
|
377
|
+
function _createPayout(
|
378
|
+
NftId policyNftId,
|
379
|
+
ClaimId claimId,
|
380
|
+
Amount amount,
|
381
|
+
address beneficiary,
|
382
|
+
bytes memory data
|
383
|
+
)
|
384
|
+
internal
|
385
|
+
virtual
|
386
|
+
returns (PayoutId payoutId)
|
387
|
+
{
|
388
|
+
(
|
389
|
+
,
|
390
|
+
IInstance instance,
|
391
|
+
InstanceReader instanceReader,
|
392
|
+
IPolicy.PolicyInfo memory policyInfo
|
393
|
+
) = _verifyCallerWithPolicy(policyNftId);
|
394
|
+
|
395
|
+
IPolicy.ClaimInfo memory claimInfo = instanceReader.getClaimInfo(policyNftId, claimId);
|
396
|
+
StateId claimState = instanceReader.getClaimState(policyNftId, claimId);
|
397
|
+
|
398
|
+
// TODO add checks
|
399
|
+
// claim needs to be open
|
400
|
+
// claim.paidAmount + amount <= claim.claimAmount
|
401
|
+
|
402
|
+
// check/update claim info
|
403
|
+
// create payout info with instance
|
404
|
+
uint24 payoutNo = claimInfo.payoutsCount + 1;
|
405
|
+
payoutId = PayoutIdLib.toPayoutId(claimId, payoutNo);
|
406
|
+
if (beneficiary == address(0)) {
|
407
|
+
beneficiary = getRegistry().ownerOf(policyNftId);
|
408
|
+
}
|
409
|
+
instance.getInstanceStore().createPayout(
|
410
|
+
policyNftId,
|
411
|
+
payoutId,
|
412
|
+
IPolicy.PayoutInfo({
|
413
|
+
claimId: payoutId.toClaimId(),
|
414
|
+
amount: amount,
|
415
|
+
beneficiary: beneficiary,
|
416
|
+
data: data,
|
417
|
+
paidAt: TimestampLib.zero()}));
|
418
|
+
|
419
|
+
// update and save claim info with instance
|
420
|
+
claimInfo.payoutsCount += 1;
|
421
|
+
claimInfo.openPayoutsCount += 1;
|
422
|
+
instance.getInstanceStore().updateClaim(policyNftId, claimId, claimInfo, KEEP_STATE());
|
423
|
+
|
424
|
+
// update and save policy info with instance
|
425
|
+
policyInfo.payoutAmount.add(amount);
|
426
|
+
instance.getInstanceStore().updatePolicyClaims(policyNftId, policyInfo, KEEP_STATE());
|
427
|
+
|
428
|
+
emit LogClaimServicePayoutCreated(policyNftId, payoutId, amount, beneficiary);
|
429
|
+
}
|
430
|
+
|
431
|
+
|
396
432
|
function _calculatePayoutAmount(
|
397
433
|
InstanceReader instanceReader,
|
398
434
|
NftId policyNftId,
|
@@ -430,7 +466,6 @@ contract ClaimService is
|
|
430
466
|
}
|
431
467
|
}
|
432
468
|
|
433
|
-
// internal functions
|
434
469
|
|
435
470
|
function _verifyCallerWithPolicy(
|
436
471
|
NftId policyNftId
|
@@ -439,12 +474,12 @@ contract ClaimService is
|
|
439
474
|
view
|
440
475
|
virtual
|
441
476
|
returns (
|
477
|
+
NftId productNftId,
|
442
478
|
IInstance instance,
|
443
479
|
InstanceReader instanceReader,
|
444
480
|
IPolicy.PolicyInfo memory policyInfo
|
445
481
|
)
|
446
482
|
{
|
447
|
-
NftId productNftId;
|
448
483
|
(productNftId,, instance) = _getAndVerifyActiveComponent(PRODUCT());
|
449
484
|
instanceReader = instance.getInstanceReader();
|
450
485
|
|
@@ -480,6 +515,65 @@ contract ClaimService is
|
|
480
515
|
claimInfo = instanceReader.getClaimInfo(policyNftId, claimId);
|
481
516
|
}
|
482
517
|
|
518
|
+
function _processConfirmedClaimByPool(
|
519
|
+
InstanceReader instanceReader,
|
520
|
+
NftId productNftId,
|
521
|
+
NftId policyNftId,
|
522
|
+
ClaimId claimId,
|
523
|
+
Amount amount
|
524
|
+
)
|
525
|
+
internal
|
526
|
+
{
|
527
|
+
NftId poolNftId = instanceReader.getProductInfo(productNftId).poolNftId;
|
528
|
+
if (instanceReader.getPoolInfo(poolNftId).isProcessingConfirmedClaims) {
|
529
|
+
address poolAddress = getRegistry().getObjectAddress(poolNftId);
|
530
|
+
IPoolComponent(poolAddress).processConfirmedClaim(policyNftId, claimId, amount);
|
531
|
+
}
|
532
|
+
}
|
533
|
+
|
534
|
+
|
535
|
+
function _policyHolderClaimConfirmed(
|
536
|
+
NftId policyNftId,
|
537
|
+
ClaimId claimId,
|
538
|
+
Amount confirmedAmount
|
539
|
+
)
|
540
|
+
internal
|
541
|
+
{
|
542
|
+
IPolicyHolder policyHolder = _getPolicyHolder(policyNftId);
|
543
|
+
if(address(policyHolder) != address(0)) {
|
544
|
+
policyHolder.claimConfirmed(policyNftId, claimId, confirmedAmount);
|
545
|
+
}
|
546
|
+
}
|
547
|
+
|
548
|
+
|
549
|
+
function _policyHolderPayoutExecuted(
|
550
|
+
NftId policyNftId,
|
551
|
+
PayoutId payoutId,
|
552
|
+
address beneficiary,
|
553
|
+
Amount payoutAmount
|
554
|
+
)
|
555
|
+
internal
|
556
|
+
{
|
557
|
+
IPolicyHolder policyHolder = _getPolicyHolder(policyNftId);
|
558
|
+
if(address(policyHolder) != address(0)) {
|
559
|
+
policyHolder.payoutExecuted(policyNftId, payoutId, payoutAmount, beneficiary);
|
560
|
+
}
|
561
|
+
}
|
562
|
+
|
563
|
+
|
564
|
+
function _getPolicyHolder(NftId policyNftId)
|
565
|
+
internal
|
566
|
+
view
|
567
|
+
returns (IPolicyHolder policyHolder)
|
568
|
+
{
|
569
|
+
address policyHolderAddress = getRegistry().ownerOf(policyNftId);
|
570
|
+
policyHolder = IPolicyHolder(policyHolderAddress);
|
571
|
+
|
572
|
+
if (!ContractLib.isPolicyHolder(policyHolderAddress)) {
|
573
|
+
policyHolder = IPolicyHolder(address(0));
|
574
|
+
}
|
575
|
+
}
|
576
|
+
|
483
577
|
|
484
578
|
function _getDomain() internal pure override returns(ObjectType) {
|
485
579
|
return CLAIM();
|
@@ -12,14 +12,14 @@ contract ClaimServiceManager is ProxyManager {
|
|
12
12
|
/// @dev initializes proxy manager with service implementation
|
13
13
|
constructor(
|
14
14
|
address authority,
|
15
|
-
address
|
15
|
+
address registry,
|
16
16
|
bytes32 salt
|
17
17
|
)
|
18
|
-
ProxyManager(registryAddress)
|
19
18
|
{
|
20
19
|
ClaimService svc = new ClaimService{salt: salt}();
|
21
|
-
bytes memory data = abi.encode(
|
22
|
-
IVersionable versionable =
|
20
|
+
bytes memory data = abi.encode(registry, authority);
|
21
|
+
IVersionable versionable = initialize(
|
22
|
+
registry,
|
23
23
|
address(svc),
|
24
24
|
data,
|
25
25
|
salt);
|
@@ -26,8 +26,9 @@ interface IClaimService is
|
|
26
26
|
event LogClaimServiceClaimRevoked(NftId policyNftId, ClaimId claimId);
|
27
27
|
event LogClaimServiceClaimClosed(NftId policyNftId, ClaimId claimId);
|
28
28
|
|
29
|
-
event LogClaimServicePayoutCreated(NftId policyNftId, PayoutId payoutId, Amount amount);
|
29
|
+
event LogClaimServicePayoutCreated(NftId policyNftId, PayoutId payoutId, Amount amount, address beneficiary);
|
30
30
|
event LogClaimServicePayoutProcessed(NftId policyNftId, PayoutId payoutId, Amount amount, address beneficiary, Amount netAmount, Amount processingFeeAmount);
|
31
|
+
error ErrorClaimServiceBeneficiarySet(NftId policyNftId, PayoutId payoutId, address beneficiary);
|
31
32
|
|
32
33
|
error ErrorClaimServicePolicyProductMismatch(NftId policyNftId, NftId expectedProduct, NftId actualProduct);
|
33
34
|
error ErrorClaimServicePolicyNotOpen(NftId policyNftId);
|
@@ -35,7 +36,7 @@ interface IClaimService is
|
|
35
36
|
error ErrorClaimServiceBeneficiaryIsZero(NftId policyNftId, ClaimId claimId);
|
36
37
|
error ErrorClaimsServicePayoutAmountIsZero(NftId policyNftId, PayoutId payoutId);
|
37
38
|
|
38
|
-
error ErrorClaimServiceClaimWithOpenPayouts(NftId policyNftId, ClaimId claimId,
|
39
|
+
error ErrorClaimServiceClaimWithOpenPayouts(NftId policyNftId, ClaimId claimId, uint24 openPayouts);
|
39
40
|
error ErrorClaimServiceClaimWithMissingPayouts(NftId policyNftId, ClaimId claimId, Amount claimAmount, Amount paidAmount);
|
40
41
|
error ErrorClaimServiceClaimNotInExpectedState(NftId policyNftId, ClaimId claimId, StateId expectedState, StateId actualState);
|
41
42
|
|
@@ -4,12 +4,20 @@ pragma solidity ^0.8.20;
|
|
4
4
|
import {IService} from "../shared/IService.sol";
|
5
5
|
|
6
6
|
import {Amount} from "../type/Amount.sol";
|
7
|
+
import {IInstance} from "../instance/IInstance.sol";
|
7
8
|
import {NftId} from "../type/NftId.sol";
|
8
9
|
import {StateId} from "../type/StateId.sol";
|
9
10
|
import {Timestamp} from "../type/Timestamp.sol";
|
10
11
|
|
11
12
|
interface IPolicyService is IService {
|
12
13
|
|
14
|
+
event LogPolicyServicePolicyCreated(NftId policyNftId, Amount premiumAmount, Timestamp activatedAt);
|
15
|
+
event LogPolicyServicePolicyDeclined(NftId policyNftId);
|
16
|
+
event LogPolicyServicePolicyPremiumCollected(NftId policyNftId, Amount premiumAmount);
|
17
|
+
event LogPolicyServicePolicyActivated(NftId policyNftId, Timestamp activatedAt);
|
18
|
+
event LogPolicyServicePolicyExpirationUpdated(NftId policyNftId, Timestamp originalExpiredAt, Timestamp expiredAt);
|
19
|
+
event LogPolicyServicePolicyClosed(NftId policyNftId);
|
20
|
+
|
13
21
|
error ErrorPolicyServicePolicyProductMismatch(NftId applicationNftId, NftId expectedProductNftId, NftId actualProductNftId);
|
14
22
|
error ErrorPolicyServicePolicyStateNotApplied(NftId applicationNftId);
|
15
23
|
error ErrorPolicyServicePolicyStateNotCollateralized(NftId applicationNftId);
|
@@ -32,9 +40,6 @@ interface IPolicyService is IService {
|
|
32
40
|
error ErrorPolicyServicePremiumMismatch(NftId policyNftId, Amount expectedPremiumAmount, Amount recalculatedPremiumAmount);
|
33
41
|
error ErrorPolicyServiceTransferredPremiumMismatch(NftId policyNftId, Amount expectedPremiumAmount, Amount transferredPremiumAmount);
|
34
42
|
|
35
|
-
event LogPolicyServicePolicyDeclined(NftId policyNftId);
|
36
|
-
event LogPolicyServicePolicyExpirationUpdated(NftId policyNftId, Timestamp expiredAt);
|
37
|
-
|
38
43
|
/// @dev creates the policy from {applicationNftId}.
|
39
44
|
/// After successful completion of the function the policy can be referenced using the application NftId.
|
40
45
|
/// Locks the sum insured amount in the pool, but does not transfer tokens. Call collectPremium to transfer tokens.
|
@@ -65,6 +70,8 @@ interface IPolicyService is IService {
|
|
65
70
|
/// @return expiredAt the effective expiry date
|
66
71
|
function expire(NftId policyNftId, Timestamp expireAt) external returns (Timestamp expiredAt);
|
67
72
|
|
73
|
+
function expirePolicy(IInstance instance, NftId policyNftId, Timestamp expireAt) external returns (Timestamp expiredAt);
|
74
|
+
|
68
75
|
/// @dev closes the specified policy and sets the closed data in the policy metadata
|
69
76
|
/// a policy can only be closed when it has been expired. in addition, it must not have any open claims
|
70
77
|
/// this function can only be called by a product. the policy needs to match with the calling product
|
@@ -2,6 +2,7 @@
|
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
4
|
import {Amount} from "../type/Amount.sol";
|
5
|
+
import {ClaimId} from "../type/ClaimId.sol";
|
5
6
|
import {IInstanceLinkedComponent} from "../shared/IInstanceLinkedComponent.sol";
|
6
7
|
import {IComponents} from "../instance/module/IComponents.sol";
|
7
8
|
import {NftId} from "../type/NftId.sol";
|
@@ -13,6 +14,18 @@ interface IProductComponent is
|
|
13
14
|
IInstanceLinkedComponent
|
14
15
|
{
|
15
16
|
|
17
|
+
/// @dev Callback function to inform product compnent about arrival of funding for a claim.
|
18
|
+
/// The callback is called by the pool service after the corresponding pool triggers this function.
|
19
|
+
/// The callback is only called when the product's property isProcessingFundedClaims is set.
|
20
|
+
function processFundedClaim(
|
21
|
+
NftId policyNftId,
|
22
|
+
ClaimId claimId,
|
23
|
+
Amount availableAmount
|
24
|
+
) external;
|
25
|
+
|
26
|
+
|
27
|
+
/// @dev Calculates the premium amount for the provided application data.
|
28
|
+
/// The returned premium amounts takes into account potential discounts and fees.
|
16
29
|
function calculatePremium(
|
17
30
|
Amount sumInsuredAmount,
|
18
31
|
RiskId riskId,
|
@@ -22,6 +35,10 @@ interface IProductComponent is
|
|
22
35
|
ReferralId referralId
|
23
36
|
) external view returns (Amount premiumAmount);
|
24
37
|
|
38
|
+
|
39
|
+
/// @dev Calculates the net premium amount for the provided application data.
|
40
|
+
/// The returned net premium amounts only covers the cost of collateralizing the application.
|
41
|
+
/// This amount purely depends on the use case specific risk and does not include any fees/commission.
|
25
42
|
function calculateNetPremium(
|
26
43
|
Amount sumInsuredAmount,
|
27
44
|
RiskId riskId,
|
@@ -29,9 +46,6 @@ interface IProductComponent is
|
|
29
46
|
bytes memory applicationData
|
30
47
|
) external view returns (Amount netPremiumAmount);
|
31
48
|
|
32
|
-
function getPoolNftId() external view returns (NftId poolNftId);
|
33
|
-
function getDistributionNftId() external view returns (NftId distributionNftId);
|
34
|
-
|
35
49
|
|
36
50
|
/// @dev returns initial pool specific infos for this pool
|
37
51
|
function getInitialProductInfo() external view returns (IComponents.ProductInfo memory info);
|