@etherisc/gif-next 0.0.2-de0a1d3-009 → 0.0.2-e1e92ab-754
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 +51 -25
- 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 +1 -1
- package/artifacts/contracts/components/Distribution.sol/Distribution.json +212 -60
- 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 +1 -1
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +0 -163
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +6 -185
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +0 -163
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/components/Pool.sol/Pool.json +257 -119
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/components/Product.sol/Product.json +220 -50
- 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/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 +247 -355
- 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 +369 -507
- package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.json +144 -50
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +1 -1
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.json +1 -1
- 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/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/instance/base/IService.sol/IService.json +120 -40
- package/artifacts/contracts/instance/base/InstanceBase.sol/InstanceBase.dbg.json +1 -1
- package/artifacts/contracts/instance/base/InstanceBase.sol/InstanceBase.json +147 -66
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- 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 +140 -59
- package/artifacts/contracts/instance/module/bundle/BundleModule.sol/BundleModule.dbg.json +1 -1
- 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/component/ComponentModule.sol/ComponentModule.dbg.json +1 -1
- 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/distribution/DistributionModule.sol/DistributionModule.dbg.json +1 -1
- package/artifacts/contracts/instance/module/distribution/DistributionModule.sol/DistributionModule.json +2 -2
- package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistribution.dbg.json +1 -1
- package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistributionModule.dbg.json +1 -1
- 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 +0 -13
- package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.dbg.json +1 -1
- package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.json +0 -13
- 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 -9
- package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.dbg.json +1 -1
- package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.json +28 -8
- 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/RiskModule.sol/RiskModule.dbg.json +1 -1
- package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.json +2 -2
- 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 +138 -11
- 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 +138 -11
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +288 -79
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +188 -65
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.json +122 -61
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.json +120 -40
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +120 -40
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.json +120 -40
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +190 -67
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +220 -97
- 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 +190 -51
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +4 -0
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +872 -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 +380 -139
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +1245 -0
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +490 -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 +2 -2
- 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/{Proxy.sol/ProxyWithProxyAdminGetter.json → UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json} +4 -4
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
- package/artifacts/contracts/shared/Versionable.sol/Versionable.json +4 -27
- package/artifacts/contracts/test/TestDistribution.sol/TestDistribution.dbg.json +1 -1
- package/artifacts/contracts/test/TestDistribution.sol/TestDistribution.json +212 -60
- 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/TestPool.sol/TestPool.dbg.json +1 -1
- package/artifacts/contracts/test/TestPool.sol/TestPool.json +257 -119
- package/artifacts/contracts/test/TestProduct.sol/TestProduct.dbg.json +1 -1
- package/artifacts/contracts/test/TestProduct.sol/TestProduct.json +225 -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 +187 -69
- 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 +15 -38
- 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/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/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/types/ReferralId.sol/ReferralIdLib.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/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 +2 -2
- package/contracts/components/BaseComponent.sol +11 -26
- package/contracts/components/Distribution.sol +29 -6
- package/contracts/components/IBaseComponent.sol +1 -1
- package/contracts/components/IDistributionComponent.sol +1 -2
- package/contracts/components/IPoolComponent.sol +3 -10
- package/contracts/components/IProductComponent.sol +2 -3
- package/contracts/components/Pool.sol +84 -73
- package/contracts/components/Product.sol +85 -13
- package/contracts/instance/IInstance.sol +6 -7
- package/contracts/instance/Instance.sol +18 -9
- package/contracts/instance/base/ComponentServiceBase.sol +13 -6
- package/contracts/instance/base/IInstanceBase.sol +3 -2
- package/contracts/instance/base/InstanceBase.sol +6 -8
- package/contracts/instance/base/ServiceBase.sol +20 -13
- package/contracts/instance/module/component/ComponentModule.sol +4 -3
- package/contracts/instance/module/component/IComponent.sol +1 -1
- package/contracts/instance/module/policy/IPolicy.sol +1 -1
- package/contracts/instance/module/pool/IPoolModule.sol +4 -3
- package/contracts/instance/module/pool/PoolModule.sol +12 -7
- package/contracts/instance/module/treasury/ITreasury.sol +6 -4
- package/contracts/instance/module/treasury/TokenHandler.sol +1 -1
- package/contracts/instance/module/treasury/TreasuryModule.sol +23 -30
- package/contracts/instance/service/ComponentOwnerService.sol +224 -66
- package/contracts/instance/service/DistributionService.sol +6 -11
- package/contracts/instance/service/IComponentOwnerService.sol +0 -2
- package/contracts/instance/service/PoolService.sol +19 -19
- package/contracts/instance/service/ProductService.sol +27 -26
- package/contracts/registry/ChainNft.sol +42 -14
- package/contracts/registry/IChainNft.sol +2 -1
- package/contracts/registry/IRegistry.sol +27 -27
- package/contracts/registry/IRegistryService.sol +35 -0
- package/contracts/registry/ITransferInterceptor.sol +6 -0
- package/contracts/registry/Registry.sol +312 -267
- package/contracts/registry/RegistryService.sol +441 -0
- package/contracts/registry/RegistryServiceManager.sol +63 -0
- package/contracts/shared/ContractDeployerLib.sol +72 -0
- package/contracts/shared/INftOwnable.sol +22 -0
- package/contracts/shared/IRegisterable.sol +8 -15
- package/contracts/shared/IVersionable.sol +40 -9
- 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 +109 -61
- package/contracts/test/TestDistribution.sol +3 -2
- package/contracts/test/TestFee.sol +2 -2
- package/contracts/test/TestPool.sol +4 -2
- package/contracts/test/TestProduct.sol +4 -2
- package/contracts/test/TestRegisterable.sol +5 -6
- package/contracts/test/TestService.sol +5 -11
- package/contracts/types/Fee.sol +3 -3
- package/contracts/types/RoleId.sol +7 -0
- package/contracts/types/UFixed.sol +128 -12
- package/contracts/types/Version.sol +1 -0
- package/package.json +4 -3
- package/artifacts/contracts/instance/module/access/Access.sol/AccessModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/access/Access.sol/AccessModule.json +0 -333
- package/artifacts/contracts/instance/module/access/IAccess.sol/IAccess.dbg.json +0 -4
- package/artifacts/contracts/instance/module/access/IAccess.sol/IAccess.json +0 -10
- package/artifacts/contracts/instance/module/access/IAccess.sol/IAccessModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/access/IAccess.sol/IAccessModule.json +0 -333
- package/artifacts/contracts/registry/IRegistryLinked.sol/IRegistryLinked.dbg.json +0 -4
- package/artifacts/contracts/registry/IRegistryLinked.sol/IRegistryLinked.json +0 -24
- package/artifacts/contracts/registry/RegistryUpgradeable.sol/RegistryUpgradeable.dbg.json +0 -4
- package/artifacts/contracts/registry/RegistryUpgradeable.sol/RegistryUpgradeable.json +0 -724
- package/artifacts/contracts/shared/IOwnable.sol/IOwnable.dbg.json +0 -4
- package/artifacts/contracts/shared/IOwnable.sol/IOwnable.json +0 -24
- package/artifacts/contracts/shared/Proxy.sol/ProxyDeployer.dbg.json +0 -4
- package/artifacts/contracts/shared/Proxy.sol/ProxyDeployer.json +0 -248
- package/artifacts/contracts/shared/Proxy.sol/ProxyWithProxyAdminGetter.dbg.json +0 -4
- package/artifacts/contracts/shared/VersionableUpgradeable.sol/VersionableUpgradeable.dbg.json +0 -4
- package/artifacts/contracts/shared/VersionableUpgradeable.sol/VersionableUpgradeable.json +0 -228
- package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.dbg.json +0 -4
- package/contracts/experiment/statemachine/README.md +0 -112
- package/contracts/instance/module/access/Access.sol +0 -149
- package/contracts/instance/module/access/IAccess.sol +0 -53
- package/contracts/registry/IRegistryLinked.sol +0 -8
- package/contracts/registry/RegistryUpgradeable.sol +0 -473
- package/contracts/shared/IOwnable.sol +0 -6
- package/contracts/shared/Proxy.sol +0 -94
- package/contracts/shared/VersionableUpgradeable.sol +0 -133
@@ -1,7 +1,7 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.19;
|
3
3
|
|
4
|
-
import {
|
4
|
+
import {DISTRIBUTION} from "../types/ObjectType.sol";
|
5
5
|
import {IDistributionService} from "../instance/service/IDistributionService.sol";
|
6
6
|
import {IProductService} from "../instance/service/IProductService.sol";
|
7
7
|
import {NftId} from "../types/NftId.sol";
|
@@ -9,6 +9,9 @@ import {ReferralId} from "../types/ReferralId.sol";
|
|
9
9
|
import {Fee, FeeLib} from "../types/Fee.sol";
|
10
10
|
import {BaseComponent} from "./BaseComponent.sol";
|
11
11
|
import {IDistributionComponent} from "./IDistributionComponent.sol";
|
12
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
13
|
+
import {IRegisterable} from "../shared/IRegisterable.sol";
|
14
|
+
import {Registerable} from "../shared/Registerable.sol";
|
12
15
|
|
13
16
|
contract Distribution is
|
14
17
|
BaseComponent,
|
@@ -34,15 +37,18 @@ contract Distribution is
|
|
34
37
|
// TODO refactor into tokenNftId
|
35
38
|
address token,
|
36
39
|
bool verifying,
|
37
|
-
Fee memory distributionFee
|
40
|
+
Fee memory distributionFee,
|
41
|
+
address initialOwner
|
38
42
|
)
|
39
|
-
BaseComponent(registry, instanceNftId, token)
|
43
|
+
BaseComponent(registry, instanceNftId, token, DISTRIBUTION(), true, initialOwner)
|
40
44
|
{
|
41
45
|
_isVerifying = verifying;
|
42
46
|
_initialDistributionFee = distributionFee;
|
43
47
|
|
44
48
|
_distributionService = _instance.getDistributionService();
|
45
49
|
_productService = _instance.getProductService();
|
50
|
+
|
51
|
+
_registerInterface(type(IDistributionComponent).interfaceId);
|
46
52
|
}
|
47
53
|
|
48
54
|
|
@@ -125,8 +131,25 @@ contract Distribution is
|
|
125
131
|
return _isVerifying;
|
126
132
|
}
|
127
133
|
|
128
|
-
// from
|
129
|
-
|
130
|
-
|
134
|
+
// from IRegisterable
|
135
|
+
|
136
|
+
function getInitialInfo()
|
137
|
+
public
|
138
|
+
view
|
139
|
+
override (IRegisterable, Registerable)
|
140
|
+
returns(IRegistry.ObjectInfo memory, bytes memory)
|
141
|
+
{
|
142
|
+
(
|
143
|
+
IRegistry.ObjectInfo memory info,
|
144
|
+
bytes memory data
|
145
|
+
) = super.getInitialInfo();
|
146
|
+
|
147
|
+
return (
|
148
|
+
info,
|
149
|
+
abi.encode(
|
150
|
+
_initialDistributionFee,
|
151
|
+
_isVerifying
|
152
|
+
)
|
153
|
+
);
|
131
154
|
}
|
132
155
|
}
|
@@ -4,9 +4,8 @@ pragma solidity ^0.8.19;
|
|
4
4
|
import {Fee} from "../types/Fee.sol";
|
5
5
|
import {ReferralId} from "../types/ReferralId.sol";
|
6
6
|
import {NftId} from "../types/NftId.sol";
|
7
|
-
import {IBaseComponent} from "./IBaseComponent.sol";
|
8
7
|
|
9
|
-
interface IDistributionComponent
|
8
|
+
interface IDistributionComponent {
|
10
9
|
|
11
10
|
function setFees(
|
12
11
|
Fee memory distributionFee
|
@@ -1,12 +1,11 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.
|
2
|
+
pragma solidity ^0.8.20;
|
3
3
|
|
4
4
|
import {NftId} from "../types/NftId.sol";
|
5
5
|
import {Fee} from "../types/Fee.sol";
|
6
6
|
import {UFixed} from "../types/UFixed.sol";
|
7
|
-
import {IBaseComponent} from "./IBaseComponent.sol";
|
8
7
|
|
9
|
-
interface IPoolComponent
|
8
|
+
interface IPoolComponent {
|
10
9
|
|
11
10
|
event LogUnderwrittenByPool(NftId policyNftId, uint256 collateralizationAmount, address pool);
|
12
11
|
|
@@ -60,12 +59,6 @@ interface IPoolComponent is IBaseComponent {
|
|
60
59
|
|
61
60
|
function getCollateralizationLevel() external view returns (UFixed collateralizationLevel);
|
62
61
|
|
63
|
-
function
|
62
|
+
function getFees() external view returns (Fee memory poolFee, Fee memory stakingFee, Fee memory performanceFee);
|
64
63
|
|
65
|
-
function getStakingFee() external view returns (Fee memory stakingFee);
|
66
|
-
|
67
|
-
function getPerformanceFee()
|
68
|
-
external
|
69
|
-
view
|
70
|
-
returns (Fee memory performanceFee);
|
71
64
|
}
|
@@ -1,14 +1,13 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.
|
2
|
+
pragma solidity ^0.8.20;
|
3
3
|
|
4
4
|
import {Fee} from "../types/Fee.sol";
|
5
5
|
import {NftId} from "../types/NftId.sol";
|
6
6
|
import {ReferralId} from "../types/ReferralId.sol";
|
7
7
|
import {RiskId} from "../types/RiskId.sol";
|
8
8
|
|
9
|
-
|
9
|
+
interface IProductComponent {
|
10
10
|
|
11
|
-
interface IProductComponent is IBaseComponent {
|
12
11
|
function setFees(
|
13
12
|
Fee memory productFee,
|
14
13
|
Fee memory processingFee
|
@@ -1,5 +1,5 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.
|
2
|
+
pragma solidity ^0.8.20;
|
3
3
|
|
4
4
|
import {ObjectType, POOL} from "../types/ObjectType.sol";
|
5
5
|
import {IProductService} from "../instance/service/IProductService.sol";
|
@@ -10,6 +10,13 @@ import {UFixed} from "../types/UFixed.sol";
|
|
10
10
|
import {IPoolComponent} from "./IPoolComponent.sol";
|
11
11
|
import {BaseComponent} from "./BaseComponent.sol";
|
12
12
|
|
13
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
14
|
+
import {IPool} from "../instance/module/pool/IPoolModule.sol";
|
15
|
+
import {ITreasury} from "../instance/module/treasury/ITreasury.sol";
|
16
|
+
|
17
|
+
import {IRegisterable} from "../shared/IRegisterable.sol";
|
18
|
+
import {Registerable} from "../shared/Registerable.sol";
|
19
|
+
|
13
20
|
contract Pool is BaseComponent, IPoolComponent {
|
14
21
|
|
15
22
|
bool internal _isVerifying;
|
@@ -44,13 +51,15 @@ contract Pool is BaseComponent, IPoolComponent {
|
|
44
51
|
NftId instanceNftId,
|
45
52
|
// TODO refactor into tokenNftId
|
46
53
|
address token,
|
54
|
+
bool isInterceptor,
|
47
55
|
bool verifying,
|
48
56
|
UFixed collateralizationLevel,
|
49
57
|
Fee memory poolFee,
|
50
58
|
Fee memory stakingFee,
|
51
|
-
Fee memory performanceFee
|
59
|
+
Fee memory performanceFee,
|
60
|
+
address initialOwner
|
52
61
|
)
|
53
|
-
BaseComponent(registry, instanceNftId, token)
|
62
|
+
BaseComponent(registry, instanceNftId, token, POOL(), isInterceptor, initialOwner)
|
54
63
|
{
|
55
64
|
_isVerifying = verifying;
|
56
65
|
// TODO add validation
|
@@ -61,18 +70,8 @@ contract Pool is BaseComponent, IPoolComponent {
|
|
61
70
|
|
62
71
|
_poolService = _instance.getPoolService();
|
63
72
|
_productService = _instance.getProductService();
|
64
|
-
}
|
65
73
|
|
66
|
-
|
67
|
-
Fee memory poolFee,
|
68
|
-
Fee memory stakingFee,
|
69
|
-
Fee memory performanceFee
|
70
|
-
)
|
71
|
-
external
|
72
|
-
onlyOwner
|
73
|
-
override
|
74
|
-
{
|
75
|
-
_poolService.setFees(poolFee, stakingFee, performanceFee);
|
74
|
+
_registerInterface(type(IPoolComponent).interfaceId);
|
76
75
|
}
|
77
76
|
|
78
77
|
function createBundle(
|
@@ -97,17 +96,6 @@ contract Pool is BaseComponent, IPoolComponent {
|
|
97
96
|
// TODO add logging
|
98
97
|
}
|
99
98
|
|
100
|
-
function setBundleFee(
|
101
|
-
NftId bundleNftId,
|
102
|
-
Fee memory fee
|
103
|
-
)
|
104
|
-
external
|
105
|
-
override
|
106
|
-
// TODO add onlyBundleOwner
|
107
|
-
{
|
108
|
-
_poolService.setBundleFee(bundleNftId, fee);
|
109
|
-
}
|
110
|
-
|
111
99
|
/**
|
112
100
|
* @dev see {IPool.underwrite}.
|
113
101
|
* Default implementation that only writes a {LogUnderwrittenByPool} entry.
|
@@ -150,6 +138,77 @@ contract Pool is BaseComponent, IPoolComponent {
|
|
150
138
|
return _collateralizationLevel;
|
151
139
|
}
|
152
140
|
|
141
|
+
function setFees(
|
142
|
+
Fee memory poolFee,
|
143
|
+
Fee memory stakingFee,
|
144
|
+
Fee memory performanceFee
|
145
|
+
)
|
146
|
+
external
|
147
|
+
onlyOwner
|
148
|
+
override
|
149
|
+
{
|
150
|
+
_poolService.setFees(poolFee, stakingFee, performanceFee);
|
151
|
+
}
|
152
|
+
|
153
|
+
function setBundleFee(
|
154
|
+
NftId bundleNftId,
|
155
|
+
Fee memory fee
|
156
|
+
)
|
157
|
+
external
|
158
|
+
override
|
159
|
+
// TODO add onlyBundleOwner
|
160
|
+
{
|
161
|
+
_poolService.setBundleFee(bundleNftId, fee);
|
162
|
+
}
|
163
|
+
// TODO delete, call instance instead
|
164
|
+
function getFees()
|
165
|
+
external
|
166
|
+
view
|
167
|
+
override
|
168
|
+
returns (Fee memory, Fee memory, Fee memory)
|
169
|
+
{
|
170
|
+
NftId productNftId = _instance.getProductNftId(getNftId());
|
171
|
+
//if (_instance.hasTreasuryInfo(productNftId)) {
|
172
|
+
ITreasury.TreasuryInfo memory info = _instance.getTreasuryInfo(productNftId);
|
173
|
+
return (info.poolFee, info.stakingFee, info.performanceFee);
|
174
|
+
//} else {
|
175
|
+
// return (_initialPoolFee, _initialStakingFee, _initialPerformanceFee);
|
176
|
+
//}
|
177
|
+
}
|
178
|
+
|
179
|
+
// from IRegisterable
|
180
|
+
|
181
|
+
// TODO used only once, occupies space
|
182
|
+
// TODO do not use super
|
183
|
+
function getInitialInfo()
|
184
|
+
public
|
185
|
+
view
|
186
|
+
override (IRegisterable, Registerable)
|
187
|
+
returns (IRegistry.ObjectInfo memory, bytes memory)
|
188
|
+
{
|
189
|
+
(
|
190
|
+
IRegistry.ObjectInfo memory info,
|
191
|
+
bytes memory data
|
192
|
+
) = super.getInitialInfo();
|
193
|
+
|
194
|
+
return (
|
195
|
+
info,
|
196
|
+
abi.encode(
|
197
|
+
IPool.PoolInfo(
|
198
|
+
_isVerifying,
|
199
|
+
_collateralizationLevel
|
200
|
+
),
|
201
|
+
_wallet,
|
202
|
+
_token,
|
203
|
+
_initialPoolFee,
|
204
|
+
_initialStakingFee,
|
205
|
+
_initialPerformanceFee
|
206
|
+
)
|
207
|
+
);
|
208
|
+
}
|
209
|
+
|
210
|
+
// Internals
|
211
|
+
|
153
212
|
function _underwrite(
|
154
213
|
NftId policyNftId,
|
155
214
|
bytes memory policyData,
|
@@ -184,52 +243,4 @@ contract Pool is BaseComponent, IPoolComponent {
|
|
184
243
|
filter
|
185
244
|
);
|
186
245
|
}
|
187
|
-
|
188
|
-
// from pool component
|
189
|
-
function getPoolFee()
|
190
|
-
external
|
191
|
-
view
|
192
|
-
override
|
193
|
-
returns (Fee memory poolFee)
|
194
|
-
{
|
195
|
-
NftId productNftId = _instance.getProductNftId(getNftId());
|
196
|
-
if (_instance.hasTreasuryInfo(productNftId)) {
|
197
|
-
return _instance.getTreasuryInfo(productNftId).poolFee;
|
198
|
-
} else {
|
199
|
-
return _initialPoolFee;
|
200
|
-
}
|
201
|
-
}
|
202
|
-
|
203
|
-
function getStakingFee()
|
204
|
-
external
|
205
|
-
view
|
206
|
-
override
|
207
|
-
returns (Fee memory stakingFee)
|
208
|
-
{
|
209
|
-
NftId productNftId = _instance.getProductNftId(getNftId());
|
210
|
-
if (_instance.hasTreasuryInfo(productNftId)) {
|
211
|
-
return _instance.getTreasuryInfo(productNftId).stakingFee;
|
212
|
-
} else {
|
213
|
-
return _initialStakingFee;
|
214
|
-
}
|
215
|
-
}
|
216
|
-
|
217
|
-
function getPerformanceFee()
|
218
|
-
external
|
219
|
-
view
|
220
|
-
override
|
221
|
-
returns (Fee memory performanceFee)
|
222
|
-
{
|
223
|
-
NftId productNftId = _instance.getProductNftId(getNftId());
|
224
|
-
if (_instance.hasTreasuryInfo(productNftId)) {
|
225
|
-
return _instance.getTreasuryInfo(productNftId).performanceFee;
|
226
|
-
} else {
|
227
|
-
return _initialPerformanceFee;
|
228
|
-
}
|
229
|
-
}
|
230
|
-
|
231
|
-
// from registerable
|
232
|
-
function getType() public pure override returns (ObjectType) {
|
233
|
-
return POOL();
|
234
|
-
}
|
235
246
|
}
|
@@ -1,41 +1,60 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.19;
|
3
3
|
|
4
|
+
import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
|
5
|
+
|
4
6
|
import {IRisk} from "../instance/module/risk/IRisk.sol";
|
5
7
|
import {ITreasury} from "../instance/module/treasury/ITreasury.sol";
|
6
8
|
import {IProductService} from "../instance/service/IProductService.sol";
|
7
9
|
import {IProductComponent} from "./IProductComponent.sol";
|
8
|
-
import {NftId} from "../types/NftId.sol";
|
10
|
+
import {NftId, zeroNftId} from "../types/NftId.sol";
|
9
11
|
import {ObjectType, PRODUCT} from "../types/ObjectType.sol";
|
10
12
|
import {ReferralId} from "../types/ReferralId.sol";
|
11
13
|
import {RiskId, RiskIdLib} from "../types/RiskId.sol";
|
12
14
|
import {StateId} from "../types/StateId.sol";
|
13
15
|
import {Timestamp} from "../types/Timestamp.sol";
|
14
|
-
import {Fee} from "../types/Fee.sol";
|
16
|
+
import {Fee, FeeLib} from "../types/Fee.sol";
|
15
17
|
import {BaseComponent} from "./BaseComponent.sol";
|
16
18
|
|
19
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
20
|
+
import {IRegisterable} from "../shared/IRegisterable.sol";
|
21
|
+
import {Registerable} from "../shared/Registerable.sol";
|
22
|
+
|
23
|
+
import {IPool} from "../instance/module/pool/IPoolModule.sol";
|
24
|
+
import {Pool} from "../components/Pool.sol";
|
25
|
+
|
17
26
|
contract Product is BaseComponent, IProductComponent {
|
18
27
|
IProductService internal _productService;
|
19
|
-
|
28
|
+
Pool internal _pool;
|
20
29
|
address internal _distribution;
|
21
30
|
Fee internal _initialProductFee;
|
22
31
|
Fee internal _initialProcessingFee;
|
23
32
|
|
33
|
+
NftId internal _poolNftId;
|
34
|
+
NftId internal _distributionNftId;
|
35
|
+
|
24
36
|
constructor(
|
25
37
|
address registry,
|
26
38
|
NftId instanceNftid,
|
27
39
|
address token,
|
40
|
+
bool isInterceptor,
|
28
41
|
address pool,
|
29
42
|
address distribution,
|
30
43
|
Fee memory productFee,
|
31
|
-
Fee memory processingFee
|
32
|
-
|
44
|
+
Fee memory processingFee,
|
45
|
+
address initialOwner
|
46
|
+
) BaseComponent(registry, instanceNftid, token, PRODUCT(), isInterceptor, initialOwner) {
|
33
47
|
// TODO add validation
|
34
48
|
_productService = _instance.getProductService();
|
35
|
-
_pool = pool;
|
49
|
+
_pool = Pool(pool);
|
36
50
|
_distribution = distribution;
|
37
51
|
_initialProductFee = productFee;
|
38
|
-
_initialProcessingFee = processingFee;
|
52
|
+
_initialProcessingFee = processingFee;
|
53
|
+
|
54
|
+
_poolNftId = getRegistry().getNftId(address(_pool));
|
55
|
+
_distributionNftId = getRegistry().getNftId(_distribution);
|
56
|
+
|
57
|
+
_registerInterface(type(IProductComponent).interfaceId);
|
39
58
|
}
|
40
59
|
|
41
60
|
|
@@ -172,11 +191,11 @@ contract Product is BaseComponent, IProductComponent {
|
|
172
191
|
}
|
173
192
|
|
174
193
|
function getPoolNftId() external view override returns (NftId poolNftId) {
|
175
|
-
return
|
194
|
+
return getRegistry().getNftId(address(_pool));
|
176
195
|
}
|
177
196
|
|
178
197
|
function getDistributionNftId() external view override returns (NftId distributionNftId) {
|
179
|
-
return
|
198
|
+
return getRegistry().getNftId(_distribution);
|
180
199
|
}
|
181
200
|
|
182
201
|
// from product component
|
@@ -191,7 +210,7 @@ contract Product is BaseComponent, IProductComponent {
|
|
191
210
|
_productService.setFees(productFee, processingFee);
|
192
211
|
}
|
193
212
|
|
194
|
-
|
213
|
+
// TODO delete, call instance intead
|
195
214
|
function getProductFee()
|
196
215
|
external
|
197
216
|
view
|
@@ -220,8 +239,61 @@ contract Product is BaseComponent, IProductComponent {
|
|
220
239
|
}
|
221
240
|
}
|
222
241
|
|
223
|
-
// from
|
224
|
-
|
225
|
-
|
242
|
+
// from IRegisterable
|
243
|
+
|
244
|
+
// TODO used only once, occupies space
|
245
|
+
function getInitialInfo()
|
246
|
+
public
|
247
|
+
view
|
248
|
+
override (IRegisterable, Registerable)
|
249
|
+
returns (IRegistry.ObjectInfo memory, bytes memory)
|
250
|
+
{
|
251
|
+
// from Registerable
|
252
|
+
(
|
253
|
+
IRegistry.ObjectInfo memory productInfo,
|
254
|
+
bytes memory data
|
255
|
+
) = super.getInitialInfo();
|
256
|
+
|
257
|
+
// TODO read pool & distribution fees
|
258
|
+
// 1) from pool -> the only option -> pool must be registered first?
|
259
|
+
// 2) from instance -> all fees are set into instance at product registration which is ongoing here
|
260
|
+
// checks are done in registryProduct() where THIS function is called
|
261
|
+
//require(getRegistry().getObjectInfo(_poolNftId).objectType == POOL(), "POOL_NOT_REGISTERED");
|
262
|
+
//require(getRegistry().getObjectInfo(_distributionNftId).objectType == DISTRIBUTION(), "DISTRIBUTION_NOT_REGISTERED");
|
263
|
+
|
264
|
+
// from PoolComponent
|
265
|
+
(
|
266
|
+
IRegistry.ObjectInfo memory poolInfo,
|
267
|
+
bytes memory poolData
|
268
|
+
) = _pool.getInitialInfo();
|
269
|
+
|
270
|
+
(
|
271
|
+
/*IPool.PoolInfo memory info*/,
|
272
|
+
/*address wallet*/,
|
273
|
+
/*IERC20Metadata token*/,
|
274
|
+
Fee memory initialPoolFee,
|
275
|
+
Fee memory initialStakingFee,
|
276
|
+
Fee memory initialPerformanceFee
|
277
|
+
) = abi.decode(poolData, (IPool.PoolInfo, address, IERC20Metadata, Fee, Fee, Fee));
|
278
|
+
|
279
|
+
// TODO from DistributionComponent
|
280
|
+
|
281
|
+
return (
|
282
|
+
productInfo,
|
283
|
+
abi.encode(
|
284
|
+
ITreasury.TreasuryInfo(
|
285
|
+
_poolNftId,
|
286
|
+
_distributionNftId,
|
287
|
+
_token,
|
288
|
+
_initialProductFee,
|
289
|
+
_initialProcessingFee,
|
290
|
+
initialPoolFee,
|
291
|
+
initialStakingFee,
|
292
|
+
initialPerformanceFee,
|
293
|
+
FeeLib.zeroFee()//_instance.getDistributionFee(_distributionNftId)
|
294
|
+
),
|
295
|
+
_wallet
|
296
|
+
)
|
297
|
+
);
|
226
298
|
}
|
227
299
|
}
|
@@ -3,12 +3,11 @@ pragma solidity ^0.8.19;
|
|
3
3
|
|
4
4
|
import {IERC165} from "@openzeppelin/contracts/utils/introspection/IERC165.sol";
|
5
5
|
|
6
|
+
import {INftOwnable} from "../shared/INftOwnable.sol";
|
6
7
|
import {IVersionable} from "../shared/IVersionable.sol";
|
7
8
|
import {IRegisterable} from "../shared/IRegisterable.sol";
|
8
|
-
import {IOwnable} from "../shared/IOwnable.sol";
|
9
9
|
import {RoleId} from "../types/RoleId.sol";
|
10
10
|
|
11
|
-
import {IAccessModule} from "./module/access/IAccess.sol";
|
12
11
|
import {IBundleModule} from "./module/bundle/IBundle.sol";
|
13
12
|
import {IDistributionModule} from "./module/distribution/IDistribution.sol";
|
14
13
|
import {IComponentModule} from "./module/component/IComponent.sol";
|
@@ -18,7 +17,7 @@ import {IRiskModule} from "./module/risk/IRisk.sol";
|
|
18
17
|
import {ITreasuryModule} from "./module/treasury/ITreasury.sol";
|
19
18
|
|
20
19
|
import {IKeyValueStore} from "./base/IKeyValueStore.sol";
|
21
|
-
import {IRegistry
|
20
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
22
21
|
|
23
22
|
import {IComponentOwnerService} from "./service/IComponentOwnerService.sol";
|
24
23
|
import {IDistributionService} from "./service/IDistributionService.sol";
|
@@ -31,7 +30,6 @@ interface IInstance is
|
|
31
30
|
IERC165,
|
32
31
|
IVersionable,
|
33
32
|
IRegisterable,
|
34
|
-
IAccessModule,
|
35
33
|
IPolicyModule,
|
36
34
|
IPoolModule,
|
37
35
|
IRiskModule,
|
@@ -41,11 +39,12 @@ interface IInstance is
|
|
41
39
|
IDistributionModule,
|
42
40
|
IInstanceBase
|
43
41
|
{
|
44
|
-
function getRegistry() external view override (
|
45
|
-
function getOwner() external view override
|
42
|
+
function getRegistry() external view override (INftOwnable) returns (IRegistry registry);
|
43
|
+
function getOwner() external view override returns(address owner);
|
46
44
|
|
47
45
|
function getKeyValueStore() external view override (IInstanceBase) returns (IKeyValueStore keyValueStore);
|
48
|
-
|
46
|
+
|
47
|
+
function getComponentOwnerService() external view override (IInstanceBase, IComponentModule, IPoolModule, ITreasuryModule) returns(IComponentOwnerService);
|
49
48
|
function getDistributionService() external view override returns(IDistributionService);
|
50
49
|
function getProductService() external view override (IInstanceBase, IBundleModule, IPolicyModule) returns(IProductService);
|
51
50
|
function getPoolService() external view override (IInstanceBase, IBundleModule, IPoolModule) returns(IPoolService);
|
@@ -2,10 +2,11 @@
|
|
2
2
|
pragma solidity ^0.8.19;
|
3
3
|
|
4
4
|
import {NftId} from "../types/NftId.sol";
|
5
|
+
import {INftOwnable} from "../shared/INftOwnable.sol";
|
6
|
+
import {NftOwnable} from "../shared/NftOwnable.sol";
|
5
7
|
import {RoleId} from "../types/RoleId.sol";
|
6
8
|
|
7
9
|
import {InstanceBase} from "./base/InstanceBase.sol";
|
8
|
-
import {AccessModule} from "./module/access/Access.sol";
|
9
10
|
import {ComponentModule} from "./module/component/ComponentModule.sol";
|
10
11
|
import {DistributionModule} from "./module/distribution/DistributionModule.sol";
|
11
12
|
import {PolicyModule} from "./module/policy/PolicyModule.sol";
|
@@ -16,12 +17,12 @@ import {TreasuryModule} from "./module/treasury/TreasuryModule.sol";
|
|
16
17
|
|
17
18
|
import {IRegistry} from "../registry/IRegistry.sol";
|
18
19
|
import {Registerable} from "../shared/Registerable.sol";
|
19
|
-
import {IAccessModule} from "./module/access/IAccess.sol";
|
20
20
|
import {IBundleModule} from "./module/bundle/IBundle.sol";
|
21
21
|
import {IComponentModule} from "./module/component/IComponent.sol";
|
22
22
|
import {IPoolModule} from "./module/pool/IPoolModule.sol";
|
23
23
|
import {IPolicyModule} from "./module/policy/IPolicy.sol";
|
24
24
|
import {IInstanceBase} from "./base/IInstanceBase.sol";
|
25
|
+
import {ITreasuryModule} from "./module/treasury/ITreasury.sol";
|
25
26
|
|
26
27
|
import {IComponentOwnerService} from "./service/IComponentOwnerService.sol";
|
27
28
|
import {IDistributionService} from "./service/IDistributionService.sol";
|
@@ -32,7 +33,6 @@ import {IKeyValueStore} from "./base/IKeyValueStore.sol";
|
|
32
33
|
|
33
34
|
contract Instance is
|
34
35
|
InstanceBase,
|
35
|
-
AccessModule,
|
36
36
|
BundleModule,
|
37
37
|
ComponentModule,
|
38
38
|
DistributionModule,
|
@@ -43,10 +43,10 @@ contract Instance is
|
|
43
43
|
{
|
44
44
|
constructor(
|
45
45
|
address registry,
|
46
|
-
NftId registryNftId
|
46
|
+
NftId registryNftId,
|
47
|
+
address initialOwner
|
47
48
|
)
|
48
|
-
InstanceBase(registry, registryNftId)
|
49
|
-
AccessModule()
|
49
|
+
InstanceBase(registry, registryNftId, initialOwner)
|
50
50
|
BundleModule()
|
51
51
|
DistributionModule()
|
52
52
|
ComponentModule()
|
@@ -62,13 +62,22 @@ contract Instance is
|
|
62
62
|
initializeRiskModule(_keyValueStore);
|
63
63
|
}
|
64
64
|
|
65
|
-
|
65
|
+
modifier onlyComponentOwnerService() override (ComponentModule, PoolModule, TreasuryModule) {
|
66
|
+
require(
|
67
|
+
msg.sender == address(this.getComponentOwnerService()),
|
68
|
+
"ERROR:CMP-001:NOT_REGISTRY_SERVICE"
|
69
|
+
);
|
70
|
+
_;
|
71
|
+
}
|
72
|
+
|
73
|
+
function getRegistry() public view override (INftOwnable, NftOwnable) returns (IRegistry registry) { return super.getRegistry(); }
|
74
|
+
|
66
75
|
function getKeyValueStore() public view override (InstanceBase) returns (IKeyValueStore keyValueStore) { return super.getKeyValueStore(); }
|
67
76
|
|
68
|
-
function getComponentOwnerService() external view override (IComponentModule,
|
77
|
+
function getComponentOwnerService() external view override (IInstanceBase, IComponentModule, ITreasuryModule, IPoolModule) returns(IComponentOwnerService service) { return _componentOwnerService; }
|
69
78
|
function getDistributionService() external view override (IInstanceBase) returns(IDistributionService service) { return _distributionService; }
|
70
79
|
function getProductService() external view override (IBundleModule, IPolicyModule, IInstanceBase) returns(IProductService service) { return _productService; }
|
71
80
|
function getPoolService() external view override (IBundleModule, IPoolModule, IInstanceBase) returns(IPoolService service) { return _poolService; }
|
72
81
|
|
73
|
-
function getOwner() public view override (
|
82
|
+
function getOwner() public view override (INftOwnable, NftOwnable) returns(address owner) { return super.getOwner(); }
|
74
83
|
}
|
@@ -2,21 +2,23 @@
|
|
2
2
|
pragma solidity ^0.8.19;
|
3
3
|
|
4
4
|
import {IRegistry} from "../../registry/IRegistry.sol";
|
5
|
+
import {IRegistryService} from "../../registry/IRegistryService.sol";
|
5
6
|
import {IInstance} from "../../instance/IInstance.sol";
|
6
7
|
import {ObjectType, INSTANCE, PRODUCT, POOL} from "../../types/ObjectType.sol";
|
7
8
|
import {NftId, NftIdLib} from "../../types/NftId.sol";
|
8
9
|
|
9
10
|
import {ServiceBase} from "./ServiceBase.sol";
|
11
|
+
import {Version, VersionPart, VersionLib} from "../../types/Version.sol";
|
10
12
|
|
11
13
|
abstract contract ComponentServiceBase is ServiceBase {
|
12
14
|
|
13
15
|
constructor(
|
14
16
|
address registry,
|
15
|
-
NftId registryNftId
|
17
|
+
NftId registryNftId,
|
18
|
+
address initialOwner
|
16
19
|
)
|
17
|
-
ServiceBase(registry, registryNftId)
|
18
|
-
// solhint-disable-next-line no-empty-blocks
|
19
20
|
{
|
21
|
+
_initializeServiceBase(registry, registryNftId, initialOwner);
|
20
22
|
}
|
21
23
|
|
22
24
|
|
@@ -30,13 +32,18 @@ abstract contract ComponentServiceBase is ServiceBase {
|
|
30
32
|
IInstance instance
|
31
33
|
)
|
32
34
|
{
|
33
|
-
NftId componentNftId =
|
35
|
+
NftId componentNftId = getRegistry().getNftId(msg.sender);
|
34
36
|
require(componentNftId.gtz(), "ERROR_COMPONENT_UNKNOWN");
|
35
37
|
|
36
|
-
info =
|
38
|
+
info = getRegistry().getObjectInfo(componentNftId);
|
37
39
|
require(info.objectType == objectType, "OBJECT_TYPE_INVALID");
|
38
40
|
|
39
|
-
address instanceAddress =
|
41
|
+
address instanceAddress = getRegistry().getObjectInfo(info.parentNftId).objectAddress;
|
40
42
|
instance = IInstance(instanceAddress);
|
41
43
|
}
|
44
|
+
|
45
|
+
function getRegistryService() public view virtual returns (IRegistryService) {
|
46
|
+
address service = getRegistry().getServiceAddress("RegistryService", getMajorVersion());
|
47
|
+
return IRegistryService(service);
|
48
|
+
}
|
42
49
|
}
|