@etherisc/gif-next 0.0.2-b28f7c7-340 → 0.0.2-b44ae3c-205
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/artifacts/contracts/components/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/components/Component.sol/Component.json +37 -6
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/components/Distribution.sol/Distribution.json +60 -13
- package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IComponent.sol/IComponent.json +37 -6
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +44 -13
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +55 -24
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +52 -21
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/components/Pool.sol/Pool.json +55 -24
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/components/Product.sol/Product.json +52 -21
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +2 -2
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +309 -2023
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +21 -38
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +424 -2776
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +67 -49
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +124 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +331 -51
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +59 -259
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +32 -117
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +2788 -0
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +1 -1
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +2 -2
- package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.json +37 -13
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +8 -8
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +6 -6
- 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/instance/module/ISetup.sol/ISetup.dbg.json +1 -1
- package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.json +113 -234
- package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.json +35 -60
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +171 -114
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +35 -60
- package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.json +638 -71
- package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.json +144 -33
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +178 -420
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +80 -105
- package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.json +45 -174
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.json +104 -28
- package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.json +313 -45
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.json +23 -273
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.json +128 -83
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +269 -36
- package/artifacts/contracts/instance/service/IPricingService.sol/IPricingService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IPricingService.sol/IPricingService.json +510 -0
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.json +5 -13
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +328 -139
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +98 -55
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +443 -58
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +84 -37
- package/artifacts/contracts/instance/service/PricingService.sol/PricingService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PricingService.sol/PricingService.json +1004 -0
- package/artifacts/contracts/instance/service/PricingServiceManager.sol/PricingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PricingServiceManager.sol/PricingServiceManager.json +688 -0
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +55 -31
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +22 -35
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +5 -13
- 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 +2 -2
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +2 -2
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +17 -25
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +21 -34
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +2 -2
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +10 -23
- package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +4 -0
- package/artifacts/contracts/{instance → shared}/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +3 -3
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +1 -1
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +0 -13
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +69 -9
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +0 -13
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.json +0 -13
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +5 -13
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +6 -19
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +80 -26
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +14 -27
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +6 -19
- 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 -13
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +24 -6
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
- package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +1 -1
- package/artifacts/contracts/test/TestFee.sol/TestFee.json +2 -2
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +1 -1
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +6 -19
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +1 -1
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +2 -2
- package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +1 -1
- package/artifacts/contracts/test/TestService.sol/TestService.json +17 -25
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +1 -1
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +1 -1
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +1 -1
- package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +1 -1
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/types/Amount.sol/AmountLib.dbg.json +1 -1
- package/artifacts/contracts/types/Amount.sol/AmountLib.json +124 -4
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.json +83 -4
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.json +2 -2
- package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/types/Fee.sol/FeeLib.json +42 -18
- package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/types/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/NftId.sol/NftIdLib.json +2 -2
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.json +2 -2
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +2 -2
- package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.json +116 -7
- package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +1 -1
- package/artifacts/contracts/types/Referral.sol/ReferralLib.json +2 -2
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.json +2 -2
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +2 -2
- package/artifacts/contracts/types/Seconds.sol/SecondsLib.dbg.json +1 -1
- package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/StateId.sol/StateIdLib.json +2 -2
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +17 -4
- package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +1 -1
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +1 -1
- package/contracts/components/Component.sol +21 -2
- package/contracts/components/Distribution.sol +11 -6
- package/contracts/components/IComponent.sol +16 -2
- package/contracts/components/IPoolComponent.sol +8 -7
- package/contracts/components/IProductComponent.sol +5 -4
- package/contracts/components/Pool.sol +11 -12
- package/contracts/components/Product.sol +144 -62
- package/contracts/instance/BundleManager.sol +3 -4
- package/contracts/instance/IInstance.sol +32 -53
- package/contracts/instance/IInstanceService.sol +15 -14
- package/contracts/instance/Instance.sol +107 -205
- package/contracts/instance/InstanceAccessManager.sol +35 -21
- package/contracts/instance/InstanceAuthorizationsLib.sol +308 -0
- package/contracts/instance/InstanceReader.sol +84 -7
- package/contracts/instance/InstanceService.sol +96 -283
- package/contracts/instance/InstanceStore.sol +212 -0
- package/contracts/instance/ObjectManager.sol +1 -1
- package/contracts/instance/base/ComponentService.sol +47 -20
- package/contracts/instance/base/KeyValueStore.sol +0 -31
- package/contracts/instance/base/Lifecycle.sol +15 -4
- package/contracts/instance/module/IComponents.sol +3 -3
- package/contracts/instance/module/IDistribution.sol +3 -2
- package/contracts/instance/module/IPolicy.sol +13 -8
- package/contracts/instance/service/ApplicationService.sol +58 -222
- package/contracts/instance/service/BundleService.sol +71 -120
- package/contracts/instance/service/ClaimService.sol +316 -30
- package/contracts/instance/service/DistributionService.sol +62 -149
- package/contracts/instance/service/IApplicationService.sol +8 -28
- package/contracts/instance/service/IBundleService.sol +34 -9
- package/contracts/instance/service/IClaimService.sol +52 -23
- package/contracts/instance/service/IDistributionService.sol +10 -22
- package/contracts/instance/service/IPolicyService.sol +24 -16
- package/contracts/instance/service/IPoolService.sol +18 -3
- package/contracts/instance/service/IPricingService.sol +37 -0
- package/contracts/instance/service/PolicyService.sol +126 -112
- package/contracts/instance/service/PoolService.sol +121 -21
- package/contracts/instance/service/PricingService.sol +275 -0
- package/contracts/instance/service/PricingServiceManager.sol +51 -0
- package/contracts/instance/service/ProductService.sol +11 -11
- package/contracts/registry/IRegistryService.sol +0 -2
- package/contracts/registry/RegistryService.sol +14 -10
- package/contracts/shared/IPolicyHolder.sol +23 -9
- package/contracts/shared/IRegistryLinked.sol +0 -1
- package/contracts/shared/IService.sol +2 -0
- package/contracts/shared/NftOwnable.sol +0 -2
- package/contracts/shared/PolicyHolder.sol +30 -17
- package/contracts/shared/Registerable.sol +10 -9
- package/contracts/shared/RegistryLinked.sol +0 -5
- package/contracts/shared/TokenHandler.sol +4 -2
- package/contracts/types/Amount.sol +49 -0
- package/contracts/types/ClaimId.sol +25 -2
- package/contracts/types/Fee.sol +7 -6
- package/contracts/types/ObjectType.sol +9 -5
- package/contracts/types/PayoutId.sol +33 -5
- package/contracts/types/StateId.sol +6 -2
- package/contracts/types/Timestamp.sol +5 -0
- package/package.json +1 -1
- package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +0 -4
- /package/contracts/{instance → shared}/AccessManagerUpgradeableInitializeable.sol +0 -0
@@ -1,6 +1,7 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.19;
|
3
3
|
|
4
|
+
import {Amount} from "../../types/Amount.sol";
|
4
5
|
import {NftId} from "../../types/NftId.sol";
|
5
6
|
import {Fee} from "../../types/Fee.sol";
|
6
7
|
import {IPolicy} from "../module/IPolicy.sol";
|
@@ -25,16 +26,8 @@ interface IDistributionService is IService {
|
|
25
26
|
error ErrorIDistributionServiceCommissionTooHigh(uint256 commissionPercentage, uint256 maxCommissionPercentage);
|
26
27
|
error ErrorIDistributionServiceMinFeeTooHigh(uint256 minFee, uint256 limit);
|
27
28
|
error ErrorIDistributionServiceMaxDiscountTooHigh(uint256 maxDiscountPercentage, uint256 limit);
|
28
|
-
error ErrorIDistributionServiceFeeCalculationMismatch(
|
29
|
-
uint256 distributionFeeFixAmount,
|
30
|
-
uint256 distributionFeeVarAmount,
|
31
|
-
uint256 distributionOwnerFeeFixAmount,
|
32
|
-
uint256 distributionOwnerFeeVarAmount,
|
33
|
-
uint256 commissionAmount,
|
34
|
-
uint256 discountAmount
|
35
|
-
);
|
36
29
|
error ErrorIDistributionServiceReferralInvalid(NftId distributionNftId, ReferralId referralId);
|
37
|
-
error
|
30
|
+
error ErrorDistributionServiceInvalidFeeTransferred(Amount transferredDistributionFeeAmount, Amount expectedDistributionFeeAmount);
|
38
31
|
|
39
32
|
function setFees(
|
40
33
|
Fee memory minDistributionOwnerFee,
|
@@ -61,11 +54,12 @@ interface IDistributionService is IService {
|
|
61
54
|
bytes memory data
|
62
55
|
) external returns (NftId distributorNftId);
|
63
56
|
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
57
|
+
// TODO re-enable and reorganize (service contract too large)
|
58
|
+
// function updateDistributorType(
|
59
|
+
// NftId distributorNftId,
|
60
|
+
// DistributorType distributorType,
|
61
|
+
// bytes memory data
|
62
|
+
// ) external;
|
69
63
|
|
70
64
|
function createReferral(
|
71
65
|
NftId distributorNftId,
|
@@ -83,17 +77,11 @@ interface IDistributionService is IService {
|
|
83
77
|
NftId distributionNftId,
|
84
78
|
ReferralId referralId,
|
85
79
|
IPolicy.Premium memory premium,
|
86
|
-
|
80
|
+
Amount transferredDistributionFeeAmount
|
87
81
|
) external;
|
88
82
|
|
89
|
-
function calculateFeeAmount(
|
90
|
-
NftId distributionNftId,
|
91
|
-
ReferralId referralId,
|
92
|
-
IPolicy.Premium memory premium
|
93
|
-
) external view returns (IPolicy.Premium memory finalPremium);
|
94
|
-
|
95
83
|
function referralIsValid(
|
96
84
|
NftId distributorNftId,
|
97
85
|
ReferralId referralId
|
98
86
|
) external view returns (bool isValid);
|
99
|
-
}
|
87
|
+
}
|
@@ -4,7 +4,10 @@ pragma solidity ^0.8.19;
|
|
4
4
|
import {IRisk} from "../module/IRisk.sol";
|
5
5
|
import {IService} from "../../shared/IService.sol";
|
6
6
|
|
7
|
+
import {Amount} from "../../types/Amount.sol";
|
8
|
+
import {ClaimId} from "../../types/ClaimId.sol";
|
7
9
|
import {NftId} from "../../types/NftId.sol";
|
10
|
+
import {PayoutId} from "../../types/PayoutId.sol";
|
8
11
|
import {ReferralId} from "../../types/Referral.sol";
|
9
12
|
import {RiskId} from "../../types/RiskId.sol";
|
10
13
|
import {Seconds} from "../../types/Seconds.sol";
|
@@ -14,37 +17,41 @@ import {UFixed} from "../../types/UFixed.sol";
|
|
14
17
|
import {Fee} from "../../types/Fee.sol";
|
15
18
|
|
16
19
|
interface IPolicyService is IService {
|
17
|
-
|
20
|
+
|
21
|
+
error ErrorPolicyServicePolicyProductMismatch(NftId applicationNftId, NftId expectedProductNftId, NftId actualProductNftId);
|
22
|
+
error ErrorPolicyServicePolicyStateNotApplied(NftId applicationNftId);
|
23
|
+
|
18
24
|
error ErrorIPolicyServiceInsufficientAllowance(address customer, address tokenHandlerAddress, uint256 amount);
|
19
|
-
error
|
25
|
+
error ErrorPolicyServicePremiumAlreadyPaid(NftId policyNftId, Amount premiumPaidAmount);
|
20
26
|
error ErrorIPolicyServicePolicyNotActivated(NftId policyNftId);
|
21
27
|
error ErrorIPolicyServicePolicyAlreadyClosed(NftId policyNftId);
|
22
28
|
error ErrorIPolicyServicePolicyNotActive(NftId policyNftId, StateId state);
|
23
|
-
error
|
29
|
+
error ErrorPolicyServicePremiumNotFullyPaid(NftId policyNftId, Amount premiumAmount, Amount premiumPaidAmount);
|
24
30
|
error ErrorIPolicyServiceOpenClaims(NftId policyNftId, uint16 openClaimsCount);
|
25
31
|
error ErrorIPolicyServicePolicyHasNotExpired(NftId policyNftId, Timestamp expiredAt);
|
26
32
|
|
27
|
-
error
|
28
|
-
|
29
|
-
/// @dev declines an application represented by {policyNftId}
|
30
|
-
/// an application can only be declined in applied state
|
31
|
-
/// only the related product may decline an application
|
32
|
-
function decline(NftId policyNftId) external;
|
33
|
+
error ErrorPolicyServicePremiumMismatch(NftId policyNftId, Amount expectedPremiumAmount, Amount recalculatedPremiumAmount);
|
34
|
+
error ErrorPolicyServiceTransferredPremiumMismatch(NftId policyNftId, Amount expectedPremiumAmount, Amount transferredPremiumAmount);
|
33
35
|
|
34
|
-
/// @dev
|
35
|
-
/// sets the policy state to
|
36
|
+
/// @dev collateralizes the policy represented by {policyNftId}
|
37
|
+
/// sets the policy state to collateralized
|
36
38
|
/// may set the policy state to activated and set the activation date
|
37
39
|
/// optionally collects premiums and activates the policy.
|
38
40
|
/// - premium payment is only attempted if requirePremiumPayment is set to true
|
39
41
|
/// - activation is only done if activateAt is a non-zero timestamp
|
40
|
-
/// an application can only be
|
41
|
-
/// only the related product may
|
42
|
-
function
|
42
|
+
/// an application can only be collateralized in applied state
|
43
|
+
/// only the related product may collateralize an application
|
44
|
+
function collateralize(
|
43
45
|
NftId policyNftId,
|
44
46
|
bool requirePremiumPayment,
|
45
47
|
Timestamp activateAt
|
46
48
|
) external;
|
47
49
|
|
50
|
+
/// @dev declines an application represented by {policyNftId}
|
51
|
+
/// an application can only be declined in applied state
|
52
|
+
/// only the related product may decline an application
|
53
|
+
function decline(NftId policyNftId) external;
|
54
|
+
|
48
55
|
/// @dev collects the premium token for the specified policy
|
49
56
|
function collectPremium(NftId policyNftId, Timestamp activateAt) external;
|
50
57
|
|
@@ -63,10 +70,11 @@ interface IPolicyService is IService {
|
|
63
70
|
/// this function can only be called by a product. the policy needs to match with the calling product
|
64
71
|
function close(NftId policyNftId) external;
|
65
72
|
|
73
|
+
|
66
74
|
// TODO move function to pool service
|
67
75
|
function calculateRequiredCollateral(
|
68
76
|
UFixed collateralizationLevel,
|
69
|
-
|
70
|
-
) external pure returns(
|
77
|
+
Amount sumInsuredAmount
|
78
|
+
) external pure returns(Amount collateralAmount);
|
71
79
|
|
72
80
|
}
|
@@ -4,6 +4,7 @@ pragma solidity ^0.8.19;
|
|
4
4
|
import {Amount} from "../../types/Amount.sol";
|
5
5
|
import {Fee} from "../../types/Fee.sol";
|
6
6
|
import {NftId} from "../../types/NftId.sol";
|
7
|
+
import {PayoutId} from "../../types/PayoutId.sol";
|
7
8
|
import {IBundle} from "../module/IBundle.sol";
|
8
9
|
import {IInstance} from "../../instance/IInstance.sol";
|
9
10
|
import {IPolicy} from "../module/IPolicy.sol";
|
@@ -14,7 +15,7 @@ import {StateId} from "../../types/StateId.sol";
|
|
14
15
|
|
15
16
|
interface IPoolService is IService {
|
16
17
|
|
17
|
-
event LogPoolServiceMaxCapitalAmountUpdated(NftId poolNftId,
|
18
|
+
event LogPoolServiceMaxCapitalAmountUpdated(NftId poolNftId, Amount previousMaxCapitalAmount, Amount currentMaxCapitalAmount);
|
18
19
|
event LogPoolServiceBundleOwnerRoleSet(NftId poolNftId, RoleId bundleOwnerRole);
|
19
20
|
|
20
21
|
event LogPoolServiceBundleCreated(NftId instanceNftId, NftId poolNftId, NftId bundleNftId);
|
@@ -22,6 +23,7 @@ interface IPoolService is IService {
|
|
22
23
|
|
23
24
|
error ErrorPoolServiceBundleOwnerRoleAlreadySet(NftId poolNftId);
|
24
25
|
error ErrorPoolServiceBundlePoolMismatch(NftId bundlePoolNftId, NftId productPoolNftId);
|
26
|
+
error ErrorPoolServiceInvalidTransferAmount(Amount expectedAmount, Amount actualAmount);
|
25
27
|
|
26
28
|
/// @dev registers a new pool with the registry service
|
27
29
|
function register(address poolAddress) external returns(NftId);
|
@@ -31,7 +33,7 @@ interface IPoolService is IService {
|
|
31
33
|
function setBundleOwnerRole(RoleId bundleOwnerRole) external;
|
32
34
|
|
33
35
|
/// @dev sets the max capital amount for the calling pool
|
34
|
-
function setMaxCapitalAmount(
|
36
|
+
function setMaxCapitalAmount(Amount maxCapitalAmount) external;
|
35
37
|
|
36
38
|
/// @dev set pool sepecific fees
|
37
39
|
function setFees(
|
@@ -51,7 +53,7 @@ interface IPoolService is IService {
|
|
51
53
|
NftId productNftId,
|
52
54
|
NftId applicationNftId,
|
53
55
|
IPolicy.PolicyInfo memory applicationInfo,
|
54
|
-
|
56
|
+
Amount premiumAmount
|
55
57
|
) external;
|
56
58
|
|
57
59
|
|
@@ -64,6 +66,17 @@ interface IPoolService is IService {
|
|
64
66
|
) external;
|
65
67
|
|
66
68
|
|
69
|
+
/// @dev reduces the locked collateral in the bundle associated with the specified policy
|
70
|
+
/// every payout of a policy reduces the collateral by the payout amount
|
71
|
+
/// may only be called by the claim service for unlocked pool components
|
72
|
+
function reduceCollateral(
|
73
|
+
IInstance instance,
|
74
|
+
NftId policyNftId,
|
75
|
+
IPolicy.PolicyInfo memory policyInfo,
|
76
|
+
Amount payoutAmount
|
77
|
+
) external;
|
78
|
+
|
79
|
+
|
67
80
|
/// @dev create a new bundle for the provided parameters
|
68
81
|
/// staking fees will be deducted by the pool service from the staking amount
|
69
82
|
/// may only be called by registered and unlocked pool components
|
@@ -85,6 +98,8 @@ interface IPoolService is IService {
|
|
85
98
|
/// may only be called by registered and unlocked pool components
|
86
99
|
function closeBundle(NftId bundleNftId) external;
|
87
100
|
|
101
|
+
/// @dev processes the sale of a bundle and track the pool fee and bundle fee amounts
|
102
|
+
function processSale(NftId bundleNftId, IPolicy.Premium memory premium, Amount actualAmountTransferred) external;
|
88
103
|
|
89
104
|
/// @dev increase stakes for bundle
|
90
105
|
/// staking fees will be deducted by the pool service from the staking amount
|
@@ -0,0 +1,37 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.19;
|
3
|
+
|
4
|
+
import {Seconds} from "../../types/Seconds.sol";
|
5
|
+
import {NftId} from "../../types/NftId.sol";
|
6
|
+
import {ReferralId} from "../../types/Referral.sol";
|
7
|
+
import {RiskId} from "../../types/RiskId.sol";
|
8
|
+
import {Amount} from "../../types/Amount.sol";
|
9
|
+
|
10
|
+
import {IService} from "./IApplicationService.sol";
|
11
|
+
import {IPolicy} from "../module/IPolicy.sol";
|
12
|
+
|
13
|
+
interface IPricingService is IService
|
14
|
+
{
|
15
|
+
error ErrorIPricingServiceBundlePoolMismatch(NftId bundleNftId, NftId bundlePoolNftId, NftId poolNftId);
|
16
|
+
error ErrorIPricingServiceFeeCalculationMismatch(
|
17
|
+
uint256 distributionFeeFixAmount,
|
18
|
+
uint256 distributionFeeVarAmount,
|
19
|
+
uint256 distributionOwnerFeeFixAmount,
|
20
|
+
uint256 distributionOwnerFeeVarAmount,
|
21
|
+
uint256 commissionAmount,
|
22
|
+
uint256 discountAmount
|
23
|
+
);
|
24
|
+
|
25
|
+
function calculatePremium(
|
26
|
+
NftId productNftId,
|
27
|
+
RiskId riskId,
|
28
|
+
Amount sumInsuredAmount,
|
29
|
+
Seconds lifetime,
|
30
|
+
bytes memory applicationData,
|
31
|
+
NftId bundleNftId,
|
32
|
+
ReferralId referralId
|
33
|
+
)
|
34
|
+
external
|
35
|
+
view
|
36
|
+
returns (IPolicy.Premium memory premium);
|
37
|
+
}
|
@@ -14,25 +14,29 @@ import {ISetup} from "../module/ISetup.sol";
|
|
14
14
|
|
15
15
|
import {TokenHandler} from "../../shared/TokenHandler.sol";
|
16
16
|
|
17
|
+
import {Amount, AmountLib} from "../../types/Amount.sol";
|
18
|
+
import {ClaimId, ClaimIdLib} from "../../types/ClaimId.sol";
|
17
19
|
import {Timestamp, TimestampLib, zeroTimestamp} from "../../types/Timestamp.sol";
|
18
20
|
import {UFixed, UFixedLib} from "../../types/UFixed.sol";
|
19
|
-
import {ObjectType, APPLICATION, DISTRIBUTION, PRODUCT, POOL, POLICY, BUNDLE} from "../../types/ObjectType.sol";
|
20
|
-
import {APPLIED,
|
21
|
+
import {ObjectType, APPLICATION, DISTRIBUTION, PRODUCT, POOL, POLICY, BUNDLE, CLAIM, PRICE} from "../../types/ObjectType.sol";
|
22
|
+
import {APPLIED, COLLATERALIZED, ACTIVE, KEEP_STATE, CLOSED, DECLINED, CONFIRMED} from "../../types/StateId.sol";
|
21
23
|
import {NftId, NftIdLib} from "../../types/NftId.sol";
|
24
|
+
import {PayoutId, PayoutIdLib} from "../../types/PayoutId.sol";
|
22
25
|
import {StateId} from "../../types/StateId.sol";
|
23
26
|
import {VersionPart} from "../../types/Version.sol";
|
24
27
|
|
25
28
|
import {ComponentService} from "../base/ComponentService.sol";
|
26
29
|
import {IApplicationService} from "./IApplicationService.sol";
|
27
30
|
import {IBundleService} from "./IBundleService.sol";
|
31
|
+
import {IClaimService} from "./IClaimService.sol";
|
28
32
|
import {IDistributionService} from "./IDistributionService.sol";
|
29
33
|
import {InstanceReader} from "../InstanceReader.sol";
|
30
34
|
import {IPolicyService} from "./IPolicyService.sol";
|
31
35
|
import {IPoolService} from "./IPoolService.sol";
|
36
|
+
import {IPricingService} from "./IPricingService.sol";
|
32
37
|
import {IService} from "../../shared/IService.sol";
|
33
38
|
import {Service} from "../../shared/Service.sol";
|
34
39
|
|
35
|
-
|
36
40
|
contract PolicyService is
|
37
41
|
ComponentService,
|
38
42
|
IPolicyService
|
@@ -40,10 +44,12 @@ contract PolicyService is
|
|
40
44
|
using NftIdLib for NftId;
|
41
45
|
using TimestampLib for Timestamp;
|
42
46
|
|
43
|
-
IPoolService internal _poolService;
|
44
|
-
IBundleService internal _bundleService;
|
45
47
|
IApplicationService internal _applicationService;
|
48
|
+
IBundleService internal _bundleService;
|
49
|
+
IClaimService internal _claimService;
|
46
50
|
IDistributionService internal _distributionService;
|
51
|
+
IPoolService internal _poolService;
|
52
|
+
IPricingService internal _pricingService;
|
47
53
|
|
48
54
|
event LogProductServiceSender(address sender);
|
49
55
|
|
@@ -64,8 +70,10 @@ contract PolicyService is
|
|
64
70
|
VersionPart majorVersion = getVersion().toMajorPart();
|
65
71
|
_poolService = IPoolService(getRegistry().getServiceAddress(POOL(), majorVersion));
|
66
72
|
_bundleService = IBundleService(getRegistry().getServiceAddress(BUNDLE(), majorVersion));
|
73
|
+
_claimService = IClaimService(getRegistry().getServiceAddress(CLAIM(), majorVersion));
|
67
74
|
_applicationService = IApplicationService(getRegistry().getServiceAddress(APPLICATION(), majorVersion));
|
68
75
|
_distributionService = IDistributionService(getRegistry().getServiceAddress(DISTRIBUTION(), majorVersion));
|
76
|
+
_pricingService = IPricingService(getRegistry().getServiceAddress(PRICE(), majorVersion));
|
69
77
|
|
70
78
|
registerInterface(type(IPolicyService).interfaceId);
|
71
79
|
}
|
@@ -78,36 +86,10 @@ contract PolicyService is
|
|
78
86
|
|
79
87
|
function _getAndVerifyInstanceAndProduct() internal view returns (Product product) {
|
80
88
|
IRegistry.ObjectInfo memory productInfo;
|
81
|
-
(, productInfo,) =
|
89
|
+
(, productInfo,) = _getAndVerifyCallingComponentAndInstance(PRODUCT());
|
82
90
|
product = Product(productInfo.objectAddress);
|
83
91
|
}
|
84
92
|
|
85
|
-
// function _getAndVerifyUnderwritingSetup(
|
86
|
-
// IInstance instance,
|
87
|
-
// InstanceReader instanceReader,
|
88
|
-
// IPolicy.PolicyInfo memory policyInfo,
|
89
|
-
// ISetup.ProductSetupInfo memory productSetupInfo
|
90
|
-
// )
|
91
|
-
// internal
|
92
|
-
// view
|
93
|
-
// returns (
|
94
|
-
// NftId poolNftId,
|
95
|
-
// IComponents.PoolInfo memory poolInfo,
|
96
|
-
// NftId bundleNftId,
|
97
|
-
// IBundle.BundleInfo memory bundleInfo
|
98
|
-
// )
|
99
|
-
// {
|
100
|
-
// // check match between policy and bundle (via pool)
|
101
|
-
// poolNftId = productSetupInfo.poolNftId;
|
102
|
-
// bundleNftId = policyInfo.bundleNftId;
|
103
|
-
// bundleInfo = instanceReader.getBundleInfo(bundleNftId);
|
104
|
-
// require(bundleInfo.poolNftId == poolNftId, "BUNDLE_POOL_MISMATCH");
|
105
|
-
|
106
|
-
// // calculate required collateral
|
107
|
-
// IComponents.ComponentInfo memory componentInfo = instanceReader.getComponentInfo(poolNftId);
|
108
|
-
// poolInfo = abi.decode(componentInfo.data, (IComponents.PoolInfo));
|
109
|
-
// }
|
110
|
-
|
111
93
|
|
112
94
|
function decline(
|
113
95
|
NftId policyNftId
|
@@ -115,12 +97,12 @@ contract PolicyService is
|
|
115
97
|
external
|
116
98
|
override
|
117
99
|
{
|
118
|
-
|
100
|
+
revert();
|
119
101
|
}
|
120
102
|
|
121
103
|
|
122
104
|
/// @dev underwites application which includes the locking of the required collateral from the pool.
|
123
|
-
function
|
105
|
+
function collateralize(
|
124
106
|
NftId applicationNftId, // = policyNftId
|
125
107
|
bool requirePremiumPayment,
|
126
108
|
Timestamp activateAt
|
@@ -129,17 +111,24 @@ contract PolicyService is
|
|
129
111
|
virtual override
|
130
112
|
{
|
131
113
|
// check caller is registered product
|
132
|
-
(NftId productNftId,, IInstance instance) =
|
114
|
+
(NftId productNftId,, IInstance instance) = _getAndVerifyCallingComponentAndInstance(PRODUCT());
|
133
115
|
InstanceReader instanceReader = instance.getInstanceReader();
|
134
116
|
|
135
117
|
// check policy matches with calling product
|
136
118
|
IPolicy.PolicyInfo memory applicationInfo = instanceReader.getPolicyInfo(applicationNftId);
|
137
|
-
|
119
|
+
if(applicationInfo.productNftId != productNftId) {
|
120
|
+
revert ErrorPolicyServicePolicyProductMismatch(
|
121
|
+
applicationNftId,
|
122
|
+
applicationInfo.productNftId,
|
123
|
+
productNftId);
|
124
|
+
}
|
138
125
|
|
139
126
|
// check policy is in state applied
|
140
|
-
|
127
|
+
if (instanceReader.getPolicyState(applicationNftId) != APPLIED()) {
|
128
|
+
revert ErrorPolicyServicePolicyStateNotApplied(applicationNftId);
|
129
|
+
}
|
141
130
|
|
142
|
-
StateId newPolicyState =
|
131
|
+
StateId newPolicyState = COLLATERALIZED();
|
143
132
|
|
144
133
|
// optional activation of policy
|
145
134
|
if(activateAt > zeroTimestamp()) {
|
@@ -149,7 +138,7 @@ contract PolicyService is
|
|
149
138
|
}
|
150
139
|
|
151
140
|
// lock bundle collateral
|
152
|
-
|
141
|
+
Amount netPremiumAmount = AmountLib.zero(); // > 0 if immediate premium payment
|
153
142
|
|
154
143
|
// optional collection of premium
|
155
144
|
if(requirePremiumPayment) {
|
@@ -158,11 +147,11 @@ contract PolicyService is
|
|
158
147
|
applicationNftId,
|
159
148
|
applicationInfo.premiumAmount);
|
160
149
|
|
161
|
-
applicationInfo.premiumPaidAmount
|
150
|
+
applicationInfo.premiumPaidAmount = applicationInfo.premiumPaidAmount + applicationInfo.premiumAmount;
|
162
151
|
}
|
163
152
|
|
164
153
|
// store updated policy info
|
165
|
-
instance.updatePolicy(applicationNftId, applicationInfo, newPolicyState);
|
154
|
+
instance.getInstanceStore().updatePolicy(applicationNftId, applicationInfo, newPolicyState);
|
166
155
|
|
167
156
|
// lock collateral and update pool and bundle book keeping
|
168
157
|
// pool retention level: fraction of sum insured that product will cover from pool funds directly
|
@@ -180,33 +169,46 @@ contract PolicyService is
|
|
180
169
|
}
|
181
170
|
|
182
171
|
|
183
|
-
function calculateRequiredCollateral(
|
184
|
-
UFixed
|
185
|
-
|
186
|
-
|
172
|
+
function calculateRequiredCollateral(
|
173
|
+
UFixed collateralizationLevel,
|
174
|
+
Amount sumInsuredAmount
|
175
|
+
)
|
176
|
+
public
|
177
|
+
pure
|
178
|
+
virtual
|
179
|
+
returns(Amount collateralAmount)
|
180
|
+
{
|
181
|
+
UFixed collateralUFixed = collateralizationLevel * sumInsuredAmount.toUFixed();
|
182
|
+
return AmountLib.toAmount(collateralUFixed.toInt());
|
187
183
|
}
|
188
184
|
|
189
|
-
function collectPremium(
|
185
|
+
function collectPremium(
|
186
|
+
NftId policyNftId,
|
187
|
+
Timestamp activateAt
|
188
|
+
)
|
189
|
+
external
|
190
|
+
virtual
|
191
|
+
{
|
190
192
|
// check caller is registered product
|
191
|
-
(NftId productNftId,, IInstance instance) =
|
193
|
+
(NftId productNftId,, IInstance instance) = _getAndVerifyCallingComponentAndInstance(PRODUCT());
|
192
194
|
InstanceReader instanceReader = instance.getInstanceReader();
|
193
195
|
IPolicy.PolicyInfo memory policyInfo = instanceReader.getPolicyInfo(policyNftId);
|
194
196
|
|
195
197
|
if (policyInfo.premiumPaidAmount == policyInfo.premiumAmount) {
|
196
|
-
revert
|
198
|
+
revert ErrorPolicyServicePremiumAlreadyPaid(policyNftId, policyInfo.premiumPaidAmount);
|
197
199
|
}
|
198
200
|
|
199
|
-
|
201
|
+
Amount unpaidPremiumAmount = policyInfo.premiumAmount - policyInfo.premiumPaidAmount;
|
200
202
|
|
201
|
-
|
203
|
+
Amount netPremiumAmount = _processPremiumByTreasury(
|
202
204
|
instance,
|
203
205
|
policyNftId,
|
204
206
|
unpaidPremiumAmount);
|
205
207
|
|
206
|
-
policyInfo.premiumPaidAmount
|
208
|
+
policyInfo.premiumPaidAmount = policyInfo.premiumPaidAmount + unpaidPremiumAmount;
|
207
209
|
|
208
210
|
_bundleService.increaseBalance(instance, policyInfo.bundleNftId, netPremiumAmount);
|
209
|
-
instance.updatePolicy(policyNftId, policyInfo, KEEP_STATE());
|
211
|
+
instance.getInstanceStore().updatePolicy(policyNftId, policyInfo, KEEP_STATE());
|
210
212
|
|
211
213
|
if(activateAt.gtz() && policyInfo.activatedAt.eqz()) {
|
212
214
|
activate(policyNftId, activateAt);
|
@@ -217,7 +219,7 @@ contract PolicyService is
|
|
217
219
|
|
218
220
|
function activate(NftId policyNftId, Timestamp activateAt) public override {
|
219
221
|
// check caller is registered product
|
220
|
-
(,, IInstance instance) =
|
222
|
+
(,, IInstance instance) = _getAndVerifyCallingComponentAndInstance(PRODUCT());
|
221
223
|
InstanceReader instanceReader = instance.getInstanceReader();
|
222
224
|
|
223
225
|
IPolicy.PolicyInfo memory policyInfo = instanceReader.getPolicyInfo(policyNftId);
|
@@ -229,7 +231,7 @@ contract PolicyService is
|
|
229
231
|
policyInfo.activatedAt = activateAt;
|
230
232
|
policyInfo.expiredAt = activateAt.addSeconds(policyInfo.lifetime);
|
231
233
|
|
232
|
-
instance.updatePolicy(policyNftId, policyInfo, ACTIVE());
|
234
|
+
instance.getInstanceStore().updatePolicy(policyNftId, policyInfo, ACTIVE());
|
233
235
|
|
234
236
|
// TODO: add logging
|
235
237
|
}
|
@@ -251,7 +253,7 @@ contract PolicyService is
|
|
251
253
|
external
|
252
254
|
override
|
253
255
|
{
|
254
|
-
(,, IInstance instance) =
|
256
|
+
(,, IInstance instance) = _getAndVerifyCallingComponentAndInstance(PRODUCT());
|
255
257
|
InstanceReader instanceReader = instance.getInstanceReader();
|
256
258
|
|
257
259
|
IPolicy.PolicyInfo memory policyInfo = instanceReader.getPolicyInfo(policyNftId);
|
@@ -269,18 +271,15 @@ contract PolicyService is
|
|
269
271
|
revert ErrorIPolicyServicePolicyAlreadyClosed(policyNftId);
|
270
272
|
}
|
271
273
|
|
272
|
-
|
273
|
-
|
274
|
+
// TODO consider to allow for underpaid premiums (with the effects of reducing max payouts accordingly)
|
275
|
+
if (!(policyInfo.premiumAmount == policyInfo.premiumPaidAmount)) {
|
276
|
+
revert ErrorPolicyServicePremiumNotFullyPaid(policyNftId, policyInfo.premiumAmount, policyInfo.premiumPaidAmount);
|
274
277
|
}
|
275
278
|
|
276
279
|
if (policyInfo.openClaimsCount > 0) {
|
277
280
|
revert ErrorIPolicyServiceOpenClaims(policyNftId, policyInfo.openClaimsCount);
|
278
281
|
}
|
279
282
|
|
280
|
-
if (TimestampLib.blockTimestamp().lte(policyInfo.expiredAt) && (policyInfo.payoutAmount < policyInfo.sumInsuredAmount)) {
|
281
|
-
revert ErrorIPolicyServicePolicyHasNotExpired(policyNftId, policyInfo.expiredAt);
|
282
|
-
}
|
283
|
-
|
284
283
|
policyInfo.closedAt = TimestampLib.blockTimestamp();
|
285
284
|
|
286
285
|
_poolService.releaseCollateral(
|
@@ -288,75 +287,90 @@ contract PolicyService is
|
|
288
287
|
policyNftId,
|
289
288
|
policyInfo);
|
290
289
|
|
291
|
-
instance.updatePolicy(policyNftId, policyInfo, CLOSED());
|
292
|
-
}
|
293
|
-
|
294
|
-
function _getPoolNftId(
|
295
|
-
IInstance instance,
|
296
|
-
NftId productNftId
|
297
|
-
)
|
298
|
-
internal
|
299
|
-
view
|
300
|
-
returns (NftId poolNftid)
|
301
|
-
{
|
302
|
-
InstanceReader instanceReader = instance.getInstanceReader();
|
303
|
-
ISetup.ProductSetupInfo memory productSetupInfo = instanceReader.getProductSetupInfo(productNftId);
|
304
|
-
return productSetupInfo.poolNftId;
|
290
|
+
instance.getInstanceStore().updatePolicy(policyNftId, policyInfo, CLOSED());
|
305
291
|
}
|
306
292
|
|
307
293
|
|
308
294
|
function _processPremiumByTreasury(
|
309
295
|
IInstance instance,
|
310
296
|
NftId policyNftId,
|
311
|
-
|
297
|
+
Amount premiumExpectedAmount
|
312
298
|
)
|
313
299
|
internal
|
314
|
-
returns (
|
300
|
+
returns (Amount netPremiumAmount)
|
315
301
|
{
|
316
302
|
// process token transfer(s)
|
317
|
-
if(
|
318
|
-
|
319
|
-
|
320
|
-
|
321
|
-
|
322
|
-
|
323
|
-
|
324
|
-
|
325
|
-
|
326
|
-
|
327
|
-
|
328
|
-
|
329
|
-
|
330
|
-
|
331
|
-
|
332
|
-
|
333
|
-
|
334
|
-
|
335
|
-
|
336
|
-
|
303
|
+
if(premiumExpectedAmount.eqz()) {
|
304
|
+
return AmountLib.zero();
|
305
|
+
}
|
306
|
+
|
307
|
+
NftId productNftId = getRegistry().getObjectInfo(policyNftId).parentNftId;
|
308
|
+
IPolicy.PolicyInfo memory policyInfo = instance.getInstanceReader().getPolicyInfo(policyNftId);
|
309
|
+
IPolicy.Premium memory premium = _pricingService.calculatePremium(
|
310
|
+
productNftId,
|
311
|
+
policyInfo.riskId,
|
312
|
+
policyInfo.sumInsuredAmount,
|
313
|
+
policyInfo.lifetime,
|
314
|
+
policyInfo.applicationData,
|
315
|
+
policyInfo.bundleNftId,
|
316
|
+
policyInfo.referralId
|
317
|
+
);
|
318
|
+
|
319
|
+
if (premium.premiumAmount != premiumExpectedAmount.toInt()) {
|
320
|
+
revert ErrorPolicyServicePremiumMismatch(
|
321
|
+
policyNftId,
|
322
|
+
premiumExpectedAmount,
|
323
|
+
AmountLib.toAmount(premium.premiumAmount));
|
324
|
+
}
|
325
|
+
|
326
|
+
address policyOwner = getRegistry().ownerOf(policyNftId);
|
327
|
+
ISetup.ProductSetupInfo memory productSetupInfo = instance.getInstanceReader().getProductSetupInfo(productNftId);
|
328
|
+
TokenHandler tokenHandler = productSetupInfo.tokenHandler;
|
329
|
+
if (tokenHandler.getToken().allowance(policyOwner, address(tokenHandler)) < premium.premiumAmount) {
|
330
|
+
revert ErrorIPolicyServiceInsufficientAllowance(policyOwner, address(tokenHandler), premium.premiumAmount);
|
331
|
+
}
|
337
332
|
|
338
|
-
|
333
|
+
Amount productFeeAmountToTransfer = AmountLib.toAmount(premium.productFeeFixAmount + premium.productFeeVarAmount);
|
334
|
+
Amount distributionFeeAmountToTransfer = AmountLib.toAmount(premium.distributionFeeFixAmount + premium.distributionFeeVarAmount - premium.discountAmount);
|
335
|
+
uint256 poolFeeAmountToTransfer = premium.poolFeeFixAmount + premium.poolFeeVarAmount;
|
336
|
+
uint256 bundleFeeAmountToTransfer = premium.bundleFeeFixAmount + premium.bundleFeeVarAmount;
|
337
|
+
Amount poolAmountToTransfer = AmountLib.toAmount(premium.netPremiumAmount + poolFeeAmountToTransfer + bundleFeeAmountToTransfer);
|
338
|
+
|
339
|
+
netPremiumAmount = AmountLib.toAmount(premium.netPremiumAmount);
|
340
|
+
|
341
|
+
// move product fee to product wallet
|
342
|
+
{
|
339
343
|
address productWallet = productSetupInfo.wallet;
|
340
|
-
|
341
|
-
|
342
|
-
}
|
343
|
-
tokenHandler.transfer(policyOwner, productWallet, premium.productFeeFixAmount + premium.productFeeVarAmount);
|
344
|
+
tokenHandler.transfer(policyOwner, productWallet, productFeeAmountToTransfer);
|
345
|
+
}
|
344
346
|
|
345
|
-
|
347
|
+
// move distribution fee to distribution wallet
|
348
|
+
{
|
346
349
|
ISetup.DistributionSetupInfo memory distributionSetupInfo = instance.getInstanceReader().getDistributionSetupInfo(productSetupInfo.distributionNftId);
|
347
350
|
address distributionWallet = distributionSetupInfo.wallet;
|
348
|
-
uint256 distributionFeeAmountToTransfer = premium.distributionFeeFixAmount + premium.distributionFeeVarAmount - premium.discountAmount;
|
349
351
|
tokenHandler.transfer(policyOwner, distributionWallet, distributionFeeAmountToTransfer);
|
350
352
|
_distributionService.processSale(productSetupInfo.distributionNftId, policyInfo.referralId, premium, distributionFeeAmountToTransfer);
|
351
|
-
|
352
|
-
|
353
|
-
|
354
|
-
|
355
|
-
|
356
|
-
|
357
|
-
|
353
|
+
}
|
354
|
+
|
355
|
+
// move netpremium, bundleFee and poolFee to pool wallet
|
356
|
+
{
|
357
|
+
address poolWallet = instance.getInstanceReader().getComponentInfo(productSetupInfo.poolNftId).wallet;
|
358
|
+
tokenHandler.transfer(policyOwner, poolWallet, poolAmountToTransfer);
|
359
|
+
_poolService.processSale(policyInfo.bundleNftId, premium, poolAmountToTransfer);
|
360
|
+
}
|
361
|
+
|
362
|
+
// validate total amount transferred
|
363
|
+
{
|
364
|
+
Amount totalTransferred = distributionFeeAmountToTransfer + poolAmountToTransfer + productFeeAmountToTransfer;
|
365
|
+
|
366
|
+
if (premium.premiumAmount != totalTransferred.toInt()) {
|
367
|
+
revert ErrorPolicyServiceTransferredPremiumMismatch(
|
368
|
+
policyNftId,
|
369
|
+
AmountLib.toAmount(premium.premiumAmount),
|
370
|
+
totalTransferred);
|
371
|
+
}
|
358
372
|
}
|
359
373
|
|
360
374
|
// TODO: add logging
|
361
375
|
}
|
362
|
-
}
|
376
|
+
}
|