@etherisc/gif-next 0.0.2-f752d2a-551 → 0.0.2-f7b8c9f-518
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 +71 -0
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +1 -1
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.json +166 -39
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +4 -0
- package/artifacts/contracts/components/Distribution.sol/Distribution.json +557 -0
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.json +119 -39
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +4 -0
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +177 -0
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +108 -156
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +67 -139
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/components/Pool.sol/Pool.json +417 -88
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/components/Product.sol/Product.json +360 -51
- 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/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +1 -1
- 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/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +913 -530
- package/artifacts/contracts/instance/IInstanceLinked.sol/IInstanceLinked.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +1043 -556
- package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.json +224 -43
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +1 -1
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.json +51 -1
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.json +49 -0
- package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/instance/base/IService.sol/IService.json +174 -53
- package/artifacts/contracts/instance/base/InstanceBase.sol/InstanceBase.dbg.json +1 -1
- package/artifacts/contracts/instance/base/InstanceBase.sol/InstanceBase.json +263 -45
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +41 -23
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +4 -4
- package/artifacts/contracts/instance/base/ModuleBase.sol/ModuleBase.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ServiceBase.sol/ServiceBase.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ServiceBase.sol/ServiceBase.json +220 -52
- package/artifacts/contracts/instance/module/access/Access.sol/AccessModule.dbg.json +1 -1
- package/artifacts/contracts/instance/module/access/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/instance/module/access/IAccess.sol/IAccessModule.dbg.json +1 -1
- package/artifacts/contracts/instance/module/bundle/BundleModule.sol/BundleModule.dbg.json +1 -1
- package/artifacts/contracts/instance/module/bundle/BundleModule.sol/BundleModule.json +55 -54
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundle.dbg.json +1 -1
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundleModule.dbg.json +1 -1
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundleModule.json +56 -55
- package/artifacts/contracts/instance/module/component/ComponentModule.sol/ComponentModule.dbg.json +1 -1
- package/artifacts/contracts/instance/module/component/ComponentModule.sol/ComponentModule.json +22 -93
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponentModule.dbg.json +1 -1
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponentModule.json +22 -93
- package/artifacts/contracts/instance/module/distribution/DistributionModule.sol/DistributionModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/distribution/DistributionModule.sol/DistributionModule.json +10 -0
- package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistribution.dbg.json +4 -0
- package/artifacts/contracts/instance/module/{compensation/ICompensation.sol/ICompensation.json → distribution/IDistribution.sol/IDistribution.json} +2 -2
- package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistributionModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/{compensation/ICompensation.sol/ICompensationModule.json → distribution/IDistribution.sol/IDistributionModule.json} +2 -2
- package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicy.dbg.json +1 -1
- package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicyModule.dbg.json +1 -1
- package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicyModule.json +61 -51
- package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.dbg.json +1 -1
- package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.json +61 -51
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPool.dbg.json +1 -1
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPoolModule.dbg.json +1 -1
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPoolModule.json +29 -14
- package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.dbg.json +1 -1
- package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.json +28 -13
- package/artifacts/contracts/instance/module/risk/IRisk.sol/IRisk.dbg.json +1 -1
- package/artifacts/contracts/instance/module/risk/IRisk.sol/IRiskModule.dbg.json +1 -1
- package/artifacts/contracts/instance/module/risk/IRisk.sol/IRiskModule.json +104 -1
- package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.dbg.json +1 -1
- package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.json +126 -5
- package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasury.dbg.json +1 -1
- package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasuryModule.dbg.json +1 -1
- package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasuryModule.json +326 -221
- package/artifacts/contracts/instance/module/treasury/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/instance/module/treasury/TokenHandler.sol/TokenHandler.json +2 -2
- package/artifacts/contracts/instance/module/treasury/TreasuryModule.sol/TreasuryModule.dbg.json +1 -1
- package/artifacts/contracts/instance/module/treasury/TreasuryModule.sol/TreasuryModule.json +326 -221
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +350 -79
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +630 -0
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.json +176 -74
- 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 +1 -1
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +235 -50
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.json +325 -51
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +335 -53
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +466 -71
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +141 -12
- package/artifacts/contracts/registry/IChainNft.sol/IChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/IChainNft.sol/IChainNft.json +5 -0
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +298 -39
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +4 -0
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +745 -0
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +4 -0
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +34 -0
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +489 -120
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +997 -0
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +468 -0
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +107 -0
- 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 +4 -0
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +127 -0
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +117 -37
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +55 -14
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +4 -0
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +158 -0
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +4 -0
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +349 -0
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +190 -37
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +4 -0
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +129 -0
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
- package/artifacts/contracts/shared/Versionable.sol/Versionable.json +78 -14
- package/artifacts/contracts/test/TestDistribution.sol/TestDistribution.dbg.json +4 -0
- package/artifacts/contracts/test/TestDistribution.sol/TestDistribution.json +557 -0
- 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/TestPool.sol/TestPool.dbg.json +1 -1
- package/artifacts/contracts/test/TestPool.sol/TestPool.json +417 -88
- package/artifacts/contracts/test/TestProduct.sol/TestProduct.dbg.json +1 -1
- package/artifacts/contracts/test/TestProduct.sol/TestProduct.json +407 -56
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +1 -1
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +204 -36
- 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 +267 -62
- 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/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 +89 -25
- 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/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/types/Fee.sol/FeeLib.json +50 -11
- 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/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +2 -2
- package/artifacts/contracts/types/ReferralId.sol/ReferralIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/ReferralId.sol/ReferralIdLib.json +99 -0
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.json +86 -0
- 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/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.dbg.json +1 -1
- package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/types/Version.sol/VersionLib.json +40 -2
- package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/types/Version.sol/VersionPartLib.json +2 -2
- package/contracts/components/BaseComponent.sol +12 -21
- package/contracts/components/Distribution.sol +155 -0
- package/contracts/components/IBaseComponent.sol +2 -2
- package/contracts/components/IDistributionComponent.sol +46 -0
- package/contracts/components/IPoolComponent.sol +15 -8
- package/contracts/components/IProductComponent.sol +26 -8
- package/contracts/components/Pool.sol +99 -27
- package/contracts/components/Product.sol +204 -22
- package/contracts/instance/IInstance.sol +12 -10
- package/contracts/instance/Instance.sol +28 -9
- package/contracts/instance/base/ComponentServiceBase.sol +13 -6
- package/contracts/instance/base/IInstanceBase.sol +11 -2
- package/contracts/instance/base/IKeyValueStore.sol +4 -3
- package/contracts/instance/base/InstanceBase.sol +19 -10
- package/contracts/instance/base/KeyValueStore.sol +12 -7
- package/contracts/instance/base/Lifecycle.sol +15 -10
- package/contracts/instance/base/ModuleBase.sol +22 -17
- package/contracts/instance/base/ServiceBase.sol +20 -13
- package/contracts/instance/module/access/Access.sol +3 -3
- package/contracts/instance/module/bundle/BundleModule.sol +10 -12
- package/contracts/instance/module/bundle/IBundle.sol +6 -11
- package/contracts/instance/module/component/ComponentModule.sol +34 -58
- package/contracts/instance/module/component/IComponent.sol +7 -32
- package/contracts/instance/module/distribution/DistributionModule.sol +17 -0
- package/contracts/instance/module/distribution/IDistribution.sol +10 -0
- package/contracts/instance/module/policy/IPolicy.sol +13 -10
- package/contracts/instance/module/policy/PolicyModule.sol +35 -20
- package/contracts/instance/module/pool/IPoolModule.sol +4 -4
- package/contracts/instance/module/pool/PoolModule.sol +23 -15
- package/contracts/instance/module/risk/IRisk.sol +18 -2
- package/contracts/instance/module/risk/RiskModule.sol +56 -2
- package/contracts/instance/module/treasury/ITreasury.sol +32 -51
- package/contracts/instance/module/treasury/TokenHandler.sol +2 -2
- package/contracts/instance/module/treasury/TreasuryModule.sol +68 -89
- package/contracts/instance/service/ComponentOwnerService.sol +200 -95
- package/contracts/instance/service/DistributionService.sol +54 -0
- package/contracts/instance/service/IComponentOwnerService.sol +0 -2
- package/contracts/instance/service/IDistributionService.sol +12 -0
- package/contracts/instance/service/IPoolService.sol +7 -0
- package/contracts/instance/service/IProductService.sol +56 -7
- package/contracts/instance/service/PoolService.sol +49 -23
- package/contracts/instance/service/ProductService.sol +248 -92
- package/contracts/registry/ChainNft.sol +43 -15
- package/contracts/registry/IChainNft.sol +3 -2
- package/contracts/registry/IRegistry.sol +42 -26
- package/contracts/registry/IRegistryService.sol +29 -0
- package/contracts/registry/ITransferInterceptor.sol +6 -0
- package/contracts/registry/Registry.sol +384 -274
- package/contracts/registry/RegistryService.sol +368 -0
- package/contracts/registry/RegistryServiceManager.sol +43 -0
- package/contracts/shared/ContractDeployerLib.sol +72 -0
- package/contracts/shared/ERC165.sol +1 -1
- package/contracts/shared/INftOwnable.sol +22 -0
- package/contracts/shared/IRegisterable.sol +9 -16
- package/contracts/shared/IVersionable.sol +55 -11
- package/contracts/shared/NftOwnable.sol +136 -0
- package/contracts/shared/ProxyManager.sol +94 -0
- package/contracts/shared/Registerable.sol +62 -59
- package/contracts/shared/UpgradableProxyWithAdmin.sol +16 -0
- package/contracts/shared/Versionable.sol +112 -54
- package/contracts/test/TestDistribution.sol +22 -0
- package/contracts/test/TestPool.sol +7 -2
- package/contracts/test/TestProduct.sol +37 -7
- package/contracts/test/TestRegisterable.sol +5 -6
- package/contracts/test/TestService.sol +5 -11
- package/contracts/types/Fee.sol +8 -3
- package/contracts/types/ObjectType.sol +24 -8
- package/contracts/types/ReferralId.sol +48 -0
- package/contracts/types/RiskId.sol +43 -0
- package/contracts/types/RoleId.sol +2 -2
- package/contracts/types/Version.sol +9 -0
- package/package.json +1 -1
- package/artifacts/contracts/instance/module/compensation/CompensationModule.sol/CompensationModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/compensation/CompensationModule.sol/CompensationModule.json +0 -10
- package/artifacts/contracts/instance/module/compensation/ICompensation.sol/ICompensation.dbg.json +0 -4
- package/artifacts/contracts/instance/module/compensation/ICompensation.sol/ICompensationModule.dbg.json +0 -4
- package/artifacts/contracts/registry/IRegistryLinked.sol/IRegistryLinked.dbg.json +0 -4
- package/artifacts/contracts/registry/IRegistryLinked.sol/IRegistryLinked.json +0 -24
- package/artifacts/contracts/shared/IOwnable.sol/IOwnable.dbg.json +0 -4
- package/artifacts/contracts/shared/IOwnable.sol/IOwnable.json +0 -24
- package/contracts/experiment/statemachine/README.md +0 -112
- package/contracts/instance/module/compensation/CompensationModule.sol +0 -8
- package/contracts/instance/module/compensation/ICompensation.sol +0 -10
- package/contracts/registry/IRegistryLinked.sol +0 -8
- package/contracts/shared/IOwnable.sol +0 -6
@@ -1,103 +1,82 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.
|
2
|
+
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
-
import {IERC20Metadata} from "@
|
4
|
+
import {IERC20Metadata} from "@openzeppelin5/contracts/token/ERC20/extensions/IERC20Metadata.sol";
|
5
|
+
import {IDistributionComponent} from "../../../components/IDistributionComponent.sol";
|
6
|
+
import {IPoolComponent} from "../../../components/IPoolComponent.sol";
|
7
|
+
import {IProductComponent} from "../../../components/IProductComponent.sol";
|
5
8
|
|
6
9
|
import {NftId} from "../../../types/NftId.sol";
|
10
|
+
import {TREASURY} from "../../../types/ObjectType.sol";
|
7
11
|
import {Fee, FeeLib} from "../../../types/Fee.sol";
|
8
12
|
import {UFixed, UFixedMathLib} from "../../../types/UFixed.sol";
|
9
13
|
import {TokenHandler} from "./TokenHandler.sol";
|
14
|
+
import {IKeyValueStore} from "../../base/IKeyValueStore.sol";
|
10
15
|
import {ITreasuryModule} from "./ITreasury.sol";
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
) external override // TODO add authz (only component module)
|
28
|
-
{
|
29
|
-
require(address(_tokenHandler[productNftId]) == address(0), "ERROR:TRS-010:TOKEN_HANDLER_ALREADY_REGISTERED");
|
30
|
-
require(address(_tokenHandler[poolNftId]) == address(0), "ERROR:TRS-011:TOKEN_HANDLER_ALREADY_REGISTERED");
|
31
|
-
require(address(_tokenHandler[distributorNftId]) == address(0), "ERROR:TRS-012:TOKEN_HANDLER_ALREADY_REGISTERED");
|
32
|
-
// TODO add additional validations
|
33
|
-
|
34
|
-
// deploy product specific handler contract
|
35
|
-
TokenHandler tokenHandler = new TokenHandler(productNftId, address(token));
|
36
|
-
_tokenHandler[productNftId] = tokenHandler;
|
37
|
-
_tokenHandler[poolNftId] = tokenHandler;
|
38
|
-
_tokenHandler[distributorNftId] = tokenHandler;
|
39
|
-
|
40
|
-
// create product setup
|
41
|
-
_productSetup[productNftId] = ProductSetup(
|
42
|
-
productNftId,
|
43
|
-
distributorNftId,
|
44
|
-
poolNftId,
|
45
|
-
token,
|
46
|
-
wallet,
|
47
|
-
policyFee,
|
48
|
-
processingFee
|
16
|
+
import {ModuleBase} from "../../base/ModuleBase.sol";
|
17
|
+
|
18
|
+
abstract contract TreasuryModule is
|
19
|
+
ModuleBase,
|
20
|
+
ITreasuryModule
|
21
|
+
{
|
22
|
+
// relation of distributor and pool nft map to product nft
|
23
|
+
mapping(NftId componentNftId => NftId productNftId) internal _productNft;
|
24
|
+
// relation of component nft to token hanlder
|
25
|
+
mapping(NftId componentNftId => TokenHandler tokenHandler) internal _tokenHandler;
|
26
|
+
Fee internal _zeroFee;
|
27
|
+
|
28
|
+
modifier onlyComponentOwnerService() virtual {
|
29
|
+
require(
|
30
|
+
msg.sender == address(this.getComponentOwnerService()),
|
31
|
+
"ERROR:CMP-001:NOT_COPONENT_OWNER_SERVICE"
|
49
32
|
);
|
33
|
+
_;
|
34
|
+
}
|
50
35
|
|
51
|
-
|
36
|
+
function _initializeTreasuryModule(IKeyValueStore keyValueStore) internal {
|
37
|
+
//_initializeModuleBase(keyValueStore);
|
38
|
+
_initialize(keyValueStore);
|
39
|
+
_zeroFee = FeeLib.zeroFee();
|
52
40
|
}
|
53
41
|
|
54
|
-
function
|
42
|
+
function registerProductSetup(
|
55
43
|
NftId productNftId,
|
56
|
-
|
57
|
-
|
58
|
-
|
44
|
+
TreasuryInfo memory setup
|
45
|
+
)
|
46
|
+
external
|
47
|
+
onlyComponentOwnerService
|
59
48
|
{
|
60
|
-
|
61
|
-
|
62
|
-
ProductSetup storage setup = _productSetup[productNftId];
|
63
|
-
setup.policyFee = policyFee;
|
64
|
-
setup.processingFee = processingFee;
|
65
|
-
|
66
|
-
// TODO add logging
|
67
|
-
}
|
49
|
+
NftId poolNftId = setup.poolNftId;
|
50
|
+
NftId distributionNftId = setup.distributionNftId;
|
68
51
|
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
Fee memory stakingFee,
|
73
|
-
Fee memory performanceFee
|
74
|
-
) external override // TODO add authz (only component module)
|
75
|
-
{
|
76
|
-
// TODO add validation
|
52
|
+
require(address(_tokenHandler[productNftId]) == address(0), "ERROR:TRS-012:TOKEN_HANDLER_ALREADY_REGISTERED");
|
53
|
+
require(_productNft[poolNftId].eqz(), "ERROR:TRS-013:POOL_ALREADY_LINKED");
|
54
|
+
require(_productNft[distributionNftId].eqz(), "ERROR:TRS-014:COMPENSATION_ALREADY_LINKED");
|
77
55
|
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
);
|
56
|
+
// TODO deploy TokenHandler with separate contract to save space
|
57
|
+
// deploy product specific handler contract
|
58
|
+
_tokenHandler[productNftId] = new TokenHandler(productNftId, address(setup.token));
|
59
|
+
_productNft[distributionNftId] = productNftId;
|
60
|
+
_productNft[poolNftId] = productNftId;
|
84
61
|
|
85
|
-
|
62
|
+
_create(TREASURY(), productNftId, abi.encode(setup));
|
86
63
|
}
|
87
64
|
|
88
|
-
function
|
89
|
-
NftId
|
90
|
-
|
91
|
-
|
92
|
-
|
65
|
+
function setTreasuryInfo(
|
66
|
+
NftId productNftId,
|
67
|
+
TreasuryInfo memory info
|
68
|
+
)
|
69
|
+
external
|
70
|
+
// TODO add authz (only component module)
|
71
|
+
override
|
93
72
|
{
|
94
|
-
|
95
|
-
|
96
|
-
PoolSetup storage setup = _poolSetup[poolNftId];
|
97
|
-
setup.stakingFee = stakingFee;
|
98
|
-
setup.performanceFee = performanceFee;
|
73
|
+
_updateData(TREASURY(), productNftId, abi.encode(info));
|
74
|
+
}
|
99
75
|
|
100
|
-
|
76
|
+
function getProductNftId(
|
77
|
+
NftId componentNftId
|
78
|
+
) external view returns (NftId productNftId) {
|
79
|
+
return _productNft[componentNftId];
|
101
80
|
}
|
102
81
|
|
103
82
|
function getTokenHandler(
|
@@ -106,23 +85,23 @@ abstract contract TreasuryModule is ITreasuryModule {
|
|
106
85
|
return _tokenHandler[componentNftId];
|
107
86
|
}
|
108
87
|
|
109
|
-
function
|
88
|
+
function hasTreasuryInfo(
|
110
89
|
NftId productNftId
|
111
|
-
)
|
112
|
-
return
|
90
|
+
) public view override returns (bool hasInfo) {
|
91
|
+
return _exists(TREASURY(), productNftId);
|
113
92
|
}
|
114
93
|
|
115
|
-
function
|
116
|
-
NftId
|
117
|
-
)
|
118
|
-
return
|
94
|
+
function getTreasuryInfo(
|
95
|
+
NftId productNftId
|
96
|
+
) public view override returns (TreasuryInfo memory info) {
|
97
|
+
return abi.decode(_getData(TREASURY(), productNftId), (TreasuryInfo));
|
119
98
|
}
|
120
99
|
|
121
100
|
function calculateFeeAmount(
|
122
101
|
uint256 amount,
|
123
102
|
Fee memory fee
|
124
103
|
) public pure override returns (uint256 feeAmount, uint256 netAmount) {
|
125
|
-
return FeeLib.calculateFee(
|
104
|
+
return FeeLib.calculateFee(fee, amount);
|
126
105
|
}
|
127
106
|
|
128
107
|
function getFee(
|
@@ -132,8 +111,8 @@ abstract contract TreasuryModule is ITreasuryModule {
|
|
132
111
|
return FeeLib.toFee(fractionalFee, fixedFee);
|
133
112
|
}
|
134
113
|
|
135
|
-
function getZeroFee() external
|
136
|
-
return
|
114
|
+
function getZeroFee() external view override returns (Fee memory fee) {
|
115
|
+
return _zeroFee;
|
137
116
|
}
|
138
117
|
|
139
118
|
function getUFixed(
|
@@ -1,30 +1,38 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.
|
2
|
+
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
-
import {IERC20Metadata} from "@
|
4
|
+
import {IERC20Metadata} from "@openzeppelin5/contracts/token/ERC20/extensions/IERC20Metadata.sol";
|
5
5
|
|
6
6
|
import {IRegistry} from "../../registry/IRegistry.sol";
|
7
7
|
import {IInstance} from "../IInstance.sol";
|
8
8
|
|
9
|
-
import {ITreasuryModule} from "../module/treasury/ITreasury.sol";
|
9
|
+
import {ITreasury, ITreasuryModule} from "../module/treasury/ITreasury.sol";
|
10
10
|
import {TreasuryModule} from "../module/treasury/TreasuryModule.sol";
|
11
11
|
import {IComponent, IComponentModule} from "../module/component/IComponent.sol";
|
12
12
|
import {IBaseComponent} from "../../components/IBaseComponent.sol";
|
13
13
|
import {IPoolComponent} from "../../components/IPoolComponent.sol";
|
14
|
-
|
14
|
+
import {IKeyValueStore} from "../../instance/base/IKeyValueStore.sol";
|
15
15
|
import {IVersionable} from "../../shared/IVersionable.sol";
|
16
16
|
import {Versionable} from "../../shared/Versionable.sol";
|
17
17
|
|
18
|
-
import {RoleId, PRODUCT_OWNER_ROLE, POOL_OWNER_ROLE, ORACLE_OWNER_ROLE} from "../../types/RoleId.sol";
|
19
|
-
import {ObjectType, PRODUCT, ORACLE, POOL} from "../../types/ObjectType.sol";
|
18
|
+
import {RoleId, PRODUCT_OWNER_ROLE, POOL_OWNER_ROLE, DISTRIBUTION_OWNER_ROLE, ORACLE_OWNER_ROLE} from "../../types/RoleId.sol";
|
19
|
+
import {ObjectType, TOKEN, COMPONENT, PRODUCT, ORACLE, POOL, DISTRIBUTION} from "../../types/ObjectType.sol";
|
20
20
|
import {StateId, ACTIVE, PAUSED} from "../../types/StateId.sol";
|
21
|
+
import {Key32} from "../../types/Key32.sol";
|
21
22
|
import {NftId, NftIdLib, zeroNftId} from "../../types/NftId.sol";
|
22
23
|
import {Fee} from "../../types/Fee.sol";
|
23
24
|
import {Version, VersionLib} from "../../types/Version.sol";
|
25
|
+
import {UFixed, UFixedMathLib} from "../../types/UFixed.sol";
|
24
26
|
|
27
|
+
import {IDistributionComponent} from "../../components/IDistributionComponent.sol";
|
28
|
+
import {IPoolComponent} from "../../components/IPoolComponent.sol";
|
25
29
|
import {IProductComponent} from "../../components/IProductComponent.sol";
|
26
|
-
import {
|
30
|
+
import {IService} from "../base/IService.sol";
|
27
31
|
import {IComponentOwnerService} from "./IComponentOwnerService.sol";
|
32
|
+
import {ServiceBase} from "../base/ServiceBase.sol";
|
33
|
+
import {IPool, IPoolModule} from "../module/pool/IPoolModule.sol";
|
34
|
+
|
35
|
+
import {IRegistryService} from "../../registry/IRegistryService.sol";
|
28
36
|
|
29
37
|
contract ComponentOwnerService is
|
30
38
|
ServiceBase,
|
@@ -32,32 +40,35 @@ contract ComponentOwnerService is
|
|
32
40
|
{
|
33
41
|
using NftIdLib for NftId;
|
34
42
|
|
43
|
+
error MissingTypeRole();
|
44
|
+
error WalletIsZero();
|
45
|
+
error InvalidToken();
|
46
|
+
error InvalidPool();
|
47
|
+
error InvalidDistribution();
|
48
|
+
error InvalidPoolsInstance();
|
49
|
+
error InvalidDistributionsInstance();
|
50
|
+
|
51
|
+
error CollateralizationLevelIsZero();
|
52
|
+
|
35
53
|
string public constant NAME = "ComponentOwnerService";
|
36
54
|
|
37
55
|
modifier onlyRegisteredComponent(IBaseComponent component) {
|
38
|
-
NftId nftId =
|
56
|
+
NftId nftId = getRegistry().getNftId(address(component));
|
39
57
|
require(nftId.gtz(), "ERROR:COS-001:COMPONENT_UNKNOWN");
|
40
58
|
_;
|
41
59
|
}
|
42
60
|
|
43
61
|
constructor(
|
44
62
|
address registry,
|
45
|
-
NftId registryNftId
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
}
|
50
|
-
|
51
|
-
function getVersion()
|
52
|
-
public
|
53
|
-
pure
|
54
|
-
virtual override (IVersionable, Versionable)
|
55
|
-
returns(Version)
|
63
|
+
NftId registryNftId,
|
64
|
+
address initialOwner
|
65
|
+
)
|
56
66
|
{
|
57
|
-
|
67
|
+
_initializeServiceBase(registry, registryNftId, initialOwner);
|
68
|
+
_registerInterface(type(IComponentOwnerService).interfaceId);
|
58
69
|
}
|
59
70
|
|
60
|
-
function getName()
|
71
|
+
function getName() public pure override(IService, ServiceBase) returns(string memory name) {
|
61
72
|
return NAME;
|
62
73
|
}
|
63
74
|
|
@@ -70,101 +81,195 @@ contract ComponentOwnerService is
|
|
70
81
|
if (cType == POOL()) {
|
71
82
|
return POOL_OWNER_ROLE();
|
72
83
|
}
|
84
|
+
if (cType == DISTRIBUTION()) {
|
85
|
+
return DISTRIBUTION_OWNER_ROLE();
|
86
|
+
}
|
73
87
|
if (cType == ORACLE()) {
|
74
88
|
return ORACLE_OWNER_ROLE();
|
75
89
|
}
|
76
90
|
}
|
77
91
|
|
78
|
-
function
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
require(
|
83
|
-
msg.sender == address(component),
|
84
|
-
"ERROR:COS-003:NOT_COMPONENT"
|
85
|
-
);
|
92
|
+
function getRegistryService() public view virtual returns (IRegistryService) {
|
93
|
+
address service = getRegistry().getServiceAddress("RegistryService", getMajorVersion());
|
94
|
+
return IRegistryService(service);
|
95
|
+
}
|
86
96
|
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
"ERROR:CMP-004:TYPE_ROLE_MISSING"
|
93
|
-
);
|
97
|
+
// TODO if user passes type BUNDLE??? -> registerComponent() must catch this
|
98
|
+
function register(
|
99
|
+
IBaseComponent component,
|
100
|
+
ObjectType componentType
|
101
|
+
) external returns (NftId nftId) {
|
94
102
|
|
95
|
-
|
96
|
-
|
103
|
+
// TODO some info parameters from component and from register may differ -> getObjectInfo() after registration?
|
104
|
+
(
|
105
|
+
IRegistry.ObjectInfo memory info,
|
106
|
+
bytes memory data
|
107
|
+
) = getRegistryService().registerComponent(
|
108
|
+
component,
|
109
|
+
componentType,
|
110
|
+
msg.sender);
|
97
111
|
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
NftId distributorNftId = zeroNftId();
|
115
|
-
instance.registerProduct(
|
116
|
-
nftId,
|
117
|
-
distributorNftId,
|
118
|
-
poolNftId,
|
119
|
-
token,
|
120
|
-
wallet,
|
121
|
-
product.getPolicyFee(),
|
122
|
-
product.getProcessingFee()
|
112
|
+
NftId instanceNftId = info.parentNftId;
|
113
|
+
address instancAddress = getRegistry().getObjectInfo(instanceNftId).objectAddress;
|
114
|
+
IInstance instance = IInstance(instancAddress);
|
115
|
+
|
116
|
+
RoleId typeRole = getRoleForType(componentType);
|
117
|
+
if(instance.hasRole(typeRole, msg.sender) == false) {
|
118
|
+
revert MissingTypeRole();
|
119
|
+
}
|
120
|
+
|
121
|
+
// component type specific registration actions
|
122
|
+
if (componentType == PRODUCT()) {
|
123
|
+
_registerProduct(
|
124
|
+
info.nftId,
|
125
|
+
instanceNftId,
|
126
|
+
instance,
|
127
|
+
data
|
123
128
|
);
|
124
|
-
} else if (
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
|
133
|
-
// register with tresury
|
134
|
-
instance.registerPool(
|
135
|
-
nftId,
|
136
|
-
wallet,
|
137
|
-
pool.getStakingFee(),
|
138
|
-
pool.getPerformanceFee());
|
139
|
-
}
|
140
|
-
// TODO add distribution
|
129
|
+
} else if (componentType == POOL()) {
|
130
|
+
_registerPool(
|
131
|
+
info.nftId,
|
132
|
+
instanceNftId,
|
133
|
+
instance,
|
134
|
+
data
|
135
|
+
);
|
136
|
+
}
|
137
|
+
// TODO add distribution and oracle
|
141
138
|
}
|
142
139
|
|
143
140
|
function lock(
|
144
141
|
IBaseComponent component
|
145
142
|
) external override onlyRegisteredComponent(component) {
|
143
|
+
// TODO use msg.sender to get component and get instance via registered parent nft id
|
146
144
|
IInstance instance = component.getInstance();
|
147
|
-
|
148
|
-
|
149
|
-
);
|
150
|
-
require(info.nftId.gtz(), "ERROR_COMPONENT_UNKNOWN");
|
151
|
-
|
152
|
-
info.state = PAUSED();
|
153
|
-
// setComponentInfo checks for valid state changes
|
154
|
-
instance.setComponentInfo(info);
|
145
|
+
NftId nftId = component.getNftId();
|
146
|
+
Key32 key = nftId.toKey32(COMPONENT());
|
147
|
+
instance.updateState(key, PAUSED());
|
155
148
|
}
|
156
149
|
|
157
150
|
function unlock(
|
158
151
|
IBaseComponent component
|
159
152
|
) external override onlyRegisteredComponent(component) {
|
153
|
+
// TODO use msg.sender to get component and get instance via registered parent nft id
|
160
154
|
IInstance instance = component.getInstance();
|
161
|
-
|
162
|
-
|
155
|
+
NftId nftId = component.getNftId();
|
156
|
+
Key32 key = nftId.toKey32(COMPONENT());
|
157
|
+
instance.updateState(key, ACTIVE());
|
158
|
+
}
|
159
|
+
|
160
|
+
// Internals
|
161
|
+
|
162
|
+
function _registerProduct(
|
163
|
+
NftId nftId,
|
164
|
+
NftId instanceNftId,
|
165
|
+
IInstance instance,
|
166
|
+
bytes memory data
|
167
|
+
)
|
168
|
+
internal
|
169
|
+
{
|
170
|
+
(
|
171
|
+
ITreasury.TreasuryInfo memory info,
|
172
|
+
address wallet
|
173
|
+
) = abi.decode(data, (ITreasury.TreasuryInfo, address));
|
174
|
+
|
175
|
+
IRegistry _registry = getRegistry();
|
176
|
+
|
177
|
+
if(wallet == address(0)) {
|
178
|
+
revert WalletIsZero();
|
179
|
+
}
|
180
|
+
|
181
|
+
IRegistry.ObjectInfo memory tokenInfo = _registry.getObjectInfo(address(info.token));
|
182
|
+
|
183
|
+
if(tokenInfo.objectType != TOKEN()) {
|
184
|
+
revert InvalidToken();
|
185
|
+
}
|
186
|
+
|
187
|
+
IRegistry.ObjectInfo memory poolInfo = _registry.getObjectInfo(info.poolNftId);
|
188
|
+
|
189
|
+
if(poolInfo.objectType != POOL()) {
|
190
|
+
revert InvalidPool();
|
191
|
+
}
|
192
|
+
|
193
|
+
if(poolInfo.parentNftId != instanceNftId) {
|
194
|
+
revert InvalidPoolsInstance();
|
195
|
+
}
|
196
|
+
// TODO pool have the same token
|
197
|
+
//ITreasury.PoolSetup memory poolSetup = instance.getPoolSetup(info.poolNftId);
|
198
|
+
//require(tokenInfo.objectAddress == address(poolSetup.token), "ERROR:COS-018:PRODUCT_POOL_TOKEN_MISMATCH");
|
199
|
+
// TODO pool is not linked
|
200
|
+
|
201
|
+
IRegistry.ObjectInfo memory distributionInfo = _registry.getObjectInfo(info.distributionNftId);
|
202
|
+
|
203
|
+
if(distributionInfo.objectType != DISTRIBUTION()) {
|
204
|
+
revert InvalidDistribution();
|
205
|
+
}
|
206
|
+
|
207
|
+
if(distributionInfo.parentNftId != instanceNftId) {
|
208
|
+
revert InvalidDistributionsInstance();
|
209
|
+
}
|
210
|
+
// TODO distribution have the same token
|
211
|
+
// TODO distribution is not linked
|
212
|
+
|
213
|
+
// component module
|
214
|
+
instance.registerComponent(
|
215
|
+
nftId,
|
216
|
+
info.token,
|
217
|
+
wallet // TODO move wallet into TreasuryInfo?
|
163
218
|
);
|
164
|
-
require(info.nftId.gtz(), "ERROR_COMPONENT_UNKNOWN");
|
165
219
|
|
166
|
-
|
167
|
-
|
168
|
-
|
220
|
+
// treasury module
|
221
|
+
instance.registerProductSetup(
|
222
|
+
nftId,
|
223
|
+
info
|
224
|
+
);
|
225
|
+
}
|
226
|
+
|
227
|
+
function _registerPool(
|
228
|
+
NftId nftId,
|
229
|
+
NftId instanceNftId,
|
230
|
+
IInstance instance,
|
231
|
+
bytes memory data
|
232
|
+
)
|
233
|
+
internal
|
234
|
+
{
|
235
|
+
(
|
236
|
+
IPool.PoolInfo memory info,
|
237
|
+
address wallet,
|
238
|
+
IERC20Metadata token,
|
239
|
+
/*poolFee*/,
|
240
|
+
/*stakingFee*/,
|
241
|
+
/*performanceFee*/
|
242
|
+
) = abi.decode(data, (IPool.PoolInfo, address, IERC20Metadata, Fee, Fee, Fee));
|
243
|
+
|
244
|
+
IRegistry _registry = getRegistry();
|
245
|
+
|
246
|
+
if(wallet == address(0)) {
|
247
|
+
revert WalletIsZero();
|
248
|
+
}
|
249
|
+
|
250
|
+
ObjectType tokenType = _registry.getObjectInfo(address(token)).objectType;
|
251
|
+
|
252
|
+
if(tokenType != TOKEN()) {
|
253
|
+
revert InvalidToken();
|
254
|
+
}
|
255
|
+
|
256
|
+
if(UFixedMathLib.eqz(info.collateralizationLevel)) {
|
257
|
+
revert CollateralizationLevelIsZero();
|
258
|
+
}
|
259
|
+
|
260
|
+
// TODO add more validations
|
261
|
+
|
262
|
+
// component module
|
263
|
+
instance.registerComponent(
|
264
|
+
nftId,
|
265
|
+
token,
|
266
|
+
wallet
|
267
|
+
);
|
268
|
+
|
269
|
+
// pool module
|
270
|
+
instance.registerPool(
|
271
|
+
nftId,
|
272
|
+
info
|
273
|
+
);
|
169
274
|
}
|
170
|
-
}
|
275
|
+
}
|
@@ -0,0 +1,54 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.19;
|
3
|
+
|
4
|
+
import {IRegistry} from "../../registry/IRegistry.sol";
|
5
|
+
import {IInstance} from "../../instance/IInstance.sol";
|
6
|
+
import {ITreasury} from "../../instance/module/treasury/ITreasury.sol";
|
7
|
+
|
8
|
+
import {NftId} from "../../types/NftId.sol";
|
9
|
+
import {Fee} from "../../types/Fee.sol";
|
10
|
+
import {DISTRIBUTION} from "../../types/ObjectType.sol";
|
11
|
+
import {Version, VersionLib} from "../../types/Version.sol";
|
12
|
+
|
13
|
+
import {IVersionable} from "../../shared/IVersionable.sol";
|
14
|
+
import {Versionable} from "../../shared/Versionable.sol";
|
15
|
+
|
16
|
+
import {IService} from "../base/IService.sol";
|
17
|
+
import {ServiceBase} from "../base/ServiceBase.sol";
|
18
|
+
import {ComponentServiceBase} from "../base/ComponentServiceBase.sol";
|
19
|
+
import {IDistributionService} from "./IDistributionService.sol";
|
20
|
+
|
21
|
+
contract DistributionService is
|
22
|
+
ComponentServiceBase,
|
23
|
+
IDistributionService
|
24
|
+
{
|
25
|
+
string public constant NAME = "DistributionService";
|
26
|
+
|
27
|
+
constructor(
|
28
|
+
address registry,
|
29
|
+
NftId registryNftId,
|
30
|
+
address initialOwner
|
31
|
+
) ComponentServiceBase(registry, registryNftId, initialOwner)
|
32
|
+
{
|
33
|
+
_registerInterface(type(IDistributionService).interfaceId);
|
34
|
+
}
|
35
|
+
|
36
|
+
|
37
|
+
function getName() public pure override(IService, ServiceBase) returns(string memory name) {
|
38
|
+
return NAME;
|
39
|
+
}
|
40
|
+
|
41
|
+
function setFees(
|
42
|
+
Fee memory distributionFee
|
43
|
+
)
|
44
|
+
external
|
45
|
+
override
|
46
|
+
{
|
47
|
+
(IRegistry.ObjectInfo memory distributionInfo, IInstance instance) = _getAndVerifyComponentInfoAndInstance(DISTRIBUTION());
|
48
|
+
|
49
|
+
NftId productNftId = instance.getProductNftId(distributionInfo.nftId);
|
50
|
+
ITreasury.TreasuryInfo memory treasuryInfo = instance.getTreasuryInfo(productNftId);
|
51
|
+
treasuryInfo.distributionFee = distributionFee;
|
52
|
+
instance.setTreasuryInfo(productNftId, treasuryInfo);
|
53
|
+
}
|
54
|
+
}
|
@@ -10,8 +10,6 @@ import {IService} from "../base/IService.sol";
|
|
10
10
|
// TODO rename to registry service
|
11
11
|
interface IComponentOwnerService is IService {
|
12
12
|
|
13
|
-
function register(IBaseComponent component) external returns(NftId componentNftId);
|
14
|
-
|
15
13
|
// TODO move to product/pool services
|
16
14
|
function lock(IBaseComponent component) external;
|
17
15
|
|
@@ -0,0 +1,12 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.19;
|
3
|
+
|
4
|
+
import {NftId} from "../../types/NftId.sol";
|
5
|
+
import {Fee} from "../../types/Fee.sol";
|
6
|
+
import {IService} from "../base/IService.sol";
|
7
|
+
|
8
|
+
interface IDistributionService is IService {
|
9
|
+
function setFees(
|
10
|
+
Fee memory distributionFee
|
11
|
+
) external;
|
12
|
+
}
|
@@ -7,17 +7,24 @@ import {IService} from "../base/IService.sol";
|
|
7
7
|
|
8
8
|
interface IPoolService is IService {
|
9
9
|
function setFees(
|
10
|
+
Fee memory poolFee,
|
10
11
|
Fee memory stakingFee,
|
11
12
|
Fee memory performanceFee
|
12
13
|
) external;
|
13
14
|
|
14
15
|
function createBundle(
|
15
16
|
address owner,
|
17
|
+
Fee memory fee,
|
16
18
|
uint256 amount,
|
17
19
|
uint256 lifetime,
|
18
20
|
bytes calldata filter
|
19
21
|
) external returns(NftId bundleNftId);
|
20
22
|
|
23
|
+
function setBundleFee(
|
24
|
+
NftId bundleNftId,
|
25
|
+
Fee memory fee
|
26
|
+
) external;
|
27
|
+
|
21
28
|
// function fundBundle(NftId bundleNftId, uint256 amount) external returns(uint256 netAmount);
|
22
29
|
|
23
30
|
// function defundBundle(NftId bundleNftId, uint256 amount) external returns(uint256 netAmount);
|