@etherisc/gif-next 0.0.2-ce8407f-016 → 0.0.2-cf68d0c-530
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 +108 -1
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +4 -0
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.json +327 -0
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +4 -0
- package/artifacts/contracts/components/Distribution.sol/Distribution.json +670 -0
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.json +39 -0
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +4 -0
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +204 -0
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +249 -0
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +4 -0
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +157 -0
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +4 -0
- package/artifacts/contracts/components/Pool.sol/Pool.json +790 -0
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +4 -0
- package/artifacts/contracts/components/Product.sol/Product.json +775 -0
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.dbg.json +4 -0
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.json +66 -0
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.dbg.json +4 -0
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.json +24 -0
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.dbg.json +4 -0
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.json +42 -0
- package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +1 -1
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +1 -1
- package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.dbg.json +1 -1
- package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +2 -2
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +1 -1
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +1 -1
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +1 -1
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.json +2 -2
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +1 -1
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.json +2 -2
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +1 -1
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +1 -1
- package/artifacts/contracts/instance/AccessManagedSimple.sol/AccessManagedSimple.dbg.json +1 -1
- package/artifacts/contracts/instance/AccessManagerSimple.sol/AccessManagerSimple.dbg.json +1 -1
- package/artifacts/contracts/instance/AccessManagerSimple.sol/AccessManagerSimple.json +15 -2
- package/artifacts/contracts/instance/IAccessManagerSimple.sol/IAccessManagerSimple.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +435 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +4 -0
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +480 -0
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +491 -495
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +34 -34
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +438 -33
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +726 -16
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +468 -0
- package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.json +481 -0
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +4 -0
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.json +113 -0
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.json +0 -77
- 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 +10 -244
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.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/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/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +827 -0
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +641 -0
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +428 -0
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.json +466 -0
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.json +446 -0
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +561 -0
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.json +751 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +47 -2
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +292 -103
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +123 -15
- 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 +249 -143
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +272 -48
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +79 -30
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +4 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +410 -0
- 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/ERC165.sol/ERC165.json +2 -2
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +4 -0
- package/artifacts/contracts/{instance/base → shared}/IService.sol/IService.json +1 -1
- 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 +2 -2
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +2 -2
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +6 -6
- package/artifacts/contracts/shared/RegisterableUpgradable.sol/RegisterableUpgradable.dbg.json +4 -0
- package/artifacts/contracts/shared/RegisterableUpgradable.sol/RegisterableUpgradable.json +442 -0
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +4 -0
- package/artifacts/contracts/{instance/base/ServiceBase.sol/ServiceBase.json → shared/Service.sol/Service.json} +2 -2
- 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/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +2 -2
- 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 +4 -4
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +1 -1
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +6 -6
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +1 -1
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +111 -5
- package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +1 -1
- package/artifacts/contracts/test/TestService.sol/TestService.json +17 -17
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +1 -1
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +91 -53
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +1 -1
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +2 -2
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +1 -1
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +2 -2
- package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +1 -1
- package/artifacts/contracts/test/Usdc.sol/USDC.json +91 -53
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- 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/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
- package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/types/Fee.sol/FeeLib.json +4 -4
- package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- 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/Referral.sol/ReferralLib.dbg.json +1 -1
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +1 -1
- 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/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/UFixed.sol/MathLib.dbg.json +4 -0
- package/artifacts/contracts/types/UFixed.sol/MathLib.json +10 -0
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +4 -0
- package/artifacts/contracts/types/UFixed.sol/{UFixedMathLib.json → UFixedLib.json} +3 -3
- package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/types/Version.sol/VersionLib.json +2 -2
- package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/types/Version.sol/VersionPartLib.json +22 -3
- package/contracts/components/BaseComponent.sol +91 -0
- package/contracts/components/Distribution.sol +166 -0
- package/contracts/components/IBaseComponent.sol +8 -2
- package/contracts/components/IDistributionComponent.sol +46 -0
- package/contracts/components/IPoolComponent.sol +62 -0
- package/contracts/components/IProductComponent.sol +35 -0
- package/contracts/components/Pool.sol +258 -0
- package/contracts/components/Product.sol +297 -0
- package/contracts/experiment/cloning/Cloner.sol +47 -0
- package/contracts/instance/AccessManagedSimple.sol +9 -8
- package/contracts/instance/AccessManagerSimple.sol +12 -2
- package/contracts/instance/IAccessManagerSimple.sol +1 -1
- package/contracts/instance/IInstance.sol +28 -1
- package/contracts/instance/IInstanceService.sol +30 -0
- package/contracts/instance/Instance.sol +61 -10
- package/contracts/instance/InstanceAccessManager.sol +3 -3
- package/contracts/instance/InstanceReader.sol +63 -8
- package/contracts/instance/InstanceService.sol +131 -18
- package/contracts/instance/InstanceServiceManager.sol +56 -0
- package/contracts/instance/base/ComponentServiceBase.sol +39 -0
- package/contracts/instance/base/IInstanceBase.sol +23 -0
- package/contracts/instance/base/IKeyValueStore.sol +5 -4
- package/contracts/instance/base/KeyValueStore.sol +4 -20
- package/contracts/instance/module/IAccess.sol +2 -2
- package/contracts/instance/module/ISetup.sol +3 -1
- package/contracts/instance/module/ITreasury.sol +1 -1
- package/contracts/instance/service/ComponentOwnerService.sol +317 -0
- package/contracts/instance/service/DistributionService.sol +96 -0
- package/contracts/instance/service/DistributionServiceManager.sol +53 -0
- package/contracts/instance/service/IComponentOwnerService.sol +20 -0
- package/contracts/instance/service/IDistributionService.sol +12 -0
- package/contracts/instance/service/IPoolService.sol +37 -0
- package/contracts/instance/service/IProductService.sol +107 -0
- package/contracts/registry/ChainNft.sol +40 -25
- package/contracts/registry/IRegistry.sol +43 -22
- package/contracts/registry/IRegistryService.sol +16 -12
- package/contracts/registry/Registry.sol +163 -165
- package/contracts/registry/RegistryService.sol +168 -138
- package/contracts/registry/RegistryServiceManager.sol +39 -2
- package/contracts/registry/TokenRegistry.sol +111 -0
- package/contracts/shared/ERC165.sol +7 -3
- package/contracts/shared/IRegisterable.sol +1 -1
- package/contracts/{instance/base → shared}/IService.sol +3 -3
- package/contracts/shared/ProxyManager.sol +3 -3
- package/contracts/shared/Registerable.sol +3 -2
- package/contracts/shared/RegisterableUpgradable.sol +16 -0
- package/contracts/shared/Service.sol +54 -0
- package/contracts/shared/TokenHandler.sol +2 -2
- package/contracts/shared/UpgradableProxyWithAdmin.sol +2 -2
- package/contracts/shared/Versionable.sol +1 -1
- package/contracts/test/TestFee.sol +2 -2
- package/contracts/test/TestRoleId.sol +6 -6
- package/contracts/test/TestService.sol +3 -5
- package/contracts/types/Fee.sol +3 -3
- package/contracts/types/RoleId.sol +17 -4
- package/contracts/types/StateId.sol +4 -0
- package/contracts/types/UFixed.sol +128 -12
- package/contracts/types/Version.sol +4 -1
- package/package.json +4 -3
- package/artifacts/contracts/instance/base/IService.sol/IService.dbg.json +0 -4
- package/artifacts/contracts/instance/base/ServiceBase.sol/ServiceBase.dbg.json +0 -4
- package/artifacts/contracts/registry/IChainNft.sol/IChainNft.dbg.json +0 -4
- package/artifacts/contracts/registry/IChainNft.sol/IChainNft.json +0 -457
- package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.dbg.json +0 -4
- package/contracts/instance/base/ServiceBase.sol +0 -44
- package/contracts/registry/IChainNft.sol +0 -22
@@ -0,0 +1,46 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.19;
|
3
|
+
|
4
|
+
import {Fee} from "../types/Fee.sol";
|
5
|
+
import {ReferralId} from "../types/Referral.sol";
|
6
|
+
import {NftId} from "../types/NftId.sol";
|
7
|
+
import {ISetup} from "../instance/module/ISetup.sol";
|
8
|
+
|
9
|
+
interface IDistributionComponent {
|
10
|
+
|
11
|
+
function getInitialSetupInfo() external view returns (ISetup.DistributionSetupInfo memory setupInfo);
|
12
|
+
|
13
|
+
function setFees(
|
14
|
+
Fee memory distributionFee
|
15
|
+
) external;
|
16
|
+
|
17
|
+
function calculateFeeAmount(
|
18
|
+
ReferralId referralId,
|
19
|
+
uint256 netPremiumAmount
|
20
|
+
) external view returns (uint256 feeAmount);
|
21
|
+
|
22
|
+
function calculateRenewalFeeAmount(
|
23
|
+
ReferralId referralId,
|
24
|
+
uint256 netPremiumAmount
|
25
|
+
) external view returns (uint256 feeAmount);
|
26
|
+
|
27
|
+
/// @dev callback from product service when selling a policy for a specific referralId
|
28
|
+
/// the used referral id and the collected fee are provided as parameters
|
29
|
+
/// the component implementation can then process this information accordingly
|
30
|
+
function processSale(
|
31
|
+
ReferralId referralId,
|
32
|
+
uint256 feeAmount
|
33
|
+
) external;
|
34
|
+
|
35
|
+
/// @dev callback from product service when a policy is renews for a specific referralId
|
36
|
+
function processRenewal(
|
37
|
+
ReferralId referralId,
|
38
|
+
uint256 feeAmount
|
39
|
+
) external;
|
40
|
+
|
41
|
+
/// @dev returns true iff the referral id is valid
|
42
|
+
function referralIsValid(ReferralId referralId) external view returns (bool isValid);
|
43
|
+
|
44
|
+
/// @dev returns true iff the component needs to be called when selling/renewing policis
|
45
|
+
function isVerifying() external view returns (bool verifying);
|
46
|
+
}
|
@@ -0,0 +1,62 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {NftId} from "../types/NftId.sol";
|
5
|
+
import {Fee} from "../types/Fee.sol";
|
6
|
+
import {UFixed} from "../types/UFixed.sol";
|
7
|
+
|
8
|
+
interface IPoolComponent {
|
9
|
+
|
10
|
+
event LogUnderwrittenByPool(NftId policyNftId, uint256 collateralizationAmount, address pool);
|
11
|
+
|
12
|
+
function setFees(
|
13
|
+
Fee memory poolFee,
|
14
|
+
Fee memory stakingFee,
|
15
|
+
Fee memory performanceFee
|
16
|
+
) external;
|
17
|
+
|
18
|
+
/**
|
19
|
+
* @dev creates a new bundle for this pool.
|
20
|
+
*/
|
21
|
+
function createBundle(
|
22
|
+
Fee memory fee,
|
23
|
+
uint256 initialAmount,
|
24
|
+
uint256 lifetime,
|
25
|
+
bytes memory filter
|
26
|
+
) external returns(NftId bundleNftId);
|
27
|
+
|
28
|
+
function setBundleFee(
|
29
|
+
NftId policyNftId,
|
30
|
+
Fee memory fee
|
31
|
+
) external;
|
32
|
+
|
33
|
+
/**
|
34
|
+
* @dev this is a callback function that is called by the product service when underwriting a policy.
|
35
|
+
* the pool has the option to check the details and object to underwriting by reverting.
|
36
|
+
* the function is only called for "active" pools that ask to be involved/notified
|
37
|
+
* by product related state changes.
|
38
|
+
*/
|
39
|
+
function underwrite(
|
40
|
+
NftId policyNftId,
|
41
|
+
bytes memory policyData,
|
42
|
+
bytes memory bundleFilter,
|
43
|
+
uint256 collateralizationAmount
|
44
|
+
) external;
|
45
|
+
|
46
|
+
/**
|
47
|
+
* @dev returns true iff the policy application data in policyData matches
|
48
|
+
* with the bundle filter criteria encoded in bundleFilter.
|
49
|
+
*/
|
50
|
+
function policyMatchesBundle(
|
51
|
+
bytes memory policyData,
|
52
|
+
bytes memory bundleFilter
|
53
|
+
)
|
54
|
+
external
|
55
|
+
view
|
56
|
+
returns (bool isMatching);
|
57
|
+
|
58
|
+
function isVerifying() external view returns (bool verifying);
|
59
|
+
|
60
|
+
function getCollateralizationLevel() external view returns (UFixed collateralizationLevel);
|
61
|
+
|
62
|
+
}
|
@@ -0,0 +1,35 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {Fee} from "../types/Fee.sol";
|
5
|
+
import {NftId} from "../types/NftId.sol";
|
6
|
+
import {ReferralId} from "../types/Referral.sol";
|
7
|
+
import {RiskId} from "../types/RiskId.sol";
|
8
|
+
|
9
|
+
interface IProductComponent {
|
10
|
+
|
11
|
+
function setFees(
|
12
|
+
Fee memory productFee,
|
13
|
+
Fee memory processingFee
|
14
|
+
) external;
|
15
|
+
|
16
|
+
function calculatePremium(
|
17
|
+
uint256 sumInsuredAmount,
|
18
|
+
RiskId riskId,
|
19
|
+
uint256 lifetime,
|
20
|
+
bytes memory applicationData,
|
21
|
+
ReferralId referralId,
|
22
|
+
NftId bundleNftId
|
23
|
+
) external view returns (uint256 premiumAmount);
|
24
|
+
|
25
|
+
function calculateNetPremium(
|
26
|
+
uint256 sumInsuredAmount,
|
27
|
+
RiskId riskId,
|
28
|
+
uint256 lifetime,
|
29
|
+
bytes memory applicationData
|
30
|
+
) external view returns (uint256 netPremiumAmount);
|
31
|
+
|
32
|
+
|
33
|
+
function getPoolNftId() external view returns (NftId poolNftId);
|
34
|
+
function getDistributionNftId() external view returns (NftId distributionNftId);
|
35
|
+
}
|
@@ -0,0 +1,258 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {ObjectType, POOL} from "../types/ObjectType.sol";
|
5
|
+
import {IProductService} from "../instance/service/IProductService.sol";
|
6
|
+
import {IPoolService} from "../instance/service/IPoolService.sol";
|
7
|
+
import {NftId, zeroNftId, NftIdLib} from "../types/NftId.sol";
|
8
|
+
import {Fee} from "../types/Fee.sol";
|
9
|
+
import {UFixed} from "../types/UFixed.sol";
|
10
|
+
import {IPoolComponent} from "./IPoolComponent.sol";
|
11
|
+
import {BaseComponent} from "./BaseComponent.sol";
|
12
|
+
import {TokenHandler} from "../shared/TokenHandler.sol";
|
13
|
+
import {ISetup} from "../instance/module/ISetup.sol";
|
14
|
+
|
15
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
16
|
+
|
17
|
+
// import {IPool} from "../instance/module/pool/IPoolModule.sol";
|
18
|
+
import {ITreasury} from "../instance/module/ITreasury.sol";
|
19
|
+
import {ISetup} from "../instance/module/ISetup.sol";
|
20
|
+
import {InstanceReader} from "../instance/InstanceReader.sol";
|
21
|
+
|
22
|
+
import {IRegisterable} from "../shared/IRegisterable.sol";
|
23
|
+
import {Registerable} from "../shared/Registerable.sol";
|
24
|
+
|
25
|
+
contract Pool is BaseComponent, IPoolComponent {
|
26
|
+
using NftIdLib for NftId;
|
27
|
+
|
28
|
+
bool internal _isVerifying;
|
29
|
+
UFixed internal _collateralizationLevel;
|
30
|
+
|
31
|
+
Fee internal _initialPoolFee;
|
32
|
+
Fee internal _initialStakingFee;
|
33
|
+
Fee internal _initialPerformanceFee;
|
34
|
+
|
35
|
+
// may be used to interact with instance by derived contracts
|
36
|
+
IPoolService internal _poolService;
|
37
|
+
|
38
|
+
// only relevant to protect callback functions for "active" pools
|
39
|
+
IProductService private _productService;
|
40
|
+
|
41
|
+
modifier onlyPoolService() {
|
42
|
+
require(
|
43
|
+
msg.sender == address(_poolService),
|
44
|
+
"ERROR:POL-001:NOT_POOL_SERVICE");
|
45
|
+
_;
|
46
|
+
}
|
47
|
+
|
48
|
+
modifier onlyProductService() {
|
49
|
+
require(
|
50
|
+
msg.sender == address(_productService),
|
51
|
+
"ERROR:POL-002:NOT_PRODUCT_SERVICE");
|
52
|
+
_;
|
53
|
+
}
|
54
|
+
|
55
|
+
constructor(
|
56
|
+
address registry,
|
57
|
+
NftId instanceNftId,
|
58
|
+
// TODO refactor into tokenNftId
|
59
|
+
address token,
|
60
|
+
bool isInterceptor,
|
61
|
+
bool verifying,
|
62
|
+
UFixed collateralizationLevel,
|
63
|
+
Fee memory poolFee,
|
64
|
+
Fee memory stakingFee,
|
65
|
+
Fee memory performanceFee,
|
66
|
+
address initialOwner
|
67
|
+
)
|
68
|
+
BaseComponent(registry, instanceNftId, token, POOL(), isInterceptor, initialOwner)
|
69
|
+
{
|
70
|
+
_isVerifying = verifying;
|
71
|
+
// TODO add validation
|
72
|
+
_collateralizationLevel = collateralizationLevel;
|
73
|
+
_initialPoolFee = poolFee;
|
74
|
+
_initialStakingFee = stakingFee;
|
75
|
+
_initialPerformanceFee = performanceFee;
|
76
|
+
|
77
|
+
// TODO: reactivate when services are available again
|
78
|
+
// _poolService = _instance.getPoolService();
|
79
|
+
// _productService = _instance.getProductService();
|
80
|
+
|
81
|
+
_registerInterface(type(IPoolComponent).interfaceId);
|
82
|
+
}
|
83
|
+
|
84
|
+
function createBundle(
|
85
|
+
Fee memory fee,
|
86
|
+
uint256 initialAmount,
|
87
|
+
uint256 lifetime,
|
88
|
+
bytes memory filter
|
89
|
+
)
|
90
|
+
external
|
91
|
+
virtual override
|
92
|
+
returns(NftId bundleNftId)
|
93
|
+
{
|
94
|
+
address owner = msg.sender;
|
95
|
+
bundleNftId = _poolService.createBundle(
|
96
|
+
owner,
|
97
|
+
fee,
|
98
|
+
initialAmount,
|
99
|
+
lifetime,
|
100
|
+
filter
|
101
|
+
);
|
102
|
+
|
103
|
+
// TODO add logging
|
104
|
+
}
|
105
|
+
|
106
|
+
/**
|
107
|
+
* @dev see {IPool.underwrite}.
|
108
|
+
* Default implementation that only writes a {LogUnderwrittenByPool} entry.
|
109
|
+
*/
|
110
|
+
function underwrite(
|
111
|
+
NftId policyNftId,
|
112
|
+
bytes memory policyData,
|
113
|
+
bytes memory bundleFilter,
|
114
|
+
uint256 collateralizationAmount
|
115
|
+
)
|
116
|
+
external
|
117
|
+
onlyProductService
|
118
|
+
virtual override
|
119
|
+
{
|
120
|
+
_underwrite(policyNftId, policyData, bundleFilter, collateralizationAmount);
|
121
|
+
}
|
122
|
+
|
123
|
+
/**
|
124
|
+
* @dev see {IPoolComponent.policyMatchesBundle}.
|
125
|
+
* Default implementation always returns true
|
126
|
+
*/
|
127
|
+
function policyMatchesBundle(
|
128
|
+
bytes memory, // policyData
|
129
|
+
bytes memory // bundleFilter
|
130
|
+
)
|
131
|
+
public
|
132
|
+
view
|
133
|
+
virtual override
|
134
|
+
returns (bool isMatching)
|
135
|
+
{
|
136
|
+
return true;
|
137
|
+
}
|
138
|
+
|
139
|
+
|
140
|
+
function isVerifying() external view override returns (bool verifying) {
|
141
|
+
return _isVerifying;
|
142
|
+
}
|
143
|
+
|
144
|
+
function getCollateralizationLevel() external view override returns (UFixed collateralizationLevel) {
|
145
|
+
return _collateralizationLevel;
|
146
|
+
}
|
147
|
+
|
148
|
+
function setFees(
|
149
|
+
Fee memory poolFee,
|
150
|
+
Fee memory stakingFee,
|
151
|
+
Fee memory performanceFee
|
152
|
+
)
|
153
|
+
external
|
154
|
+
onlyOwner
|
155
|
+
override
|
156
|
+
{
|
157
|
+
_poolService.setFees(poolFee, stakingFee, performanceFee);
|
158
|
+
}
|
159
|
+
|
160
|
+
function setBundleFee(
|
161
|
+
NftId bundleNftId,
|
162
|
+
Fee memory fee
|
163
|
+
)
|
164
|
+
external
|
165
|
+
override
|
166
|
+
// TODO add onlyBundleOwner
|
167
|
+
{
|
168
|
+
_poolService.setBundleFee(bundleNftId, fee);
|
169
|
+
}
|
170
|
+
|
171
|
+
function getSetupInfo() public view returns (ISetup.PoolSetupInfo memory setupInfo) {
|
172
|
+
// TODO fix this
|
173
|
+
if (getNftId().eq(zeroNftId())) {
|
174
|
+
return ISetup.PoolSetupInfo(
|
175
|
+
_productNftId,
|
176
|
+
TokenHandler(address(0)),
|
177
|
+
_collateralizationLevel,
|
178
|
+
_initialPoolFee,
|
179
|
+
_initialStakingFee,
|
180
|
+
_initialPerformanceFee,
|
181
|
+
_isVerifying,
|
182
|
+
_wallet
|
183
|
+
);
|
184
|
+
}
|
185
|
+
|
186
|
+
InstanceReader reader = _instance.getInstanceReader();
|
187
|
+
return reader.getPoolSetupInfo(getNftId());
|
188
|
+
}
|
189
|
+
|
190
|
+
// from IRegisterable
|
191
|
+
|
192
|
+
// TODO used only once, occupies space
|
193
|
+
// TODO do not use super
|
194
|
+
function getInitialInfo()
|
195
|
+
public
|
196
|
+
view
|
197
|
+
override (IRegisterable, Registerable)
|
198
|
+
returns (IRegistry.ObjectInfo memory, bytes memory)
|
199
|
+
{
|
200
|
+
(
|
201
|
+
IRegistry.ObjectInfo memory info,
|
202
|
+
bytes memory data
|
203
|
+
) = super.getInitialInfo();
|
204
|
+
|
205
|
+
return (
|
206
|
+
info,
|
207
|
+
abi.encode(
|
208
|
+
ISetup.PoolSetupInfo(
|
209
|
+
getProductNftId(),
|
210
|
+
TokenHandler(address(0)),
|
211
|
+
_collateralizationLevel,
|
212
|
+
_initialPoolFee,
|
213
|
+
_initialStakingFee,
|
214
|
+
_initialPerformanceFee,
|
215
|
+
_isVerifying,
|
216
|
+
_wallet
|
217
|
+
)
|
218
|
+
)
|
219
|
+
);
|
220
|
+
}
|
221
|
+
|
222
|
+
// Internals
|
223
|
+
|
224
|
+
function _underwrite(
|
225
|
+
NftId policyNftId,
|
226
|
+
bytes memory policyData,
|
227
|
+
bytes memory bundleFilter,
|
228
|
+
uint256 collateralizationAmount
|
229
|
+
)
|
230
|
+
internal
|
231
|
+
{
|
232
|
+
require(
|
233
|
+
policyMatchesBundle(policyData, bundleFilter),
|
234
|
+
"ERROR:POL-020:POLICY_BUNDLE_MISMATCH"
|
235
|
+
);
|
236
|
+
|
237
|
+
emit LogUnderwrittenByPool(policyNftId, collateralizationAmount, address(this));
|
238
|
+
}
|
239
|
+
|
240
|
+
function _createBundle(
|
241
|
+
address bundleOwner,
|
242
|
+
Fee memory fee,
|
243
|
+
uint256 amount,
|
244
|
+
uint256 lifetime,
|
245
|
+
bytes calldata filter
|
246
|
+
)
|
247
|
+
internal
|
248
|
+
returns(NftId bundleNftId)
|
249
|
+
{
|
250
|
+
bundleNftId = _poolService.createBundle(
|
251
|
+
bundleOwner,
|
252
|
+
fee,
|
253
|
+
amount,
|
254
|
+
lifetime,
|
255
|
+
filter
|
256
|
+
);
|
257
|
+
}
|
258
|
+
}
|
@@ -0,0 +1,297 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.19;
|
3
|
+
|
4
|
+
import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
|
5
|
+
|
6
|
+
import {IRisk} from "../instance/module/IRisk.sol";
|
7
|
+
import {ITreasury} from "../instance/module/ITreasury.sol";
|
8
|
+
import {IProductService} from "../instance/service/IProductService.sol";
|
9
|
+
import {IProductComponent} from "./IProductComponent.sol";
|
10
|
+
import {NftId, zeroNftId, NftIdLib} from "../types/NftId.sol";
|
11
|
+
import {ObjectType, PRODUCT} from "../types/ObjectType.sol";
|
12
|
+
import {ReferralId} from "../types/Referral.sol";
|
13
|
+
import {RiskId, RiskIdLib} from "../types/RiskId.sol";
|
14
|
+
import {StateId} from "../types/StateId.sol";
|
15
|
+
import {Timestamp} from "../types/Timestamp.sol";
|
16
|
+
import {Fee, FeeLib} from "../types/Fee.sol";
|
17
|
+
import {BaseComponent} from "./BaseComponent.sol";
|
18
|
+
|
19
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
20
|
+
import {IRegisterable} from "../shared/IRegisterable.sol";
|
21
|
+
import {Registerable} from "../shared/Registerable.sol";
|
22
|
+
import {TokenHandler} from "../shared/TokenHandler.sol";
|
23
|
+
|
24
|
+
import {InstanceReader} from "../instance/InstanceReader.sol";
|
25
|
+
import {ISetup} from "../instance/module/ISetup.sol";
|
26
|
+
import {Pool} from "../components/Pool.sol";
|
27
|
+
|
28
|
+
import {zeroNftId} from "../types/NftId.sol";
|
29
|
+
|
30
|
+
contract Product is BaseComponent, IProductComponent {
|
31
|
+
using NftIdLib for NftId;
|
32
|
+
|
33
|
+
IProductService internal _productService;
|
34
|
+
Pool internal _pool;
|
35
|
+
address internal _distribution;
|
36
|
+
Fee internal _initialProductFee;
|
37
|
+
Fee internal _initialProcessingFee;
|
38
|
+
|
39
|
+
NftId internal _poolNftId;
|
40
|
+
NftId internal _distributionNftId;
|
41
|
+
|
42
|
+
constructor(
|
43
|
+
address registry,
|
44
|
+
NftId instanceNftid,
|
45
|
+
address token,
|
46
|
+
bool isInterceptor,
|
47
|
+
address pool,
|
48
|
+
address distribution,
|
49
|
+
Fee memory productFee,
|
50
|
+
Fee memory processingFee,
|
51
|
+
address initialOwner
|
52
|
+
) BaseComponent(registry, instanceNftid, token, PRODUCT(), isInterceptor, initialOwner) {
|
53
|
+
// TODO add validation
|
54
|
+
// TODO: reactivate when services are available again
|
55
|
+
// _productService = _instance.getProductService();
|
56
|
+
_pool = Pool(pool);
|
57
|
+
_distribution = distribution;
|
58
|
+
_initialProductFee = productFee;
|
59
|
+
_initialProcessingFee = processingFee;
|
60
|
+
|
61
|
+
_poolNftId = getRegistry().getNftId(address(_pool));
|
62
|
+
_distributionNftId = getRegistry().getNftId(_distribution);
|
63
|
+
|
64
|
+
_registerInterface(type(IProductComponent).interfaceId);
|
65
|
+
}
|
66
|
+
|
67
|
+
|
68
|
+
function calculatePremium(
|
69
|
+
uint256 sumInsuredAmount,
|
70
|
+
RiskId riskId,
|
71
|
+
uint256 lifetime,
|
72
|
+
bytes memory applicationData,
|
73
|
+
ReferralId referralId,
|
74
|
+
NftId bundleNftId
|
75
|
+
)
|
76
|
+
external
|
77
|
+
view
|
78
|
+
override
|
79
|
+
returns (uint256 premiumAmount)
|
80
|
+
{
|
81
|
+
(premiumAmount,,,,) = _productService.calculatePremium(
|
82
|
+
riskId,
|
83
|
+
sumInsuredAmount,
|
84
|
+
lifetime,
|
85
|
+
applicationData,
|
86
|
+
bundleNftId,
|
87
|
+
referralId
|
88
|
+
);
|
89
|
+
}
|
90
|
+
|
91
|
+
|
92
|
+
function calculateNetPremium(
|
93
|
+
uint256 sumInsuredAmount,
|
94
|
+
RiskId riskId,
|
95
|
+
uint256 lifetime,
|
96
|
+
bytes memory applicationData
|
97
|
+
)
|
98
|
+
external
|
99
|
+
view
|
100
|
+
virtual override
|
101
|
+
returns (uint256 netPremiumAmount)
|
102
|
+
{
|
103
|
+
// default 10% of sum insured
|
104
|
+
return sumInsuredAmount / 10;
|
105
|
+
}
|
106
|
+
|
107
|
+
function _toRiskId(string memory riskName) internal pure returns (RiskId riskId) {
|
108
|
+
return RiskIdLib.toRiskId(riskName);
|
109
|
+
}
|
110
|
+
|
111
|
+
function _createRisk(
|
112
|
+
RiskId id,
|
113
|
+
bytes memory data
|
114
|
+
) internal {
|
115
|
+
_productService.createRisk(
|
116
|
+
id,
|
117
|
+
data
|
118
|
+
);
|
119
|
+
}
|
120
|
+
|
121
|
+
function _setRiskInfo(
|
122
|
+
RiskId id,
|
123
|
+
IRisk.RiskInfo memory info
|
124
|
+
) internal {
|
125
|
+
_productService.setRiskInfo(
|
126
|
+
id,
|
127
|
+
info
|
128
|
+
);
|
129
|
+
}
|
130
|
+
|
131
|
+
function _updateRiskState(
|
132
|
+
RiskId id,
|
133
|
+
StateId state
|
134
|
+
) internal {
|
135
|
+
_productService.updateRiskState(
|
136
|
+
id,
|
137
|
+
state
|
138
|
+
);
|
139
|
+
}
|
140
|
+
|
141
|
+
function _getRiskInfo(RiskId id) internal view returns (IRisk.RiskInfo memory info) {
|
142
|
+
return _instance.getInstanceReader().getRiskInfo(id);
|
143
|
+
}
|
144
|
+
|
145
|
+
function _createApplication(
|
146
|
+
address applicationOwner,
|
147
|
+
RiskId riskId,
|
148
|
+
uint256 sumInsuredAmount,
|
149
|
+
uint256 lifetime,
|
150
|
+
bytes memory applicationData,
|
151
|
+
NftId bundleNftId,
|
152
|
+
ReferralId referralId
|
153
|
+
) internal returns (NftId nftId) {
|
154
|
+
nftId = _productService.createApplication(
|
155
|
+
applicationOwner,
|
156
|
+
riskId,
|
157
|
+
sumInsuredAmount,
|
158
|
+
lifetime,
|
159
|
+
applicationData,
|
160
|
+
bundleNftId,
|
161
|
+
referralId
|
162
|
+
);
|
163
|
+
}
|
164
|
+
|
165
|
+
function _underwrite(
|
166
|
+
NftId policyNftId,
|
167
|
+
bool requirePremiumPayment,
|
168
|
+
Timestamp activateAt
|
169
|
+
)
|
170
|
+
internal
|
171
|
+
{
|
172
|
+
_productService.underwrite(
|
173
|
+
policyNftId,
|
174
|
+
requirePremiumPayment,
|
175
|
+
activateAt);
|
176
|
+
}
|
177
|
+
|
178
|
+
function _collectPremium(
|
179
|
+
NftId policyNftId,
|
180
|
+
Timestamp activateAt
|
181
|
+
)
|
182
|
+
internal
|
183
|
+
{
|
184
|
+
_productService.collectPremium(
|
185
|
+
policyNftId,
|
186
|
+
activateAt);
|
187
|
+
}
|
188
|
+
|
189
|
+
function _activate(
|
190
|
+
NftId policyNftId,
|
191
|
+
Timestamp activateAt
|
192
|
+
)
|
193
|
+
internal
|
194
|
+
{
|
195
|
+
_productService.activate(
|
196
|
+
policyNftId,
|
197
|
+
activateAt);
|
198
|
+
}
|
199
|
+
|
200
|
+
function getPoolNftId() external view override returns (NftId poolNftId) {
|
201
|
+
return getRegistry().getNftId(address(_pool));
|
202
|
+
}
|
203
|
+
|
204
|
+
function getDistributionNftId() external view override returns (NftId distributionNftId) {
|
205
|
+
return getRegistry().getNftId(_distribution);
|
206
|
+
}
|
207
|
+
|
208
|
+
// from product component
|
209
|
+
function setFees(
|
210
|
+
Fee memory productFee,
|
211
|
+
Fee memory processingFee
|
212
|
+
)
|
213
|
+
external
|
214
|
+
onlyOwner
|
215
|
+
override
|
216
|
+
{
|
217
|
+
_productService.setFees(productFee, processingFee);
|
218
|
+
}
|
219
|
+
|
220
|
+
function getSetupInfo() public view returns (ISetup.ProductSetupInfo memory setupInfo) {
|
221
|
+
if (getNftId().eq(zeroNftId())) {
|
222
|
+
return ISetup.ProductSetupInfo(
|
223
|
+
_token,
|
224
|
+
TokenHandler(address(0)),
|
225
|
+
_distributionNftId,
|
226
|
+
_poolNftId,
|
227
|
+
FeeLib.zeroFee(), //_instance.getDistributionFee(_distributionNftId)
|
228
|
+
_initialProductFee,
|
229
|
+
_initialProcessingFee,
|
230
|
+
FeeLib.zeroFee(), //_instance.getPoolFee(_poolNftId)
|
231
|
+
FeeLib.zeroFee(), //_instance.getStakingFee(_poolNftId)
|
232
|
+
FeeLib.zeroFee() //_instance.getPerformanceFee(_poolNftId)
|
233
|
+
);
|
234
|
+
}
|
235
|
+
|
236
|
+
InstanceReader reader = _instance.getInstanceReader();
|
237
|
+
return reader.getProductSetupInfo(getNftId());
|
238
|
+
}
|
239
|
+
|
240
|
+
// from IRegisterable
|
241
|
+
|
242
|
+
// TODO used only once, occupies space
|
243
|
+
function getInitialInfo()
|
244
|
+
public
|
245
|
+
view
|
246
|
+
override (IRegisterable, Registerable)
|
247
|
+
returns (IRegistry.ObjectInfo memory, bytes memory)
|
248
|
+
{
|
249
|
+
// from Registerable
|
250
|
+
(
|
251
|
+
IRegistry.ObjectInfo memory productInfo,
|
252
|
+
bytes memory data
|
253
|
+
) = super.getInitialInfo();
|
254
|
+
|
255
|
+
// TODO read pool & distribution fees
|
256
|
+
// 1) from pool -> the only option -> pool must be registered first?
|
257
|
+
// 2) from instance -> all fees are set into instance at product registration which is ongoing here
|
258
|
+
// checks are done in registryProduct() where THIS function is called
|
259
|
+
//require(getRegistry().getObjectInfo(_poolNftId).objectType == POOL(), "POOL_NOT_REGISTERED");
|
260
|
+
//require(getRegistry().getObjectInfo(_distributionNftId).objectType == DISTRIBUTION(), "DISTRIBUTION_NOT_REGISTERED");
|
261
|
+
|
262
|
+
// from PoolComponent
|
263
|
+
(
|
264
|
+
IRegistry.ObjectInfo memory poolInfo,
|
265
|
+
bytes memory poolData
|
266
|
+
) = _pool.getInitialInfo();
|
267
|
+
|
268
|
+
(
|
269
|
+
/*IPool.PoolInfo memory info*/,
|
270
|
+
/*address wallet*/,
|
271
|
+
/*IERC20Metadata token*/,
|
272
|
+
Fee memory initialPoolFee,
|
273
|
+
Fee memory initialStakingFee,
|
274
|
+
Fee memory initialPerformanceFee
|
275
|
+
) = abi.decode(poolData, (ISetup.PoolSetupInfo, address, IERC20Metadata, Fee, Fee, Fee));
|
276
|
+
|
277
|
+
// TODO from DistributionComponent
|
278
|
+
|
279
|
+
return (
|
280
|
+
productInfo,
|
281
|
+
abi.encode(
|
282
|
+
ISetup.ProductSetupInfo(
|
283
|
+
_token,
|
284
|
+
TokenHandler(address(0)),
|
285
|
+
_distributionNftId,
|
286
|
+
_poolNftId,
|
287
|
+
FeeLib.zeroFee(), //_instance.getDistributionFee(_distributionNftId)
|
288
|
+
_initialProductFee,
|
289
|
+
_initialProcessingFee,
|
290
|
+
initialPoolFee,
|
291
|
+
initialStakingFee,
|
292
|
+
initialPerformanceFee
|
293
|
+
)
|
294
|
+
)
|
295
|
+
);
|
296
|
+
}
|
297
|
+
}
|