@etherisc/gif-next 0.0.2-bfb44e0-483 → 0.0.2-c00cf5d-513
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 +8 -84
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +4 -0
- package/artifacts/contracts/{components → distribution}/Distribution.sol/Distribution.json +206 -244
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +4 -0
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +1583 -0
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +855 -0
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +4 -0
- package/artifacts/contracts/{components → distribution}/IDistributionComponent.sol/IDistributionComponent.json +206 -156
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → distribution}/IDistributionService.sol/IDistributionService.json +380 -196
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +68 -54
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +277 -1998
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +172 -230
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +389 -2735
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +692 -0
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +188 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +443 -255
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +217 -479
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +246 -129
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +2847 -0
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +4 -0
- package/artifacts/contracts/instance/{Cloneable.sol → base/Cloneable.sol}/Cloneable.json +6 -1
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.json +49 -0
- package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +93 -14
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +38 -13
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +256 -0
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +25 -150
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +4 -0
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.json +10 -0
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
- package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +1 -1
- package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +4 -0
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +1307 -0
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +767 -0
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → pool}/IBundleService.sol/IBundleService.json +273 -336
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
- package/artifacts/contracts/{components → pool}/IPoolComponent.sol/IPoolComponent.json +386 -185
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +4 -0
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +1077 -0
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +4 -0
- package/artifacts/contracts/{components → pool}/Pool.sol/Pool.json +363 -303
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +1649 -0
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +783 -0
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +4 -0
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +937 -0
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +719 -0
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +4 -0
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +1405 -0
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +819 -0
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → product}/IApplicationService.sol/IApplicationService.json +109 -254
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +4 -0
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +753 -0
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → product}/IPolicyService.sol/IPolicyService.json +174 -307
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service/IPoolService.sol/IPoolService.json → product/IPricingService.sol/IPricingService.json} +235 -237
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +4 -0
- package/artifacts/contracts/{components → product}/IProductComponent.sol/IProductComponent.json +212 -164
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → product}/IProductService.sol/IProductService.json +67 -174
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +1300 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +811 -0
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +4 -0
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +1023 -0
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +759 -0
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +4 -0
- package/artifacts/contracts/{components → product}/Product.sol/Product.json +166 -239
- package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +4 -0
- package/artifacts/contracts/product/ProductService.sol/ProductService.json +891 -0
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +715 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +15 -2
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +123 -19
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +212 -240
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +18 -0
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +146 -34
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +292 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +245 -314
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +240 -123
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +597 -86
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +44 -92
- package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.json +1193 -0
- package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.json +1715 -0
- package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.json +1728 -0
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.json +1806 -0
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.json +1824 -0
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +4 -0
- package/artifacts/contracts/{components → shared}/Component.sol/Component.json +146 -151
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +4 -0
- package/artifacts/contracts/{instance/base → shared}/ComponentService.sol/ComponentService.json +118 -222
- 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/IAccessManagerExtended.sol/IAccessManagerExtended.dbg.json +4 -0
- package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.json +1562 -0
- package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.dbg.json +4 -0
- package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.json +1600 -0
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +4 -0
- package/artifacts/contracts/{components → shared}/IComponent.sol/IComponent.json +190 -74
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +4 -43
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +69 -9
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +4 -43
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.json +0 -34
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +66 -173
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +0 -150
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +19 -91
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +80 -47
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +226 -95
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +32 -89
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -36
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +92 -212
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +24 -6
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +2 -2
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
- package/artifacts/contracts/shared/Versionable.sol/Versionable.json +0 -150
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +4 -0
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +523 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +786 -0
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +699 -0
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/AddressSet.sol/LibAddressSet.json +3 -3
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +4 -0
- package/artifacts/contracts/type/Amount.sol/AmountLib.json +281 -0
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Blocknumber.sol/BlocknumberLib.json +3 -3
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +179 -0
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/DistributorType.sol/DistributorTypeLib.json +5 -5
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +4 -0
- package/artifacts/contracts/type/Fee.sol/FeeLib.json +312 -0
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Key32.sol/Key32Lib.json +3 -3
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +166 -0
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/NftIdSet.sol/LibNftIdSet.json +3 -3
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/ObjectType.sol/ObjectTypeLib.json +3 -3
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +209 -0
- package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +4 -0
- package/artifacts/contracts/type/Referral.sol/ReferralLib.json +142 -0
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/RiskId.sol/RiskIdLib.json +5 -5
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/RoleId.sol/RoleIdLib.json +5 -5
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +4 -0
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +124 -0
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/StateId.sol/StateIdLib.json +3 -3
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Timestamp.sol/TimestampLib.json +39 -8
- package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/UFixed.sol/MathLib.json +3 -3
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/UFixed.sol/UFixedLib.json +3 -3
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Version.sol/VersionLib.json +3 -3
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Version.sol/VersionPartLib.json +3 -3
- package/contracts/{components → distribution}/Distribution.sol +47 -60
- package/contracts/distribution/DistributionService.sol +351 -0
- package/contracts/distribution/DistributionServiceManager.sol +42 -0
- package/contracts/{components → distribution}/IDistributionComponent.sol +8 -37
- package/contracts/distribution/IDistributionService.sol +87 -0
- package/contracts/instance/BundleManager.sol +15 -14
- package/contracts/instance/IInstance.sol +52 -59
- package/contracts/instance/IInstanceService.sol +32 -19
- package/contracts/instance/Instance.sol +138 -185
- package/contracts/instance/InstanceAdmin.sol +330 -0
- package/contracts/instance/InstanceAuthorizationsLib.sol +320 -0
- package/contracts/instance/InstanceReader.sol +101 -26
- package/contracts/instance/InstanceService.sol +173 -307
- package/contracts/instance/InstanceServiceManager.sol +12 -22
- package/contracts/instance/InstanceStore.sol +211 -0
- package/contracts/instance/{Cloneable.sol → base/Cloneable.sol} +8 -3
- package/contracts/instance/base/IKeyValueStore.sol +14 -10
- package/contracts/instance/base/ILifecycle.sol +3 -3
- package/contracts/instance/base/KeyValueStore.sol +44 -47
- package/contracts/instance/base/Lifecycle.sol +28 -7
- package/contracts/instance/{ObjectManager.sol → base/ObjectManager.sol} +12 -14
- package/contracts/instance/module/IAccess.sol +19 -20
- package/contracts/instance/module/IBundle.sol +11 -8
- package/contracts/instance/module/IComponents.sol +41 -0
- package/contracts/instance/module/IDistribution.sol +7 -4
- package/contracts/instance/module/IPolicy.sol +50 -17
- package/contracts/instance/module/IRisk.sol +1 -1
- package/contracts/instance/module/ISetup.sol +9 -23
- package/contracts/instance/module/ITreasury.sol +2 -2
- package/contracts/pool/BundleService.sol +384 -0
- package/contracts/pool/BundleServiceManager.sol +42 -0
- package/contracts/pool/IBundleService.sol +118 -0
- package/contracts/pool/IPoolComponent.sol +114 -0
- package/contracts/pool/IPoolService.sol +114 -0
- package/contracts/pool/Pool.sol +302 -0
- package/contracts/pool/PoolService.sol +404 -0
- package/contracts/pool/PoolServiceManager.sol +42 -0
- package/contracts/product/ApplicationService.sol +187 -0
- package/contracts/product/ApplicationServiceManager.sol +38 -0
- package/contracts/product/ClaimService.sol +443 -0
- package/contracts/product/ClaimServiceManager.sol +38 -0
- package/contracts/{instance/service → product}/IApplicationService.sol +16 -36
- package/contracts/product/IClaimService.sol +93 -0
- package/contracts/product/IPolicyService.sol +80 -0
- package/contracts/product/IPricingService.sol +37 -0
- package/contracts/{components → product}/IProductComponent.sol +13 -11
- package/contracts/{instance/service → product}/IProductService.sol +10 -10
- package/contracts/product/PolicyService.sol +378 -0
- package/contracts/product/PolicyServiceManager.sol +42 -0
- package/contracts/product/PricingService.sol +276 -0
- package/contracts/product/PricingServiceManager.sol +42 -0
- package/contracts/{components → product}/Product.sol +186 -85
- package/contracts/product/ProductService.sol +212 -0
- package/contracts/product/ProductServiceManager.sol +42 -0
- package/contracts/registry/ChainNft.sol +8 -0
- package/contracts/registry/IRegistry.sol +31 -17
- package/contracts/registry/IRegistryService.sol +32 -38
- package/contracts/registry/ITransferInterceptor.sol +1 -0
- package/contracts/registry/Registry.sol +70 -67
- package/contracts/registry/RegistryAdmin.sol +141 -0
- package/contracts/registry/RegistryService.sol +65 -94
- package/contracts/registry/RegistryServiceManager.sol +22 -24
- package/contracts/registry/ReleaseManager.sol +318 -188
- package/contracts/registry/TokenRegistry.sol +19 -14
- package/contracts/shared/AccessManagerCustom.sol +736 -0
- package/contracts/shared/AccessManagerExtended.sol +469 -0
- package/contracts/shared/AccessManagerExtendedInitializeable.sol +13 -0
- package/contracts/shared/AccessManagerExtendedWithDisable.sol +137 -0
- package/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol +14 -0
- package/contracts/{components → shared}/Component.sol +121 -86
- package/contracts/shared/ComponentService.sol +142 -0
- package/contracts/shared/ERC165.sol +2 -1
- package/contracts/shared/IAccessManagerExtended.sol +74 -0
- package/contracts/shared/IAccessManagerExtendedWithDisable.sol +18 -0
- package/contracts/shared/IComponent.sol +90 -0
- package/contracts/shared/INftOwnable.sol +5 -10
- package/contracts/shared/IPolicyHolder.sol +24 -10
- package/contracts/shared/IRegistryLinked.sol +0 -4
- package/contracts/shared/IService.sol +6 -4
- package/contracts/shared/IVersionable.sol +5 -48
- package/contracts/shared/NftOwnable.sol +20 -93
- package/contracts/shared/PolicyHolder.sol +31 -18
- package/contracts/shared/ProxyManager.sol +129 -24
- package/contracts/shared/Registerable.sol +14 -20
- package/contracts/shared/RegistryLinked.sol +5 -26
- package/contracts/shared/Service.sol +30 -18
- package/contracts/shared/TokenHandler.sol +14 -6
- package/contracts/shared/Versionable.sol +1 -90
- package/contracts/staking/IStakingService.sol +102 -0
- package/contracts/staking/StakingService.sol +169 -0
- package/contracts/staking/StakingServiceManager.sol +40 -0
- package/contracts/type/Amount.sol +109 -0
- package/contracts/{types → type}/Blocknumber.sol +1 -0
- package/contracts/type/ClaimId.sol +75 -0
- package/contracts/{types → type}/Fee.sol +17 -8
- package/contracts/{types → type}/NftId.sol +8 -0
- package/contracts/{types → type}/NftIdSet.sol +1 -1
- package/contracts/{types → type}/ObjectType.sol +13 -7
- package/contracts/type/PayoutId.sol +82 -0
- package/contracts/{types → type}/Referral.sol +4 -0
- package/contracts/{types → type}/RoleId.sol +62 -13
- package/contracts/type/Seconds.sol +54 -0
- package/contracts/{types → type}/StateId.sol +7 -2
- package/contracts/{types → type}/Timestamp.sol +18 -13
- package/contracts/{types → type}/UFixed.sol +1 -0
- package/contracts/{types → type}/Version.sol +1 -0
- package/package.json +1 -1
- package/artifacts/contracts/components/Component.sol/Component.dbg.json +0 -4
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +0 -4
- package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +0 -4
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +0 -4
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.json +0 -66
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.json +0 -24
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.json +0 -42
- package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +0 -4
- package/artifacts/contracts/experiment/errors/Require.sol/Require.json +0 -105
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +0 -4
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +0 -105
- package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/A.sol/A.json +0 -128
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +0 -42
- package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/B.sol/B.json +0 -76
- package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/C.sol/C.json +0 -89
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.json +0 -128
- package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.json +0 -37
- package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IB.sol/IB.json +0 -50
- package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IC.sol/IC.json +0 -63
- package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +0 -59
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.json +0 -124
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.json +0 -74
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.json +0 -124
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.json +0 -207
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +0 -4
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.json +0 -10
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +0 -4
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.json +0 -10
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +0 -4
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +0 -4
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +0 -984
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +0 -4
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +0 -261
- package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.json +0 -1117
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +0 -1318
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +0 -586
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +0 -1176
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +0 -602
- package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +0 -1378
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +0 -642
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +0 -957
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +0 -574
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +0 -1007
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +0 -574
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +0 -4
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +0 -285
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +0 -4
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +0 -107
- package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +0 -4
- package/artifacts/contracts/test/TestFee.sol/TestFee.json +0 -119
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +0 -4
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +0 -446
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +0 -4
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +0 -116
- package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +0 -4
- package/artifacts/contracts/test/TestService.sol/TestService.json +0 -759
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +0 -4
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +0 -376
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +0 -4
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +0 -218
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +0 -4
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +0 -286
- package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +0 -4
- package/artifacts/contracts/test/Usdc.sol/USDC.json +0 -376
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +0 -4
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +0 -4
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +0 -10
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +0 -4
- package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +0 -4
- package/artifacts/contracts/types/Fee.sol/FeeLib.json +0 -257
- package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +0 -4
- package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/NftId.sol/NftIdLib.json +0 -153
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +0 -4
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.json +0 -100
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +0 -4
- package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +0 -4
- package/artifacts/contracts/types/Referral.sol/ReferralLib.json +0 -123
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +0 -4
- package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +0 -4
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +0 -4
- package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +0 -4
- package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +0 -4
- package/contracts/components/IComponent.sol +0 -50
- package/contracts/components/IPoolComponent.sol +0 -87
- package/contracts/components/Pool.sol +0 -254
- package/contracts/experiment/cloning/Cloner.sol +0 -47
- package/contracts/experiment/errors/Require.sol +0 -38
- package/contracts/experiment/errors/Revert.sol +0 -44
- package/contracts/experiment/inheritance/A.sol +0 -53
- package/contracts/experiment/inheritance/B.sol +0 -28
- package/contracts/experiment/inheritance/C.sol +0 -34
- package/contracts/experiment/inheritance/IA.sol +0 -13
- package/contracts/experiment/inheritance/IB.sol +0 -10
- package/contracts/experiment/inheritance/IC.sol +0 -12
- package/contracts/experiment/statemachine/Dummy.sol +0 -27
- package/contracts/experiment/statemachine/ISM.sol +0 -25
- package/contracts/experiment/statemachine/SM.sol +0 -57
- package/contracts/experiment/statemachine/SimpleStateMachine.sol +0 -31
- package/contracts/experiment/types/TypeA.sol +0 -47
- package/contracts/experiment/types/TypeB.sol +0 -29
- package/contracts/instance/InstanceAccessManager.sol +0 -297
- package/contracts/instance/base/ComponentService.sol +0 -134
- package/contracts/instance/service/ApplicationService.sol +0 -268
- package/contracts/instance/service/BundleService.sol +0 -298
- package/contracts/instance/service/BundleServiceManager.sol +0 -51
- package/contracts/instance/service/DistributionService.sol +0 -274
- package/contracts/instance/service/DistributionServiceManager.sol +0 -51
- package/contracts/instance/service/IBundleService.sol +0 -54
- package/contracts/instance/service/IDistributionService.sol +0 -65
- package/contracts/instance/service/IPolicyService.sol +0 -88
- package/contracts/instance/service/IPoolService.sol +0 -20
- package/contracts/instance/service/PolicyService.sol +0 -524
- package/contracts/instance/service/PolicyServiceManager.sol +0 -54
- package/contracts/instance/service/PoolService.sol +0 -109
- package/contracts/instance/service/PoolServiceManager.sol +0 -51
- package/contracts/instance/service/ProductService.sol +0 -233
- package/contracts/instance/service/ProductServiceManager.sol +0 -54
- package/contracts/registry/RegistryAccessManager.sol +0 -216
- package/contracts/shared/ContractDeployerLib.sol +0 -72
- package/contracts/test/TestFee.sol +0 -25
- package/contracts/test/TestRegisterable.sol +0 -18
- package/contracts/test/TestRoleId.sol +0 -14
- package/contracts/test/TestService.sol +0 -25
- package/contracts/test/TestToken.sol +0 -26
- package/contracts/test/TestVersion.sol +0 -44
- package/contracts/test/TestVersionable.sol +0 -17
- package/contracts/test/Usdc.sol +0 -26
- package/contracts/types/ChainId.sol +0 -38
- package/contracts/types/NumberId.sol +0 -52
- /package/contracts/{types → type}/AddressSet.sol +0 -0
- /package/contracts/{types → type}/DistributorType.sol +0 -0
- /package/contracts/{types → type}/Key32.sol +0 -0
- /package/contracts/{types → type}/RiskId.sol +0 -0
@@ -1,23 +1,26 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
-
import {SafeERC20} from "@openzeppelin/contracts/token/ERC20/utils/SafeERC20.sol";
|
5
|
-
import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
|
6
4
|
import {AccessManagedUpgradeable} from "@openzeppelin/contracts-upgradeable/access/manager/AccessManagedUpgradeable.sol";
|
5
|
+
import {IAccessManaged} from "@openzeppelin/contracts/access/manager/IAccessManaged.sol";
|
6
|
+
import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
|
7
|
+
import {SafeERC20} from "@openzeppelin/contracts/token/ERC20/utils/SafeERC20.sol";
|
7
8
|
|
8
9
|
import {IComponent} from "./IComponent.sol";
|
9
|
-
import {
|
10
|
+
import {IComponents} from "../instance/module/IComponents.sol";
|
10
11
|
import {IInstanceService} from "../instance/IInstanceService.sol";
|
11
12
|
import {IInstance} from "../instance/IInstance.sol";
|
12
|
-
import {
|
13
|
+
import {InstanceAdmin} from "../instance/InstanceAdmin.sol";
|
13
14
|
import {InstanceReader} from "../instance/InstanceReader.sol";
|
14
15
|
import {IRegistry} from "../registry/IRegistry.sol";
|
15
|
-
import {NftId} from "../
|
16
|
-
import {ObjectType, INSTANCE, PRODUCT} from "../
|
17
|
-
import {VersionPart} from "../
|
16
|
+
import {NftId} from "../type/NftId.sol";
|
17
|
+
import {ObjectType, INSTANCE, PRODUCT} from "../type/ObjectType.sol";
|
18
|
+
import {VersionPart} from "../type/Version.sol";
|
18
19
|
import {Registerable} from "../shared/Registerable.sol";
|
19
|
-
import {RoleId, RoleIdLib} from "../
|
20
|
+
import {RoleId, RoleIdLib} from "../type/RoleId.sol";
|
20
21
|
import {IAccess} from "../instance/module/IAccess.sol";
|
22
|
+
import {TokenHandler} from "../shared/TokenHandler.sol";
|
23
|
+
import {VersionPart} from "../type/Version.sol";
|
21
24
|
|
22
25
|
// TODO discuss to inherit from oz accessmanaged
|
23
26
|
// then add (Distribution|Pool|Product)Upradeable that also intherit from Versionable
|
@@ -28,21 +31,23 @@ abstract contract Component is
|
|
28
31
|
AccessManagedUpgradeable
|
29
32
|
{
|
30
33
|
// keccak256(abi.encode(uint256(keccak256("gif-next.contracts.component.Component.sol")) - 1)) & ~bytes32(uint256(0xff));
|
31
|
-
bytes32 public constant
|
34
|
+
bytes32 public constant COMPONENT_LOCATION_V1 = 0xffe8d4462baed26a47154f4b8f6db497d2f772496965791d25bd456e342b7f00;
|
32
35
|
|
33
36
|
struct ComponentStorage {
|
34
|
-
IInstance _instance; // instance for this component
|
35
|
-
InstanceReader _instanceReader; // instance reader for this component
|
36
37
|
string _name; // unique (per instance) component name
|
37
38
|
IERC20Metadata _token; // token for this component
|
39
|
+
IInstance _instance; // instance for this component
|
38
40
|
address _wallet; // wallet for this component (default = component contract itself)
|
41
|
+
InstanceReader _instanceReader; // instance reader for this component
|
39
42
|
bool _isNftInterceptor; // declares if component is involved in nft transfers
|
40
|
-
IInstanceService _instanceService; // instance service for this component
|
41
|
-
|
42
43
|
NftId _productNftId; // only relevant for components that are linked to a aproduct
|
43
|
-
IProductService _productService; // product service for component, might not be relevant for some component types (eg oracles)
|
44
44
|
}
|
45
45
|
|
46
|
+
function _getComponentStorage() private pure returns (ComponentStorage storage $) {
|
47
|
+
assembly {
|
48
|
+
$.slot := COMPONENT_LOCATION_V1
|
49
|
+
}
|
50
|
+
}
|
46
51
|
|
47
52
|
modifier onlyChainNft() {
|
48
53
|
if(msg.sender != getRegistry().getChainNftAddress()) {
|
@@ -51,20 +56,6 @@ abstract contract Component is
|
|
51
56
|
_;
|
52
57
|
}
|
53
58
|
|
54
|
-
|
55
|
-
modifier onlyProductService() {
|
56
|
-
if(msg.sender != address(_getComponentStorage()._productService)) {
|
57
|
-
revert ErrorComponentNotProductService(msg.sender);
|
58
|
-
}
|
59
|
-
_;
|
60
|
-
}
|
61
|
-
|
62
|
-
function _getComponentStorage() private pure returns (ComponentStorage storage $) {
|
63
|
-
assembly {
|
64
|
-
$.slot := CONTRACT_LOCATION_V1
|
65
|
-
}
|
66
|
-
}
|
67
|
-
|
68
59
|
function initializeComponent(
|
69
60
|
address registry,
|
70
61
|
NftId instanceNftId,
|
@@ -73,78 +64,59 @@ abstract contract Component is
|
|
73
64
|
ObjectType componentType,
|
74
65
|
bool isInterceptor,
|
75
66
|
address initialOwner,
|
76
|
-
bytes memory data
|
67
|
+
bytes memory registryData // writeonly data that will saved in the object info record of the registry
|
77
68
|
)
|
78
69
|
public
|
79
70
|
virtual
|
80
71
|
onlyInitializing()
|
81
72
|
{
|
82
|
-
|
83
|
-
initializeRegisterable(registry, instanceNftId, componentType, isInterceptor, initialOwner, data);
|
84
|
-
|
85
|
-
// set unique name of component
|
86
|
-
$._name = name;
|
87
|
-
$._isNftInterceptor = isInterceptor;
|
73
|
+
initializeRegisterable(registry, instanceNftId, componentType, isInterceptor, initialOwner, registryData);
|
88
74
|
|
89
75
|
// set and check linked instance
|
90
|
-
|
91
|
-
$._instance = IInstance(
|
76
|
+
ComponentStorage storage $ = _getComponentStorage();
|
77
|
+
$._instance = IInstance(
|
78
|
+
getRegistry().getObjectInfo(instanceNftId).objectAddress);
|
79
|
+
|
92
80
|
if(!$._instance.supportsInterface(type(IInstance).interfaceId)) {
|
93
|
-
revert ErrorComponentNotInstance(instanceNftId
|
81
|
+
revert ErrorComponentNotInstance(instanceNftId);
|
94
82
|
}
|
95
83
|
|
96
84
|
// initialize AccessManagedUpgradeable
|
97
85
|
__AccessManaged_init($._instance.authority());
|
98
86
|
|
99
|
-
// set
|
100
|
-
|
101
|
-
$.
|
87
|
+
// set component state
|
88
|
+
$._name = name;
|
89
|
+
$._isNftInterceptor = isInterceptor;
|
102
90
|
$._instanceReader = $._instance.getInstanceReader();
|
103
|
-
$._productService = IProductService(getRegistry().getServiceAddress(PRODUCT(), gifVersion));
|
104
|
-
|
105
|
-
// set wallet and token
|
106
91
|
$._wallet = address(this);
|
107
92
|
$._token = IERC20Metadata(token);
|
108
93
|
|
94
|
+
registerInterface(type(IAccessManaged).interfaceId);
|
109
95
|
registerInterface(type(IComponent).interfaceId);
|
110
96
|
}
|
111
97
|
|
112
|
-
|
113
|
-
|
114
|
-
function nftTransferFrom(address from, address to, uint256 tokenId)
|
115
|
-
external
|
116
|
-
virtual override
|
117
|
-
onlyChainNft()
|
118
|
-
{ }
|
119
|
-
|
120
|
-
// TODO discuss replacement with modifier restricted from accessmanaged
|
121
|
-
function lock() external onlyOwner override {
|
122
|
-
_getComponentStorage()._instanceService.setTargetLocked(getName(), true);
|
98
|
+
function lock() external onlyOwner {
|
99
|
+
IInstanceService(_getServiceAddress(INSTANCE())).setComponentLocked(true);
|
123
100
|
}
|
124
101
|
|
125
|
-
function unlock() external onlyOwner
|
126
|
-
|
102
|
+
function unlock() external onlyOwner {
|
103
|
+
IInstanceService(_getServiceAddress(INSTANCE())).setComponentLocked(false);
|
127
104
|
}
|
128
105
|
|
129
|
-
|
130
|
-
|
131
|
-
external
|
132
|
-
override
|
133
|
-
onlyProductService()
|
134
|
-
{
|
135
|
-
ComponentStorage storage $ = _getComponentStorage();
|
106
|
+
function approveTokenHandler(uint256 spendingLimitAmount) external onlyOwner {
|
107
|
+
IComponents.ComponentInfo memory info = getComponentInfo();
|
136
108
|
|
137
|
-
if(
|
138
|
-
revert
|
109
|
+
if(info.wallet != address(this)) {
|
110
|
+
revert ErrorComponentWalletNotComponent();
|
139
111
|
}
|
140
112
|
|
141
|
-
|
113
|
+
info.token.approve(
|
114
|
+
address(info.tokenHandler),
|
115
|
+
spendingLimitAmount);
|
116
|
+
|
117
|
+
emit LogComponentTokenHandlerApproved(spendingLimitAmount);
|
142
118
|
}
|
143
119
|
|
144
|
-
/// @dev Sets the wallet address for the component.
|
145
|
-
/// if the current wallet has tokens, these will be transferred.
|
146
|
-
/// if the new wallet address is externally owned, an approval from the
|
147
|
-
/// owner of the external wallet for the component to move all tokens must exist.
|
148
120
|
function setWallet(address newWallet)
|
149
121
|
external
|
150
122
|
override
|
@@ -159,8 +131,9 @@ abstract contract Component is
|
|
159
131
|
if (newWallet == address(0)) {
|
160
132
|
revert ErrorComponentWalletAddressZero();
|
161
133
|
}
|
134
|
+
|
162
135
|
if (newWallet == currentWallet) {
|
163
|
-
revert ErrorComponentWalletAddressIsSameAsCurrent(
|
136
|
+
revert ErrorComponentWalletAddressIsSameAsCurrent();
|
164
137
|
}
|
165
138
|
|
166
139
|
if (currentBalance > 0) {
|
@@ -177,7 +150,7 @@ abstract contract Component is
|
|
177
150
|
|
178
151
|
// effects
|
179
152
|
$._wallet = newWallet;
|
180
|
-
emit LogComponentWalletAddressChanged(newWallet);
|
153
|
+
emit LogComponentWalletAddressChanged(currentWallet, newWallet);
|
181
154
|
|
182
155
|
// interactions
|
183
156
|
if (currentBalance > 0) {
|
@@ -192,11 +165,44 @@ abstract contract Component is
|
|
192
165
|
}
|
193
166
|
}
|
194
167
|
|
195
|
-
function
|
196
|
-
|
197
|
-
view
|
168
|
+
function setProductNftId(NftId productNftId)
|
169
|
+
external
|
198
170
|
override
|
199
|
-
|
171
|
+
{
|
172
|
+
ComponentStorage storage $ = _getComponentStorage();
|
173
|
+
|
174
|
+
// verify caller is product service
|
175
|
+
if(msg.sender != _getServiceAddress(PRODUCT())) {
|
176
|
+
revert ErrorComponentNotProductService(msg.sender);
|
177
|
+
}
|
178
|
+
|
179
|
+
// verify component is not yet linked to a product
|
180
|
+
if($._productNftId.gtz()) {
|
181
|
+
revert ErrorComponentProductNftAlreadySet();
|
182
|
+
}
|
183
|
+
|
184
|
+
$._productNftId = productNftId;
|
185
|
+
}
|
186
|
+
|
187
|
+
function nftMint(address to, uint256 tokenId)
|
188
|
+
external
|
189
|
+
virtual
|
190
|
+
onlyChainNft
|
191
|
+
{}
|
192
|
+
|
193
|
+
/// @dev callback function for nft transfers
|
194
|
+
/// may only be called by chain nft contract.
|
195
|
+
/// do not override this function to implement business logic for handling transfers
|
196
|
+
/// override internal function _nftTransferFrom instead
|
197
|
+
function nftTransferFrom(address from, address to, uint256 tokenId)
|
198
|
+
external
|
199
|
+
virtual
|
200
|
+
onlyChainNft
|
201
|
+
{
|
202
|
+
_nftTransferFrom(from, to, tokenId);
|
203
|
+
}
|
204
|
+
|
205
|
+
function getWallet() public view override returns (address walletAddress)
|
200
206
|
{
|
201
207
|
return _getComponentStorage()._wallet;
|
202
208
|
}
|
@@ -205,6 +211,10 @@ abstract contract Component is
|
|
205
211
|
return _getComponentStorage()._token;
|
206
212
|
}
|
207
213
|
|
214
|
+
function getTokenHandler() public view returns (TokenHandler tokenHandler) {
|
215
|
+
return getComponentInfo().tokenHandler;
|
216
|
+
}
|
217
|
+
|
208
218
|
function isNftInterceptor() public view override returns(bool isInterceptor) {
|
209
219
|
return _getComponentStorage()._isNftInterceptor;
|
210
220
|
}
|
@@ -213,10 +223,6 @@ abstract contract Component is
|
|
213
223
|
return _getComponentStorage()._instance;
|
214
224
|
}
|
215
225
|
|
216
|
-
function getInstanceReader() public view returns (InstanceReader reader) {
|
217
|
-
return _getComponentStorage()._instanceReader;
|
218
|
-
}
|
219
|
-
|
220
226
|
function getName() public view override returns(string memory name) {
|
221
227
|
return _getComponentStorage()._name;
|
222
228
|
}
|
@@ -225,12 +231,41 @@ abstract contract Component is
|
|
225
231
|
return _getComponentStorage()._productNftId;
|
226
232
|
}
|
227
233
|
|
228
|
-
function
|
229
|
-
|
234
|
+
function getComponentInfo() public view returns (IComponents.ComponentInfo memory info) {
|
235
|
+
info = _getInstanceReader().getComponentInfo(getNftId());
|
236
|
+
|
237
|
+
// fallback to initial info (wallet is always != address(0))
|
238
|
+
if(info.wallet == address(0)) {
|
239
|
+
info = _getInitialInfo();
|
240
|
+
}
|
230
241
|
}
|
231
242
|
|
232
|
-
|
233
|
-
|
243
|
+
/// @dev defines initial component specification
|
244
|
+
/// overwrite this function according to your use case
|
245
|
+
function _getInitialInfo()
|
246
|
+
internal
|
247
|
+
view
|
248
|
+
virtual
|
249
|
+
returns (IComponents.ComponentInfo memory info)
|
250
|
+
{ }
|
251
|
+
|
252
|
+
|
253
|
+
/// @dev internal function for nft transfers.
|
254
|
+
/// handling logic that deals with nft transfers need to overwrite this function
|
255
|
+
function _nftTransferFrom(address from, address to, uint256 tokenId)
|
256
|
+
internal
|
257
|
+
virtual
|
258
|
+
{ }
|
259
|
+
|
260
|
+
/// @dev returns reader for linked instance
|
261
|
+
function _getInstanceReader() internal view returns (InstanceReader reader) {
|
262
|
+
return _getComponentStorage()._instanceReader;
|
234
263
|
}
|
235
264
|
|
236
|
-
|
265
|
+
/// @dev returns the service address for the specified domain
|
266
|
+
/// gets address via lookup from registry using the major version form the linked instance
|
267
|
+
function _getServiceAddress(ObjectType domain) internal view returns (address service) {
|
268
|
+
VersionPart majorVersion = _getComponentStorage()._instance.getMajorVersion();
|
269
|
+
return getRegistry().getServiceAddress(domain, majorVersion);
|
270
|
+
}
|
271
|
+
}
|
@@ -0,0 +1,142 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.19;
|
3
|
+
|
4
|
+
import {IComponent} from "./IComponent.sol";
|
5
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
6
|
+
import {IRegistryService} from "../registry/IRegistryService.sol";
|
7
|
+
import {IInstance} from "../instance/IInstance.sol";
|
8
|
+
import {IAccess} from "../instance/module/IAccess.sol";
|
9
|
+
import {ObjectType, INSTANCE, REGISTRY} from "../type/ObjectType.sol";
|
10
|
+
import {NftId} from "../type/NftId.sol";
|
11
|
+
import {RoleId} from "../type/RoleId.sol";
|
12
|
+
|
13
|
+
import {Service} from "../shared/Service.sol";
|
14
|
+
import {InstanceService} from "../instance/InstanceService.sol";
|
15
|
+
import {InstanceAdmin} from "../instance/InstanceAdmin.sol";
|
16
|
+
|
17
|
+
abstract contract ComponentService is
|
18
|
+
Service
|
19
|
+
{
|
20
|
+
|
21
|
+
error ErrorComponentServiceNotComponent(address component);
|
22
|
+
error ErrorComponentServiceInvalidType(address component, ObjectType requiredType, ObjectType componentType);
|
23
|
+
error ErrorComponentServiceSenderNotOwner(address component, address initialOwner, address sender);
|
24
|
+
error ErrorComponentServiceExpectedRoleMissing(NftId instanceNftId, RoleId requiredRole, address sender);
|
25
|
+
error ErrorComponentServiceComponentLocked(address component);
|
26
|
+
error ErrorComponentServiceSenderNotService(address sender);
|
27
|
+
error ErrorComponentServiceComponentTypeInvalid(address component, ObjectType expectedType, ObjectType foundType);
|
28
|
+
|
29
|
+
// view functions
|
30
|
+
|
31
|
+
function getRegistryService() public view virtual returns (IRegistryService) {
|
32
|
+
return IRegistryService(_getServiceAddress(REGISTRY()));
|
33
|
+
}
|
34
|
+
|
35
|
+
function getInstanceService() public view returns (InstanceService) {
|
36
|
+
return InstanceService(_getServiceAddress(INSTANCE()));
|
37
|
+
}
|
38
|
+
|
39
|
+
// internal functions
|
40
|
+
function _checkComponentForRegistration(
|
41
|
+
address componentAddress,
|
42
|
+
ObjectType requiredType,
|
43
|
+
RoleId requiredRole
|
44
|
+
)
|
45
|
+
internal
|
46
|
+
view
|
47
|
+
returns (
|
48
|
+
IComponent component,
|
49
|
+
address owner,
|
50
|
+
IInstance instance,
|
51
|
+
NftId instanceNftId
|
52
|
+
)
|
53
|
+
{
|
54
|
+
// component may only be registerd by initial owner of component
|
55
|
+
owner = msg.sender;
|
56
|
+
|
57
|
+
// check this is a component
|
58
|
+
component = IComponent(componentAddress);
|
59
|
+
if(!component.supportsInterface(type(IComponent).interfaceId)) {
|
60
|
+
revert ErrorComponentServiceNotComponent(componentAddress);
|
61
|
+
}
|
62
|
+
|
63
|
+
// check component is of required type
|
64
|
+
IRegistry.ObjectInfo memory componentInfo = component.getInitialInfo();
|
65
|
+
if(componentInfo.objectType != requiredType) {
|
66
|
+
revert ErrorComponentServiceInvalidType(componentAddress, requiredType, componentInfo.objectType);
|
67
|
+
}
|
68
|
+
|
69
|
+
// check msg.sender is component owner
|
70
|
+
address initialOwner = componentInfo.initialOwner;
|
71
|
+
if(owner != initialOwner) {
|
72
|
+
revert ErrorComponentServiceSenderNotOwner(componentAddress, componentInfo.initialOwner, owner);
|
73
|
+
}
|
74
|
+
|
75
|
+
// check instance has assigned required role to owner
|
76
|
+
instanceNftId = componentInfo.parentNftId;
|
77
|
+
instance = _getInstance(instanceNftId);
|
78
|
+
(bool hasRole,) = instance.getInstanceAccessManager().hasRole(requiredRole.toInt(), owner);
|
79
|
+
if(!hasRole) {
|
80
|
+
revert ErrorComponentServiceExpectedRoleMissing(instanceNftId, requiredRole, owner);
|
81
|
+
}
|
82
|
+
}
|
83
|
+
|
84
|
+
// internal view functions
|
85
|
+
function _getAndVerifyCallingComponentAndInstance(
|
86
|
+
ObjectType expectedType // assume always of `component` type
|
87
|
+
)
|
88
|
+
internal
|
89
|
+
view
|
90
|
+
returns(
|
91
|
+
NftId componentNftId,
|
92
|
+
IRegistry.ObjectInfo memory componentInfo,
|
93
|
+
IInstance instance
|
94
|
+
)
|
95
|
+
{
|
96
|
+
componentNftId = getRegistry().getNftId(msg.sender);
|
97
|
+
(componentInfo, instance) = _getAndVerifyComponentInfoAndInstance(componentNftId, expectedType);
|
98
|
+
|
99
|
+
// locked component can not call services
|
100
|
+
if(instance.getInstanceAccessManager().isTargetClosed(componentInfo.objectAddress)) {
|
101
|
+
revert IAccess.ErrorIAccessTargetLocked(componentInfo.objectAddress);
|
102
|
+
}
|
103
|
+
}
|
104
|
+
|
105
|
+
function _getAndVerifyComponentInfoAndInstance(
|
106
|
+
NftId componentNftId,
|
107
|
+
ObjectType expectedType // assume always of `component` type
|
108
|
+
)
|
109
|
+
internal
|
110
|
+
view
|
111
|
+
returns(
|
112
|
+
IRegistry.ObjectInfo memory componentInfo,
|
113
|
+
IInstance instance
|
114
|
+
)
|
115
|
+
{
|
116
|
+
componentInfo = getRegistry().getObjectInfo(componentNftId);
|
117
|
+
if(componentInfo.objectType != expectedType) {
|
118
|
+
revert ErrorComponentServiceComponentTypeInvalid(
|
119
|
+
componentInfo.objectAddress,
|
120
|
+
expectedType,
|
121
|
+
componentInfo.objectType);
|
122
|
+
}
|
123
|
+
|
124
|
+
instance = _getInstance(componentInfo.parentNftId);
|
125
|
+
}
|
126
|
+
// assume componentNftId is always of `instance` type
|
127
|
+
function _getInstance(NftId instanceNftId) internal view returns (IInstance) {
|
128
|
+
return IInstance(
|
129
|
+
getRegistry().getObjectInfo(
|
130
|
+
instanceNftId).objectAddress);
|
131
|
+
}
|
132
|
+
// assume componentNftId is always of `component` type
|
133
|
+
/*function _getInstanceForComponent(NftId componentNftId) internal view returns (IInstance) {
|
134
|
+
NftId instanceNftId = getRegistry().getObjectInfo(componentNftId).parentNftId;
|
135
|
+
address instanceAddress = getRegistry().getObjectInfo(instanceNftId).objectAddress;
|
136
|
+
return IInstance(instanceAddress);
|
137
|
+
}*/
|
138
|
+
|
139
|
+
function _getServiceAddress(ObjectType domain) internal view returns (address) {
|
140
|
+
return getRegistry().getServiceAddress(domain, getVersion().toMajorPart());
|
141
|
+
}
|
142
|
+
}
|
@@ -10,12 +10,13 @@ contract ERC165 is
|
|
10
10
|
{
|
11
11
|
mapping(bytes4 => bool) private _isSupported;
|
12
12
|
|
13
|
-
// @dev
|
13
|
+
// @dev initializes with support for ERC165
|
14
14
|
function initializeERC165() public onlyInitializing() {
|
15
15
|
_isSupported[type(IERC165).interfaceId] = true;
|
16
16
|
}
|
17
17
|
|
18
18
|
// @dev register support for provided interfaceId
|
19
|
+
// includes initialization for ERC165_ID if not yet done
|
19
20
|
function registerInterface(bytes4 interfaceId) public onlyInitializing() {
|
20
21
|
_isSupported[interfaceId] = true;
|
21
22
|
}
|
@@ -0,0 +1,74 @@
|
|
1
|
+
// SPDX-License-Identifier: MIT
|
2
|
+
// OpenZeppelin Contracts (last updated v5.0.0) (access/manager/IAccessManager.sol)
|
3
|
+
|
4
|
+
pragma solidity ^0.8.20;
|
5
|
+
|
6
|
+
import {IAccessManager} from "@openzeppelin/contracts/access/manager/IAccessManager.sol";
|
7
|
+
|
8
|
+
import {Timestamp} from "../type/Timestamp.sol";
|
9
|
+
|
10
|
+
interface IAccessManagerExtended is IAccessManager {
|
11
|
+
// Structure that stores the details for a target contract.
|
12
|
+
struct TargetInfo {
|
13
|
+
address taddress;
|
14
|
+
//IAccess.Type ttype;
|
15
|
+
string name;
|
16
|
+
Timestamp createdAt;
|
17
|
+
//Timestamp updatedAt;
|
18
|
+
}
|
19
|
+
|
20
|
+
// Structure that stores the details of a role.
|
21
|
+
struct RoleInfo {
|
22
|
+
uint64 id;
|
23
|
+
//IAccess.Type rtype;
|
24
|
+
string name;
|
25
|
+
Timestamp createdAt;
|
26
|
+
}
|
27
|
+
|
28
|
+
event LogRoleCreation(uint64 roleId, string name);// IAccess.Type rtype);
|
29
|
+
event LogTargetCreation(address target, string name);// IAccess.Type ttype);
|
30
|
+
|
31
|
+
error AccessManagerRoleIdNotExists(uint64 roleId);
|
32
|
+
error AccessManagerRoleIdAlreadyExists(uint64 roleId);
|
33
|
+
error AccessManagerRoleNameAlreadyExists(uint64 newRoleId, uint64 existingRoleId, string duplicateName);
|
34
|
+
error AccessManagerRoleIdZero();
|
35
|
+
error AccessManagerRoleNameEmpty(uint64 roleId);
|
36
|
+
error AccessManagerRoleIdTooBig(uint64 roleId);
|
37
|
+
|
38
|
+
error AccessManagerTargetAlreadyExists(address target);
|
39
|
+
error AccessManagerTargetNotExists(address target);
|
40
|
+
error AccessManagerTargetNameAlreadyExists(address newTarget, address existingTarget, string duplicateName);
|
41
|
+
error AccessManagerTargetAddressZero();
|
42
|
+
error AccessManagerTargetNameEmpty(address target);
|
43
|
+
error AccessManagerTargetAuthorityInvalid(address target, address targetAuthority);
|
44
|
+
|
45
|
+
function getRoleMembers(uint64 roleId) external view returns (uint256 numberOfMembers);
|
46
|
+
|
47
|
+
function getRoleMember(uint64 roleId, uint256 idx) external view returns (address member);
|
48
|
+
|
49
|
+
function getRoleId(uint256 idx) external view returns (uint64 roleId);
|
50
|
+
|
51
|
+
// TODO returns ADMIN_ROLE id for non existent name
|
52
|
+
function getRoleId(string memory name) external view returns (uint64 roleId);
|
53
|
+
|
54
|
+
function getRoles() external view returns (uint256 numberOfRoles);
|
55
|
+
|
56
|
+
function isRoleExists(uint64 roleId) external view returns (bool exists);
|
57
|
+
|
58
|
+
function getRoleInfo(uint64 roleId) external view returns (RoleInfo memory);
|
59
|
+
|
60
|
+
function isRoleNameExists(string memory name) external view returns (bool);
|
61
|
+
|
62
|
+
function isTargetExists(address target) external view returns (bool);
|
63
|
+
|
64
|
+
function isTargetNameExists(string memory name) external view returns (bool);
|
65
|
+
|
66
|
+
function getTargetAddress(string memory name) external view returns(address targetAddress);
|
67
|
+
|
68
|
+
function getTargetInfo(address target) external view returns (TargetInfo memory);
|
69
|
+
|
70
|
+
|
71
|
+
function createRole(uint64 roleId, string memory roleName/*, IAccess.Type rtype*/) external;
|
72
|
+
|
73
|
+
function createTarget(address target, string memory name/*, IAccess.Type.Custom*/) external;
|
74
|
+
}
|
@@ -0,0 +1,18 @@
|
|
1
|
+
// SPDX-License-Identifier: MIT
|
2
|
+
|
3
|
+
pragma solidity ^0.8.20;
|
4
|
+
|
5
|
+
import {IAccessManagerExtended} from "./IAccessManagerExtended.sol";
|
6
|
+
|
7
|
+
import {Timestamp} from "../type/Timestamp.sol";
|
8
|
+
import {VersionPart} from "../type/Version.sol";
|
9
|
+
import {Seconds} from "../type/Seconds.sol";
|
10
|
+
|
11
|
+
interface IAccessManagerExtendedWithDisable is IAccessManagerExtended {
|
12
|
+
|
13
|
+
error AccessManagerDisabled();
|
14
|
+
|
15
|
+
function disable(Seconds delay) external;
|
16
|
+
function enable() external;
|
17
|
+
function getVersion() external view returns (VersionPart version);
|
18
|
+
}
|
@@ -0,0 +1,90 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {IAccessManaged} from "@openzeppelin/contracts/access/manager/IAccessManaged.sol";
|
5
|
+
import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
|
6
|
+
|
7
|
+
import {IComponents} from "../instance/module/IComponents.sol";
|
8
|
+
import {IInstance} from "../instance/IInstance.sol";
|
9
|
+
import {IInstanceService} from "../instance/IInstanceService.sol";
|
10
|
+
import {IProductService} from "../product/IProductService.sol";
|
11
|
+
import {IRegisterable} from "../shared/IRegisterable.sol";
|
12
|
+
import {ITransferInterceptor} from "../registry/ITransferInterceptor.sol";
|
13
|
+
import {NftId} from "../type/NftId.sol";
|
14
|
+
import {ObjectType} from "../type/ObjectType.sol";
|
15
|
+
import {TokenHandler} from "../shared/TokenHandler.sol";
|
16
|
+
|
17
|
+
/// @dev component base class
|
18
|
+
/// component examples are product, distribution, pool and oracle
|
19
|
+
interface IComponent is
|
20
|
+
IRegisterable,
|
21
|
+
ITransferInterceptor,
|
22
|
+
IAccessManaged
|
23
|
+
{
|
24
|
+
error ErrorComponentNotChainNft(address caller);
|
25
|
+
error ErrorComponentNotProductService(address caller);
|
26
|
+
error ErrorComponentNotInstance(NftId instanceNftId);
|
27
|
+
error ErrorComponentProductNftAlreadySet();
|
28
|
+
|
29
|
+
error ErrorComponentWalletAddressZero();
|
30
|
+
error ErrorComponentWalletAddressIsSameAsCurrent();
|
31
|
+
error ErrorComponentWalletAllowanceTooSmall(address oldWallet, address newWallet, uint256 allowance, uint256 balance);
|
32
|
+
|
33
|
+
error ErrorComponentWalletNotComponent();
|
34
|
+
|
35
|
+
event LogComponentWalletAddressChanged(address oldWallet, address newWallet);
|
36
|
+
event LogComponentWalletTokensTransferred(address from, address to, uint256 amount);
|
37
|
+
|
38
|
+
event LogComponentTokenHandlerApproved(uint256 limit);
|
39
|
+
|
40
|
+
/// @dev locks component to disable functions that may change state related to this component, the only exception is function "unlock"
|
41
|
+
/// only component owner (nft holder) is authorizes to call this function
|
42
|
+
function lock() external;
|
43
|
+
|
44
|
+
/// @dev unlocks component to (re-)enable functions that may change state related to this component
|
45
|
+
/// only component owner (nft holder) is authorizes to call this function
|
46
|
+
function unlock() external;
|
47
|
+
|
48
|
+
/// @dev approves token hanlder to spend up to the specified amount of tokens
|
49
|
+
/// reverts if component wallet is not component itself
|
50
|
+
/// only component owner (nft holder) is authorizes to call this function
|
51
|
+
function approveTokenHandler(uint256 spendingLimitAmount) external;
|
52
|
+
|
53
|
+
/// @dev sets the wallet address for the component
|
54
|
+
/// if the current wallet has tokens, these will be transferred
|
55
|
+
/// if the new wallet address is externally owned, an approval from the
|
56
|
+
/// owner of the external wallet for the component to move all tokens must exist
|
57
|
+
function setWallet(address walletAddress) external;
|
58
|
+
|
59
|
+
/// @dev only product service may set product nft id during registration of product setup
|
60
|
+
function setProductNftId(NftId productNftId) external;
|
61
|
+
|
62
|
+
/// @dev defines the instance to which this component is linked to
|
63
|
+
function getInstance() external view returns (IInstance instance);
|
64
|
+
|
65
|
+
/// @dev returns the name of this component
|
66
|
+
/// to successfully register the component with an instance the name MUST be unique in the linked instance
|
67
|
+
function getName() external view returns (string memory name);
|
68
|
+
|
69
|
+
/// @dev defines which ERC20 token is used by this component
|
70
|
+
function getToken() external view returns (IERC20Metadata token);
|
71
|
+
|
72
|
+
/// @dev returns token handler for this component
|
73
|
+
/// only registered components return a non zero token handler
|
74
|
+
function getTokenHandler() external view returns (TokenHandler tokenHandler);
|
75
|
+
|
76
|
+
/// @dev defines the wallet address used to hold the ERC20 tokens related to this component
|
77
|
+
/// the default address is the component token address
|
78
|
+
function getWallet() external view returns (address walletAddress);
|
79
|
+
|
80
|
+
/// @dev defines the product to which this component is linked to
|
81
|
+
/// this is only relevant for pool and distribution components
|
82
|
+
function getProductNftId() external view returns (NftId productNftId);
|
83
|
+
|
84
|
+
function isNftInterceptor() external view returns(bool isInterceptor);
|
85
|
+
|
86
|
+
/// @dev returns component infos for this pool
|
87
|
+
/// when registered with an instance the info is obtained from the data stored in the instance
|
88
|
+
/// when not registered the function returns the info from the component contract
|
89
|
+
function getComponentInfo() external view returns (IComponents.ComponentInfo memory info);
|
90
|
+
}
|