@etherisc/gif-next 0.0.2-efef0ea-320 → 0.0.2-f02157b-803
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 +144 -26
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +1 -1
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.json +168 -28
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/components/Distribution.sol/Distribution.json +259 -54
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.json +121 -28
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +0 -188
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +0 -238
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +0 -213
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/components/Pool.sol/Pool.json +292 -96
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/components/Product.sol/Product.json +388 -78
- 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 +4 -0
- package/artifacts/contracts/instance/AccessManagedSimple.sol/AccessManagedSimple.json +101 -0
- package/artifacts/contracts/instance/AccessManagerSimple.sol/AccessManagerSimple.dbg.json +4 -0
- package/artifacts/contracts/instance/AccessManagerSimple.sol/AccessManagerSimple.json +1119 -0
- package/artifacts/contracts/instance/IAccessManagerSimple.sol/IAccessManagerSimple.dbg.json +4 -0
- package/artifacts/contracts/instance/IAccessManagerSimple.sol/IAccessManagerSimple.json +1082 -0
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +116 -1813
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +4 -0
- package/artifacts/contracts/instance/{base/InstanceBase.sol/InstanceBase.json → IInstanceService.sol/IInstanceService.json} +127 -169
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +2238 -1251
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +917 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +1257 -0
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +703 -0
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +424 -0
- 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/IKeyValueStore.sol/IKeyValueStore.json +27 -158
- 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/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +37 -245
- 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/base/ServiceBase.sol/ServiceBase.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ServiceBase.sol/ServiceBase.json +140 -59
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +4 -0
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +211 -0
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +4 -0
- package/artifacts/contracts/instance/module/{bundle/IBundle.sol → IBundle.sol}/IBundle.json +1 -1
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +4 -0
- package/artifacts/contracts/instance/module/{distribution/IDistribution.sol → IDistribution.sol}/IDistribution.json +1 -1
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +4 -0
- package/artifacts/contracts/instance/module/{policy/IPolicy.sol → IPolicy.sol}/IPolicy.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +4 -0
- package/artifacts/contracts/instance/module/{risk/IRisk.sol → IRisk.sol}/IRisk.json +1 -1
- package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +4 -0
- package/artifacts/contracts/instance/{base/ModuleBase.sol/ModuleBase.json → module/ISetup.sol/ISetup.json} +2 -2
- package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +4 -0
- package/artifacts/contracts/instance/module/{treasury/ITreasury.sol → ITreasury.sol}/ITreasury.json +1 -1
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +295 -86
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.json +123 -62
- 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/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +186 -12
- 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 +1261 -0
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +504 -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/{instance/module/component/ComponentModule.sol/ComponentModule.json → shared/INftOwnable.sol/INftOwnable.json} +67 -57
- 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/TokenHandler.sol/TokenHandler.dbg.json +4 -0
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +96 -0
- 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/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 +204 -36
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +1 -1
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +14 -14
- package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +1 -1
- package/artifacts/contracts/test/TestService.sol/TestService.json +203 -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 +29 -36
- 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 +4 -0
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.json +104 -0
- 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/Key32.sol/Key32Lib.json +31 -17
- package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/NftId.sol/NftIdLib.json +2 -2
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.json +2 -2
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.json +100 -0
- 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/Referral.sol/ReferralLib.dbg.json +4 -0
- package/artifacts/contracts/types/Referral.sol/ReferralLib.json +123 -0
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.json +2 -2
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +134 -8
- package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/StateId.sol/StateIdLib.json +2 -2
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +15 -2
- 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 +20 -28
- package/contracts/components/Distribution.sol +54 -20
- package/contracts/components/IBaseComponent.sol +8 -3
- package/contracts/components/IDistributionComponent.sol +2 -6
- package/contracts/components/IPoolComponent.sol +2 -11
- package/contracts/components/IProductComponent.sol +4 -7
- package/contracts/components/Pool.sol +100 -76
- package/contracts/components/Product.sol +111 -41
- package/contracts/experiment/cloning/Cloner.sol +47 -0
- package/contracts/instance/AccessManagedSimple.sol +114 -0
- package/contracts/instance/AccessManagerSimple.sol +682 -0
- package/contracts/instance/IAccessManagerSimple.sol +391 -0
- package/contracts/instance/IInstance.sol +17 -42
- package/contracts/instance/IInstanceService.sol +17 -0
- package/contracts/instance/Instance.sol +421 -59
- package/contracts/instance/InstanceAccessManager.sol +288 -0
- package/contracts/instance/InstanceReader.sol +280 -0
- package/contracts/instance/InstanceService.sol +102 -0
- package/contracts/instance/InstanceServiceManager.sol +56 -0
- package/contracts/instance/base/ComponentServiceBase.sol +13 -6
- package/contracts/instance/base/IInstanceBase.sol +3 -2
- package/contracts/instance/base/IKeyValueStore.sol +13 -14
- package/contracts/instance/base/ILifecycle.sol +3 -3
- package/contracts/instance/base/KeyValueStore.sol +49 -38
- package/contracts/instance/base/Lifecycle.sol +1 -1
- package/contracts/instance/base/ServiceBase.sol +20 -13
- package/contracts/instance/module/IAccess.sol +38 -0
- package/contracts/instance/module/IBundle.sol +19 -0
- package/contracts/instance/module/IDistribution.sol +39 -0
- package/contracts/instance/module/IPolicy.sol +45 -0
- package/contracts/instance/module/IRisk.sol +11 -0
- package/contracts/instance/module/ISetup.sol +43 -0
- package/contracts/instance/module/ITreasury.sol +23 -0
- package/contracts/instance/service/ComponentOwnerService.sol +231 -71
- package/contracts/instance/service/IComponentOwnerService.sol +0 -2
- package/contracts/instance/service/IProductService.sol +2 -2
- package/contracts/registry/ChainNft.sol +80 -37
- package/contracts/registry/IRegistry.sol +28 -28
- package/contracts/registry/IRegistryService.sol +35 -0
- package/contracts/registry/ITransferInterceptor.sol +6 -0
- package/contracts/registry/Registry.sol +313 -271
- package/contracts/registry/RegistryService.sol +439 -0
- package/contracts/registry/RegistryServiceManager.sol +64 -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 +46 -15
- package/contracts/shared/NftOwnable.sol +136 -0
- package/contracts/shared/ProxyManager.sol +94 -0
- package/contracts/shared/Registerable.sol +62 -59
- package/contracts/shared/TokenHandler.sol +27 -0
- package/contracts/shared/UpgradableProxyWithAdmin.sol +16 -0
- package/contracts/shared/Versionable.sol +110 -62
- package/contracts/test/TestFee.sol +2 -2
- package/contracts/test/TestRegisterable.sol +5 -6
- package/contracts/test/TestRoleId.sol +1 -1
- package/contracts/test/TestService.sol +5 -11
- package/contracts/types/DistributorType.sol +55 -0
- package/contracts/types/Fee.sol +3 -3
- package/contracts/types/Key32.sol +8 -3
- package/contracts/types/NumberId.sol +52 -0
- package/contracts/types/ObjectType.sol +35 -14
- package/contracts/types/Referral.sol +85 -0
- package/contracts/types/RoleId.sol +53 -9
- package/contracts/types/StateId.sol +1 -1
- package/contracts/types/Timestamp.sol +7 -3
- package/contracts/types/UFixed.sol +128 -12
- package/contracts/types/Version.sol +1 -0
- package/package.json +4 -3
- package/artifacts/contracts/instance/IInstanceLinked.sol/IInstanceLinked.dbg.json +0 -4
- package/artifacts/contracts/instance/IInstanceLinked.sol/IInstanceLinked.json +0 -24
- package/artifacts/contracts/instance/base/InstanceBase.sol/InstanceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/base/ModuleBase.sol/ModuleBase.dbg.json +0 -4
- 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/instance/module/bundle/BundleModule.sol/BundleModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/bundle/BundleModule.sol/BundleModule.json +0 -297
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundle.dbg.json +0 -4
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundleModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundleModule.json +0 -297
- package/artifacts/contracts/instance/module/component/ComponentModule.sol/ComponentModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponent.dbg.json +0 -4
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponent.json +0 -10
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponentModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponentModule.json +0 -117
- package/artifacts/contracts/instance/module/distribution/DistributionModule.sol/DistributionModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/distribution/DistributionModule.sol/DistributionModule.json +0 -10
- package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistribution.dbg.json +0 -4
- package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistributionModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistributionModule.json +0 -10
- package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicy.dbg.json +0 -4
- package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicyModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicyModule.json +0 -284
- package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.json +0 -284
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPool.dbg.json +0 -4
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPool.json +0 -10
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPoolModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPoolModule.json +0 -144
- package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.json +0 -144
- package/artifacts/contracts/instance/module/risk/IRisk.sol/IRisk.dbg.json +0 -4
- package/artifacts/contracts/instance/module/risk/IRisk.sol/IRiskModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/risk/IRisk.sol/IRiskModule.json +0 -113
- package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.json +0 -131
- package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasury.dbg.json +0 -4
- package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasuryModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasuryModule.json +0 -511
- package/artifacts/contracts/instance/module/treasury/TokenHandler.sol/TokenHandler.dbg.json +0 -4
- package/artifacts/contracts/instance/module/treasury/TokenHandler.sol/TokenHandler.json +0 -76
- package/artifacts/contracts/instance/module/treasury/TreasuryModule.sol/TreasuryModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/treasury/TreasuryModule.sol/TreasuryModule.json +0 -511
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +0 -507
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +0 -630
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +0 -945
- package/artifacts/contracts/registry/IChainNft.sol/IChainNft.dbg.json +0 -4
- package/artifacts/contracts/registry/IChainNft.sol/IChainNft.json +0 -452
- 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/test/TestDistribution.sol/TestDistribution.dbg.json +0 -4
- package/artifacts/contracts/test/TestDistribution.sol/TestDistribution.json +0 -405
- package/artifacts/contracts/test/TestPool.sol/TestPool.dbg.json +0 -4
- package/artifacts/contracts/test/TestPool.sol/TestPool.json +0 -578
- package/artifacts/contracts/test/TestProduct.sol/TestProduct.dbg.json +0 -4
- package/artifacts/contracts/test/TestProduct.sol/TestProduct.json +0 -575
- package/artifacts/contracts/types/ReferralId.sol/ReferralIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/ReferralId.sol/ReferralIdLib.json +0 -99
- package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.dbg.json +0 -4
- package/contracts/experiment/statemachine/README.md +0 -112
- package/contracts/instance/IInstanceLinked.sol +0 -8
- package/contracts/instance/base/InstanceBase.sol +0 -91
- package/contracts/instance/base/ModuleBase.sol +0 -57
- package/contracts/instance/module/access/Access.sol +0 -149
- package/contracts/instance/module/access/IAccess.sol +0 -53
- package/contracts/instance/module/bundle/BundleModule.sol +0 -134
- package/contracts/instance/module/bundle/IBundle.sol +0 -53
- package/contracts/instance/module/component/ComponentModule.sol +0 -70
- package/contracts/instance/module/component/IComponent.sol +0 -28
- package/contracts/instance/module/distribution/DistributionModule.sol +0 -17
- package/contracts/instance/module/distribution/IDistribution.sol +0 -10
- package/contracts/instance/module/policy/IPolicy.sol +0 -63
- package/contracts/instance/module/policy/PolicyModule.sol +0 -91
- package/contracts/instance/module/pool/IPoolModule.sol +0 -40
- package/contracts/instance/module/pool/PoolModule.sol +0 -90
- package/contracts/instance/module/risk/IRisk.sol +0 -26
- package/contracts/instance/module/risk/RiskModule.sol +0 -62
- package/contracts/instance/module/treasury/ITreasury.sol +0 -82
- package/contracts/instance/module/treasury/TokenHandler.sol +0 -48
- package/contracts/instance/module/treasury/TreasuryModule.sol +0 -138
- package/contracts/instance/service/DistributionService.sol +0 -59
- package/contracts/instance/service/PoolService.sol +0 -149
- package/contracts/instance/service/ProductService.sol +0 -509
- package/contracts/registry/IChainNft.sol +0 -21
- package/contracts/registry/IRegistryLinked.sol +0 -8
- package/contracts/registry/RegistryUpgradeable.sol +0 -488
- package/contracts/shared/IOwnable.sol +0 -6
- package/contracts/shared/Proxy.sol +0 -94
- package/contracts/shared/VersionableUpgradeable.sol +0 -136
- package/contracts/test/TestDistribution.sol +0 -21
- package/contracts/test/TestPool.sol +0 -25
- package/contracts/test/TestProduct.sol +0 -72
- package/contracts/types/ReferralId.sol +0 -48
@@ -1,82 +0,0 @@
|
|
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
|
-
import {IDistributionComponent} from "../../../components/IDistributionComponent.sol";
|
6
|
-
import {IPoolComponent} from "../../../components/IPoolComponent.sol";
|
7
|
-
import {IProductComponent} from "../../../components/IProductComponent.sol";
|
8
|
-
|
9
|
-
import {NftId} from "../../../types/NftId.sol";
|
10
|
-
import {UFixed} from "../../../types/UFixed.sol";
|
11
|
-
import {Fee} from "../../../types/Fee.sol";
|
12
|
-
|
13
|
-
import {TokenHandler} from "./TokenHandler.sol";
|
14
|
-
|
15
|
-
interface ITreasury {
|
16
|
-
// TODO add events
|
17
|
-
// TODO add errors
|
18
|
-
|
19
|
-
// treasury info is linked to product nft id
|
20
|
-
struct TreasuryInfo {
|
21
|
-
NftId poolNftId;
|
22
|
-
NftId distributionNftId;
|
23
|
-
IERC20Metadata token;
|
24
|
-
Fee productFee; // product fee on net premium
|
25
|
-
Fee processingFee; // product fee on payout amounts
|
26
|
-
Fee poolFee; // pool fee on net premium
|
27
|
-
Fee stakingFee; // pool fee on staked capital from investor
|
28
|
-
Fee performanceFee; // pool fee on profits from capital investors
|
29
|
-
Fee distributionFee; // default distribution fee (no referral id)
|
30
|
-
}
|
31
|
-
}
|
32
|
-
|
33
|
-
interface ITreasuryModule is ITreasury {
|
34
|
-
|
35
|
-
function registerProductSetup(
|
36
|
-
IProductComponent product,
|
37
|
-
IPoolComponent pool,
|
38
|
-
IDistributionComponent distribution
|
39
|
-
) external;
|
40
|
-
|
41
|
-
function setTreasuryInfo(
|
42
|
-
NftId productNftId,
|
43
|
-
TreasuryInfo memory info
|
44
|
-
) external;
|
45
|
-
|
46
|
-
function hasTreasuryInfo(
|
47
|
-
NftId productNftId
|
48
|
-
) external view returns (bool hasInfo);
|
49
|
-
|
50
|
-
function getTreasuryInfo(
|
51
|
-
NftId productNftId
|
52
|
-
) external view returns (TreasuryInfo memory info);
|
53
|
-
|
54
|
-
function getProductNftId(
|
55
|
-
NftId componentNftId
|
56
|
-
) external view returns (NftId productNftId);
|
57
|
-
|
58
|
-
function getTokenHandler(
|
59
|
-
NftId componentNftId
|
60
|
-
) external view returns (TokenHandler tokenHandler);
|
61
|
-
|
62
|
-
function calculateFeeAmount(
|
63
|
-
uint256 amount,
|
64
|
-
Fee memory fee
|
65
|
-
) external pure returns (uint256 feeAmount, uint256 netAmount);
|
66
|
-
|
67
|
-
function getFee(
|
68
|
-
UFixed fractionalFee,
|
69
|
-
uint256 fixedFee
|
70
|
-
) external pure returns (Fee memory fee);
|
71
|
-
|
72
|
-
function getZeroFee() external view returns (Fee memory fee);
|
73
|
-
|
74
|
-
function getUFixed(
|
75
|
-
uint256 a
|
76
|
-
) external pure returns (UFixed);
|
77
|
-
|
78
|
-
function getUFixed(
|
79
|
-
uint256 a,
|
80
|
-
int8 exp
|
81
|
-
) external pure returns (UFixed);
|
82
|
-
}
|
@@ -1,48 +0,0 @@
|
|
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 {NftId} from "../../../types/NftId.sol";
|
7
|
-
|
8
|
-
contract TokenHandler {
|
9
|
-
NftId private _productNftId;
|
10
|
-
IERC20Metadata private _token;
|
11
|
-
|
12
|
-
constructor(
|
13
|
-
NftId productNftId,
|
14
|
-
address token
|
15
|
-
)
|
16
|
-
{
|
17
|
-
_productNftId = productNftId;
|
18
|
-
_token = IERC20Metadata(token);
|
19
|
-
}
|
20
|
-
|
21
|
-
// TODO add logging
|
22
|
-
function transfer(
|
23
|
-
address from,
|
24
|
-
address to,
|
25
|
-
uint256 amount
|
26
|
-
)
|
27
|
-
external // TODO add authz (only treasury/instance/product/pool/ service)
|
28
|
-
{
|
29
|
-
// TODO switch to oz safeTransferFrom
|
30
|
-
_token.transferFrom(from, to, amount);
|
31
|
-
}
|
32
|
-
|
33
|
-
function getProductNftId()
|
34
|
-
external
|
35
|
-
view
|
36
|
-
returns(NftId)
|
37
|
-
{
|
38
|
-
return _productNftId;
|
39
|
-
}
|
40
|
-
|
41
|
-
function getToken()
|
42
|
-
external
|
43
|
-
view
|
44
|
-
returns(IERC20Metadata)
|
45
|
-
{
|
46
|
-
return _token;
|
47
|
-
}
|
48
|
-
}
|
@@ -1,138 +0,0 @@
|
|
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
|
-
import {IDistributionComponent} from "../../../components/IDistributionComponent.sol";
|
6
|
-
import {IPoolComponent} from "../../../components/IPoolComponent.sol";
|
7
|
-
import {IProductComponent} from "../../../components/IProductComponent.sol";
|
8
|
-
|
9
|
-
import {NftId} from "../../../types/NftId.sol";
|
10
|
-
import {TREASURY} from "../../../types/ObjectType.sol";
|
11
|
-
import {Fee, FeeLib} from "../../../types/Fee.sol";
|
12
|
-
import {UFixed, UFixedMathLib} from "../../../types/UFixed.sol";
|
13
|
-
import {TokenHandler} from "./TokenHandler.sol";
|
14
|
-
import {IKeyValueStore} from "../../base/IKeyValueStore.sol";
|
15
|
-
import {ITreasuryModule} from "./ITreasury.sol";
|
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
|
-
|
29
|
-
function initializeTreasuryModule(IKeyValueStore keyValueStore) internal {
|
30
|
-
_initialize(keyValueStore);
|
31
|
-
_zeroFee = FeeLib.zeroFee();
|
32
|
-
}
|
33
|
-
|
34
|
-
function registerProductSetup(
|
35
|
-
IProductComponent product,
|
36
|
-
IPoolComponent pool,
|
37
|
-
IDistributionComponent distribution
|
38
|
-
) external override // TODO add authz (only component module)
|
39
|
-
{
|
40
|
-
NftId productNftId = product.getNftId();
|
41
|
-
NftId poolNftId = pool.getNftId();
|
42
|
-
NftId distributionNftId = distribution.getNftId();
|
43
|
-
|
44
|
-
require(productNftId.gtz(), "ERROR:TRS-010:PRODUCT_UNDEFINED");
|
45
|
-
require(poolNftId.gtz(), "ERROR:TRS-011:POOL_UNDEFINED");
|
46
|
-
|
47
|
-
require(address(_tokenHandler[productNftId]) == address(0), "ERROR:TRS-012:TOKEN_HANDLER_ALREADY_REGISTERED");
|
48
|
-
require(_productNft[poolNftId].eqz(), "ERROR:TRS-013:POOL_ALREADY_LINKED");
|
49
|
-
require(_productNft[distributionNftId].eqz(), "ERROR:TRS-014:COMPENSATION_ALREADY_LINKED");
|
50
|
-
|
51
|
-
// deploy product specific handler contract
|
52
|
-
IERC20Metadata token = product.getToken();
|
53
|
-
_tokenHandler[productNftId] = new TokenHandler(productNftId, address(token));
|
54
|
-
_productNft[distributionNftId] = productNftId;
|
55
|
-
_productNft[poolNftId] = productNftId;
|
56
|
-
|
57
|
-
TreasuryInfo memory info = TreasuryInfo(
|
58
|
-
poolNftId,
|
59
|
-
distributionNftId,
|
60
|
-
token,
|
61
|
-
product.getProductFee(),
|
62
|
-
product.getProcessingFee(),
|
63
|
-
pool.getPoolFee(),
|
64
|
-
pool.getStakingFee(),
|
65
|
-
pool.getPerformanceFee(),
|
66
|
-
distribution.getDistributionFee()
|
67
|
-
);
|
68
|
-
|
69
|
-
_create(TREASURY(), productNftId, abi.encode(info));
|
70
|
-
}
|
71
|
-
|
72
|
-
function setTreasuryInfo(
|
73
|
-
NftId productNftId,
|
74
|
-
TreasuryInfo memory info
|
75
|
-
)
|
76
|
-
external
|
77
|
-
// TODO add authz (only component module)
|
78
|
-
override
|
79
|
-
{
|
80
|
-
_updateData(TREASURY(), productNftId, abi.encode(info));
|
81
|
-
}
|
82
|
-
|
83
|
-
function getProductNftId(
|
84
|
-
NftId componentNftId
|
85
|
-
) external view returns (NftId productNftId) {
|
86
|
-
return _productNft[componentNftId];
|
87
|
-
}
|
88
|
-
|
89
|
-
function getTokenHandler(
|
90
|
-
NftId componentNftId
|
91
|
-
) external view override returns (TokenHandler tokenHandler) {
|
92
|
-
return _tokenHandler[componentNftId];
|
93
|
-
}
|
94
|
-
|
95
|
-
function hasTreasuryInfo(
|
96
|
-
NftId productNftId
|
97
|
-
) public view override returns (bool hasInfo) {
|
98
|
-
return _exists(TREASURY(), productNftId);
|
99
|
-
}
|
100
|
-
|
101
|
-
function getTreasuryInfo(
|
102
|
-
NftId productNftId
|
103
|
-
) public view override returns (TreasuryInfo memory info) {
|
104
|
-
return abi.decode(_getData(TREASURY(), productNftId), (TreasuryInfo));
|
105
|
-
}
|
106
|
-
|
107
|
-
function calculateFeeAmount(
|
108
|
-
uint256 amount,
|
109
|
-
Fee memory fee
|
110
|
-
) public pure override returns (uint256 feeAmount, uint256 netAmount) {
|
111
|
-
return FeeLib.calculateFee(fee, amount);
|
112
|
-
}
|
113
|
-
|
114
|
-
function getFee(
|
115
|
-
UFixed fractionalFee,
|
116
|
-
uint256 fixedFee
|
117
|
-
) external pure override returns (Fee memory fee) {
|
118
|
-
return FeeLib.toFee(fractionalFee, fixedFee);
|
119
|
-
}
|
120
|
-
|
121
|
-
function getZeroFee() external view override returns (Fee memory fee) {
|
122
|
-
return _zeroFee;
|
123
|
-
}
|
124
|
-
|
125
|
-
function getUFixed(
|
126
|
-
uint256 a
|
127
|
-
) external pure override returns (UFixed) {
|
128
|
-
return UFixedMathLib.toUFixed(a);
|
129
|
-
}
|
130
|
-
|
131
|
-
function getUFixed(
|
132
|
-
uint256 a,
|
133
|
-
int8 exp
|
134
|
-
) external pure returns (UFixed)
|
135
|
-
{
|
136
|
-
return UFixedMathLib.toUFixed(a, exp);
|
137
|
-
}
|
138
|
-
}
|
@@ -1,59 +0,0 @@
|
|
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 {ComponentServiceBase} from "../base/ComponentServiceBase.sol";
|
17
|
-
import {IDistributionService} from "./IDistributionService.sol";
|
18
|
-
|
19
|
-
contract DistributionService is
|
20
|
-
ComponentServiceBase,
|
21
|
-
IDistributionService
|
22
|
-
{
|
23
|
-
string public constant NAME = "DistributionService";
|
24
|
-
|
25
|
-
constructor(
|
26
|
-
address registry,
|
27
|
-
NftId registryNftId
|
28
|
-
) ComponentServiceBase(registry, registryNftId) // solhint-disable-next-line no-empty-blocks
|
29
|
-
{
|
30
|
-
_registerInterface(type(IDistributionService).interfaceId);
|
31
|
-
}
|
32
|
-
|
33
|
-
function getVersion()
|
34
|
-
public
|
35
|
-
pure
|
36
|
-
virtual override (IVersionable, Versionable)
|
37
|
-
returns(Version)
|
38
|
-
{
|
39
|
-
return VersionLib.toVersion(3,0,0);
|
40
|
-
}
|
41
|
-
|
42
|
-
function getName() external pure override returns(string memory name) {
|
43
|
-
return NAME;
|
44
|
-
}
|
45
|
-
|
46
|
-
function setFees(
|
47
|
-
Fee memory distributionFee
|
48
|
-
)
|
49
|
-
external
|
50
|
-
override
|
51
|
-
{
|
52
|
-
(IRegistry.ObjectInfo memory distributionInfo, IInstance instance) = _getAndVerifyComponentInfoAndInstance(DISTRIBUTION());
|
53
|
-
|
54
|
-
NftId productNftId = instance.getProductNftId(distributionInfo.nftId);
|
55
|
-
ITreasury.TreasuryInfo memory treasuryInfo = instance.getTreasuryInfo(productNftId);
|
56
|
-
treasuryInfo.distributionFee = distributionFee;
|
57
|
-
instance.setTreasuryInfo(productNftId, treasuryInfo);
|
58
|
-
}
|
59
|
-
}
|
@@ -1,149 +0,0 @@
|
|
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 {IBundle} from "../../instance/module/bundle/IBundle.sol";
|
7
|
-
import {ITreasury, ITreasuryModule, TokenHandler} from "../../instance/module/treasury/ITreasury.sol";
|
8
|
-
|
9
|
-
import {IVersionable} from "../../shared/IVersionable.sol";
|
10
|
-
import {Versionable} from "../../shared/Versionable.sol";
|
11
|
-
|
12
|
-
import {NftId, NftIdLib} from "../../types/NftId.sol";
|
13
|
-
import {POOL, BUNDLE} from "../../types/ObjectType.sol";
|
14
|
-
import {Fee} from "../../types/Fee.sol";
|
15
|
-
import {Version, VersionLib} from "../../types/Version.sol";
|
16
|
-
|
17
|
-
import {ComponentServiceBase} from "../base/ComponentServiceBase.sol";
|
18
|
-
import {IPoolService} from "./IPoolService.sol";
|
19
|
-
|
20
|
-
|
21
|
-
contract PoolService is ComponentServiceBase, IPoolService {
|
22
|
-
using NftIdLib for NftId;
|
23
|
-
|
24
|
-
string public constant NAME = "PoolService";
|
25
|
-
|
26
|
-
constructor(
|
27
|
-
address registry,
|
28
|
-
NftId registryNftId
|
29
|
-
) ComponentServiceBase(registry, registryNftId) // solhint-disable-next-line no-empty-blocks
|
30
|
-
{
|
31
|
-
_registerInterface(type(IPoolService).interfaceId);
|
32
|
-
}
|
33
|
-
|
34
|
-
function getVersion()
|
35
|
-
public
|
36
|
-
pure
|
37
|
-
virtual override (IVersionable, Versionable)
|
38
|
-
returns(Version)
|
39
|
-
{
|
40
|
-
return VersionLib.toVersion(3,0,0);
|
41
|
-
}
|
42
|
-
|
43
|
-
function getName() external pure override returns(string memory name) {
|
44
|
-
return NAME;
|
45
|
-
}
|
46
|
-
|
47
|
-
function setFees(
|
48
|
-
Fee memory poolFee,
|
49
|
-
Fee memory stakingFee,
|
50
|
-
Fee memory performanceFee
|
51
|
-
)
|
52
|
-
external
|
53
|
-
override
|
54
|
-
{
|
55
|
-
(IRegistry.ObjectInfo memory poolInfo, IInstance instance) = _getAndVerifyComponentInfoAndInstance(POOL());
|
56
|
-
|
57
|
-
NftId productNftId = instance.getProductNftId(poolInfo.nftId);
|
58
|
-
ITreasury.TreasuryInfo memory treasuryInfo = instance.getTreasuryInfo(productNftId);
|
59
|
-
treasuryInfo.poolFee = poolFee;
|
60
|
-
treasuryInfo.stakingFee = stakingFee;
|
61
|
-
treasuryInfo.performanceFee = performanceFee;
|
62
|
-
instance.setTreasuryInfo(productNftId, treasuryInfo);
|
63
|
-
}
|
64
|
-
|
65
|
-
function createBundle(
|
66
|
-
address owner,
|
67
|
-
Fee memory fee,
|
68
|
-
uint256 stakingAmount,
|
69
|
-
uint256 lifetime,
|
70
|
-
bytes calldata filter
|
71
|
-
)
|
72
|
-
external
|
73
|
-
override
|
74
|
-
returns(NftId bundleNftId)
|
75
|
-
{
|
76
|
-
(IRegistry.ObjectInfo memory info, IInstance instance) = _getAndVerifyComponentInfoAndInstance(POOL());
|
77
|
-
|
78
|
-
// register bundle with registry
|
79
|
-
NftId poolNftId = info.nftId;
|
80
|
-
bundleNftId = _registry.registerObjectForInstance(
|
81
|
-
poolNftId,
|
82
|
-
BUNDLE(),
|
83
|
-
owner,
|
84
|
-
"");
|
85
|
-
|
86
|
-
// create bundle info in instance
|
87
|
-
instance.createBundleInfo(
|
88
|
-
bundleNftId,
|
89
|
-
poolNftId,
|
90
|
-
fee,
|
91
|
-
stakingAmount,
|
92
|
-
lifetime,
|
93
|
-
filter);
|
94
|
-
|
95
|
-
// add bundle to pool in instance
|
96
|
-
instance.addBundleToPool(
|
97
|
-
bundleNftId,
|
98
|
-
poolNftId,
|
99
|
-
stakingAmount);
|
100
|
-
|
101
|
-
// collect capital
|
102
|
-
_processStakingByTreasury(
|
103
|
-
instance,
|
104
|
-
poolNftId,
|
105
|
-
bundleNftId,
|
106
|
-
stakingAmount);
|
107
|
-
|
108
|
-
// TODO add logging
|
109
|
-
}
|
110
|
-
|
111
|
-
function setBundleFee(
|
112
|
-
NftId bundleNftId,
|
113
|
-
Fee memory fee
|
114
|
-
)
|
115
|
-
external
|
116
|
-
override
|
117
|
-
{
|
118
|
-
(IRegistry.ObjectInfo memory poolInfo, IInstance instance) = _getAndVerifyComponentInfoAndInstance(POOL());
|
119
|
-
IBundle.BundleInfo memory bundleInfo = instance.getBundleInfo(bundleNftId);
|
120
|
-
require(bundleInfo.poolNftId.gtz(), "ERROR:PLS-010:BUNDLE_UNKNOWN");
|
121
|
-
require(poolInfo.nftId == bundleInfo.poolNftId, "ERROR:PLS-011:BUNDLE_POOL_MISMATCH");
|
122
|
-
bundleInfo.fee = fee;
|
123
|
-
instance.setBundleInfo(bundleNftId, bundleInfo);
|
124
|
-
}
|
125
|
-
|
126
|
-
|
127
|
-
function _processStakingByTreasury(
|
128
|
-
IInstance instance,
|
129
|
-
NftId poolNftId,
|
130
|
-
NftId bundleNftId,
|
131
|
-
uint256 stakingAmount
|
132
|
-
)
|
133
|
-
internal
|
134
|
-
{
|
135
|
-
// process token transfer(s)
|
136
|
-
if(stakingAmount > 0) {
|
137
|
-
NftId productNftId = instance.getProductNftId(poolNftId);
|
138
|
-
TokenHandler tokenHandler = instance.getTokenHandler(productNftId);
|
139
|
-
address bundleOwner = _registry.getOwner(bundleNftId);
|
140
|
-
address poolWallet = instance.getComponentWallet(poolNftId);
|
141
|
-
|
142
|
-
tokenHandler.transfer(
|
143
|
-
bundleOwner,
|
144
|
-
poolWallet,
|
145
|
-
stakingAmount
|
146
|
-
);
|
147
|
-
}
|
148
|
-
}
|
149
|
-
}
|