@etherisc/gif-next 0.0.2-bfb44e0-483 → 0.0.2-c0b400a-177
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 -8
- package/artifacts/contracts/components/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/components/Component.sol/Component.json +80 -145
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/components/Distribution.sol/Distribution.json +125 -239
- package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IComponent.sol/IComponent.json +77 -92
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +102 -183
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +261 -201
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +81 -164
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/components/Pool.sol/Pool.json +278 -288
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/components/Product.sol/Product.json +85 -218
- package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +4 -0
- package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +1206 -0
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +64 -50
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +1 -1
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.json +5 -0
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +496 -536
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +105 -212
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +567 -621
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +448 -121
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +120 -227
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +170 -397
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +207 -116
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +1 -1
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +8 -13
- package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.json +18 -220
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +40 -10
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +36 -11
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +54 -71
- 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/instance/service/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.json +182 -331
- package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.json +665 -0
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +141 -366
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +182 -107
- package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.json +754 -0
- package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.json +637 -0
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +824 -268
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +312 -109
- package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.json +124 -206
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.json +89 -257
- package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.json +409 -0
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.json +514 -157
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.json +45 -289
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +69 -153
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.json +12 -177
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +85 -442
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +188 -141
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +116 -249
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +187 -104
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +42 -272
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +179 -104
- 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 +19 -0
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +71 -180
- 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 +31 -12
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +2 -2
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +90 -264
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +182 -113
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +11 -11
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +34 -67
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +1 -1
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +2 -2
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +4 -30
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +4 -30
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.json +0 -21
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +12 -177
- 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 +10 -62
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +2 -23
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +171 -88
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +11 -74
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -23
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +13 -215
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +2 -2
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +2 -2
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
- package/artifacts/contracts/shared/Versionable.sol/Versionable.json +0 -150
- package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +1 -1
- package/artifacts/contracts/test/TestFee.sol/TestFee.json +2 -2
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +1 -1
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +11 -74
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +1 -1
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +6 -6
- package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +1 -1
- package/artifacts/contracts/test/TestService.sol/TestService.json +31 -269
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +1 -1
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +1 -1
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +2 -2
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +1 -1
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +6 -188
- package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +1 -1
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +2 -2
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.json +100 -0
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.json +2 -2
- package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/types/Fee.sol/FeeLib.json +2 -2
- package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/types/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/NftId.sol/NftIdLib.json +17 -4
- 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 +1 -1
- 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/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.json +100 -0
- package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +1 -1
- package/artifacts/contracts/types/Referral.sol/ReferralLib.json +23 -4
- 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 +2 -2
- package/artifacts/contracts/types/Seconds.sol/SecondsLib.dbg.json +4 -0
- package/artifacts/contracts/types/Seconds.sol/SecondsLib.json +124 -0
- 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 +25 -7
- package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +1 -1
- package/artifacts/contracts/types/UFixed.sol/MathLib.json +2 -2
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.json +2 -2
- 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/Component.sol +96 -81
- package/contracts/components/Distribution.sol +29 -47
- package/contracts/components/IComponent.sol +40 -16
- package/contracts/components/IDistributionComponent.sol +1 -30
- package/contracts/components/IPoolComponent.sol +73 -47
- package/contracts/components/IProductComponent.sol +3 -2
- package/contracts/components/Pool.sol +171 -126
- package/contracts/components/Product.sol +38 -23
- package/contracts/instance/AccessManagerUpgradeableInitializeable.sol +13 -0
- package/contracts/instance/BundleManager.sol +7 -5
- package/contracts/instance/Cloneable.sol +7 -2
- package/contracts/instance/IInstance.sol +23 -11
- package/contracts/instance/IInstanceService.sol +18 -5
- package/contracts/instance/Instance.sol +62 -16
- package/contracts/instance/InstanceAccessManager.sol +382 -157
- package/contracts/instance/InstanceReader.sol +7 -10
- package/contracts/instance/InstanceService.sol +222 -160
- package/contracts/instance/InstanceServiceManager.sol +1 -1
- package/contracts/instance/ObjectManager.sol +6 -8
- package/contracts/instance/base/ComponentService.sol +5 -5
- package/contracts/instance/base/KeyValueStore.sol +5 -2
- package/contracts/instance/base/Lifecycle.sol +11 -2
- package/contracts/instance/module/IAccess.sol +20 -13
- package/contracts/instance/module/IBundle.sol +2 -1
- package/contracts/instance/module/IComponents.sol +35 -0
- package/contracts/instance/module/IDistribution.sol +2 -0
- package/contracts/instance/module/IPolicy.sol +30 -3
- package/contracts/instance/module/ISetup.sol +7 -21
- package/contracts/instance/service/ApplicationService.sol +139 -57
- package/contracts/instance/service/ApplicationServiceManager.sol +35 -0
- package/contracts/instance/service/BundleService.sol +76 -38
- package/contracts/instance/service/BundleServiceManager.sol +1 -1
- package/contracts/instance/service/ClaimService.sol +151 -0
- package/contracts/instance/service/ClaimServiceManager.sol +35 -0
- package/contracts/instance/service/DistributionService.sol +224 -31
- package/contracts/instance/service/DistributionServiceManager.sol +1 -1
- package/contracts/instance/service/IApplicationService.sol +9 -9
- package/contracts/instance/service/IBundleService.sol +19 -11
- package/contracts/instance/service/IClaimService.sol +61 -0
- package/contracts/instance/service/IDistributionService.sol +36 -3
- package/contracts/instance/service/IPolicyService.sol +18 -34
- package/contracts/instance/service/IPoolService.sol +17 -2
- package/contracts/instance/service/PolicyService.sol +74 -195
- package/contracts/instance/service/PolicyServiceManager.sol +2 -2
- package/contracts/instance/service/PoolService.sol +128 -17
- package/contracts/instance/service/PoolServiceManager.sol +1 -1
- package/contracts/instance/service/ProductService.sol +10 -2
- package/contracts/instance/service/ProductServiceManager.sol +2 -2
- package/contracts/registry/ChainNft.sol +8 -0
- package/contracts/registry/IRegistry.sol +2 -0
- package/contracts/registry/IRegistryService.sol +10 -8
- package/contracts/registry/ITransferInterceptor.sol +1 -0
- package/contracts/registry/Registry.sol +26 -21
- package/contracts/registry/RegistryService.sol +62 -40
- package/contracts/registry/RegistryServiceManager.sol +13 -13
- package/contracts/registry/ReleaseManager.sol +18 -28
- package/contracts/registry/TokenRegistry.sol +13 -10
- package/contracts/shared/ERC165.sol +2 -1
- package/contracts/shared/INftOwnable.sol +4 -9
- package/contracts/shared/IRegistryLinked.sol +0 -3
- package/contracts/shared/IService.sol +2 -0
- package/contracts/shared/IVersionable.sol +4 -47
- package/contracts/shared/NftOwnable.sol +10 -80
- package/contracts/shared/ProxyManager.sol +98 -24
- package/contracts/shared/Registerable.sol +3 -10
- package/contracts/shared/RegistryLinked.sol +10 -26
- package/contracts/shared/Service.sol +10 -12
- package/contracts/shared/TokenHandler.sol +11 -5
- package/contracts/shared/Versionable.sol +1 -90
- package/contracts/types/Blocknumber.sol +1 -0
- package/contracts/types/ClaimId.sol +52 -0
- package/contracts/types/Fee.sol +1 -0
- package/contracts/types/NftId.sol +8 -0
- package/contracts/types/ObjectType.sol +5 -4
- package/contracts/types/PayoutId.sol +54 -0
- package/contracts/types/Referral.sol +4 -0
- package/contracts/types/RoleId.sol +16 -9
- package/contracts/types/Seconds.sol +54 -0
- package/contracts/types/StateId.sol +1 -0
- package/contracts/types/Timestamp.sol +13 -13
- package/contracts/types/UFixed.sol +1 -0
- package/contracts/types/Version.sol +1 -0
- package/package.json +1 -1
- 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/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
@@ -170,8 +170,8 @@
|
|
170
170
|
"type": "function"
|
171
171
|
}
|
172
172
|
],
|
173
|
-
"bytecode": "
|
174
|
-
"deployedBytecode": "
|
173
|
+
"bytecode": "0x61039161003a600b82828239805160001a60731461002d57634e487b7160e01b600052600060045260246000fd5b30600052607381538281f3fe73000000000000000000000000000000000000000030146080604052600436106100925760003560e01c80638e4ad86c116100655780638e4ad86c1461012157806394aa449c14610144578063a123b37c14610152578063c9e66e291461017957600080fd5b806304b8f6c5146100975780632efe0113146100b357806349a7111a146100c657806355601007146100fd575b600080fd5b60005b60405162ffffff90911681526020015b60405180910390f35b61009a6100c136600461026e565b610190565b6100d96100d436600461029a565b610231565b6040805160ff948516815292841660208401529216918101919091526060016100aa565b61011361010b36600461029a565b62ffffff1690565b6040519081526020016100aa565b61013261012f3660046102c6565b90565b60405160ff90911681526020016100aa565b61009a61012f3660046102df565b61016061010b36600461029a565b60405167ffffffffffffffff90911681526020016100aa565b61013261018736600461029a565b60101c60ff1690565b6000610100841080156101a4575061010083105b80156101b1575061010082105b61020c5760405162461bcd60e51b815260206004820152602260248201527f4552524f523a5652532d3031303a56455253494f4e5f504152545f544f4f5f42604482015261494760f01b606482015260840160405180910390fd5b8161021f600885901b601087901b61031f565b610229919061031f565b949350505050565b600080808360ff601082901c166102488383610338565b915061ffff600883901c16600061025f8185610338565b92989197509195509350505050565b60008060006060848603121561028357600080fd5b505081359360208301359350604090920135919050565b6000602082840312156102ac57600080fd5b813562ffffff811681146102bf57600080fd5b9392505050565b6000602082840312156102d857600080fd5b5035919050565b6000602082840312156102f157600080fd5b813567ffffffffffffffff811681146102bf57600080fd5b634e487b7160e01b600052601160045260246000fd5b8082018082111561033257610332610309565b92915050565b62ffffff82811682821603908082111561035457610354610309565b509291505056fea2646970667358221220801f2c14b03a7330f0c0f9dce2a4a4bea8603a2ffbea5bb26b7564e07c0d257564736f6c63430008140033",
|
174
|
+
"deployedBytecode": "0x73000000000000000000000000000000000000000030146080604052600436106100925760003560e01c80638e4ad86c116100655780638e4ad86c1461012157806394aa449c14610144578063a123b37c14610152578063c9e66e291461017957600080fd5b806304b8f6c5146100975780632efe0113146100b357806349a7111a146100c657806355601007146100fd575b600080fd5b60005b60405162ffffff90911681526020015b60405180910390f35b61009a6100c136600461026e565b610190565b6100d96100d436600461029a565b610231565b6040805160ff948516815292841660208401529216918101919091526060016100aa565b61011361010b36600461029a565b62ffffff1690565b6040519081526020016100aa565b61013261012f3660046102c6565b90565b60405160ff90911681526020016100aa565b61009a61012f3660046102df565b61016061010b36600461029a565b60405167ffffffffffffffff90911681526020016100aa565b61013261018736600461029a565b60101c60ff1690565b6000610100841080156101a4575061010083105b80156101b1575061010082105b61020c5760405162461bcd60e51b815260206004820152602260248201527f4552524f523a5652532d3031303a56455253494f4e5f504152545f544f4f5f42604482015261494760f01b606482015260840160405180910390fd5b8161021f600885901b601087901b61031f565b610229919061031f565b949350505050565b600080808360ff601082901c166102488383610338565b915061ffff600883901c16600061025f8185610338565b92989197509195509350505050565b60008060006060848603121561028357600080fd5b505081359360208301359350604090920135919050565b6000602082840312156102ac57600080fd5b813562ffffff811681146102bf57600080fd5b9392505050565b6000602082840312156102d857600080fd5b5035919050565b6000602082840312156102f157600080fd5b813567ffffffffffffffff811681146102bf57600080fd5b634e487b7160e01b600052601160045260246000fd5b8082018082111561033257610332610309565b92915050565b62ffffff82811682821603908082111561035457610354610309565b509291505056fea2646970667358221220801f2c14b03a7330f0c0f9dce2a4a4bea8603a2ffbea5bb26b7564e07c0d257564736f6c63430008140033",
|
175
175
|
"linkReferences": {},
|
176
176
|
"deployedLinkReferences": {}
|
177
177
|
}
|
@@ -42,8 +42,8 @@
|
|
42
42
|
"type": "function"
|
43
43
|
}
|
44
44
|
],
|
45
|
-
"bytecode": "
|
46
|
-
"deployedBytecode": "
|
45
|
+
"bytecode": "0x60fb610039600b82828239805160001a60731461002c57634e487b7160e01b600052600060045260246000fd5b30600052607381538281f3fe7300000000000000000000000000000000000000003014608060405260043610603d5760003560e01c80638e4ad86c146042578063ac43d834146067575b600080fd5b6050604d3660046085565b90565b60405160ff90911681526020015b60405180910390f35b60786072366004609d565b60ff1690565b604051908152602001605e565b600060208284031215609657600080fd5b5035919050565b60006020828403121560ae57600080fd5b813560ff8116811460be57600080fd5b939250505056fea2646970667358221220cdee50fe6c9714f8463d3a3d707ceac1b02f5c17b070c998ecfbac805f95cace64736f6c63430008140033",
|
46
|
+
"deployedBytecode": "0x7300000000000000000000000000000000000000003014608060405260043610603d5760003560e01c80638e4ad86c146042578063ac43d834146067575b600080fd5b6050604d3660046085565b90565b60405160ff90911681526020015b60405180910390f35b60786072366004609d565b60ff1690565b604051908152602001605e565b600060208284031215609657600080fd5b5035919050565b60006020828403121560ae57600080fd5b813560ff8116811460be57600080fd5b939250505056fea2646970667358221220cdee50fe6c9714f8463d3a3d707ceac1b02f5c17b070c998ecfbac805f95cace64736f6c63430008140033",
|
47
47
|
"linkReferences": {},
|
48
48
|
"deployedLinkReferences": {}
|
49
49
|
}
|
@@ -6,6 +6,7 @@ import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IER
|
|
6
6
|
import {AccessManagedUpgradeable} from "@openzeppelin/contracts-upgradeable/access/manager/AccessManagedUpgradeable.sol";
|
7
7
|
|
8
8
|
import {IComponent} from "./IComponent.sol";
|
9
|
+
import {IComponents} from "../instance/module/IComponents.sol";
|
9
10
|
import {IProductService} from "../instance/service/IProductService.sol";
|
10
11
|
import {IInstanceService} from "../instance/IInstanceService.sol";
|
11
12
|
import {IInstance} from "../instance/IInstance.sol";
|
@@ -18,6 +19,7 @@ import {VersionPart} from "../types/Version.sol";
|
|
18
19
|
import {Registerable} from "../shared/Registerable.sol";
|
19
20
|
import {RoleId, RoleIdLib} from "../types/RoleId.sol";
|
20
21
|
import {IAccess} from "../instance/module/IAccess.sol";
|
22
|
+
import {VersionPart} from "../types/Version.sol";
|
21
23
|
|
22
24
|
// TODO discuss to inherit from oz accessmanaged
|
23
25
|
// then add (Distribution|Pool|Product)Upradeable that also intherit from Versionable
|
@@ -28,21 +30,23 @@ abstract contract Component is
|
|
28
30
|
AccessManagedUpgradeable
|
29
31
|
{
|
30
32
|
// keccak256(abi.encode(uint256(keccak256("gif-next.contracts.component.Component.sol")) - 1)) & ~bytes32(uint256(0xff));
|
31
|
-
bytes32 public constant
|
33
|
+
bytes32 public constant COMPONENT_LOCATION_V1 = 0xffe8d4462baed26a47154f4b8f6db497d2f772496965791d25bd456e342b7f00;
|
32
34
|
|
33
35
|
struct ComponentStorage {
|
34
|
-
IInstance _instance; // instance for this component
|
35
|
-
InstanceReader _instanceReader; // instance reader for this component
|
36
36
|
string _name; // unique (per instance) component name
|
37
37
|
IERC20Metadata _token; // token for this component
|
38
|
+
IInstance _instance; // instance for this component
|
38
39
|
address _wallet; // wallet for this component (default = component contract itself)
|
40
|
+
InstanceReader _instanceReader; // instance reader for this component
|
39
41
|
bool _isNftInterceptor; // declares if component is involved in nft transfers
|
40
|
-
IInstanceService _instanceService; // instance service for this component
|
41
|
-
|
42
42
|
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
43
|
}
|
45
44
|
|
45
|
+
function _getComponentStorage() private pure returns (ComponentStorage storage $) {
|
46
|
+
assembly {
|
47
|
+
$.slot := COMPONENT_LOCATION_V1
|
48
|
+
}
|
49
|
+
}
|
46
50
|
|
47
51
|
modifier onlyChainNft() {
|
48
52
|
if(msg.sender != getRegistry().getChainNftAddress()) {
|
@@ -51,20 +55,6 @@ abstract contract Component is
|
|
51
55
|
_;
|
52
56
|
}
|
53
57
|
|
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
58
|
function initializeComponent(
|
69
59
|
address registry,
|
70
60
|
NftId instanceNftId,
|
@@ -73,78 +63,44 @@ abstract contract Component is
|
|
73
63
|
ObjectType componentType,
|
74
64
|
bool isInterceptor,
|
75
65
|
address initialOwner,
|
76
|
-
bytes memory data
|
66
|
+
bytes memory registryData // writeonly data that will saved in the object info record of the registry
|
77
67
|
)
|
78
68
|
public
|
79
69
|
virtual
|
80
70
|
onlyInitializing()
|
81
71
|
{
|
82
|
-
|
83
|
-
initializeRegisterable(registry, instanceNftId, componentType, isInterceptor, initialOwner, data);
|
84
|
-
|
85
|
-
// set unique name of component
|
86
|
-
$._name = name;
|
87
|
-
$._isNftInterceptor = isInterceptor;
|
72
|
+
initializeRegisterable(registry, instanceNftId, componentType, isInterceptor, initialOwner, registryData);
|
88
73
|
|
89
74
|
// set and check linked instance
|
90
|
-
|
91
|
-
$._instance = IInstance(
|
75
|
+
ComponentStorage storage $ = _getComponentStorage();
|
76
|
+
$._instance = IInstance(
|
77
|
+
getRegistry().getObjectInfo(instanceNftId).objectAddress);
|
78
|
+
|
92
79
|
if(!$._instance.supportsInterface(type(IInstance).interfaceId)) {
|
93
|
-
revert ErrorComponentNotInstance(instanceNftId
|
80
|
+
revert ErrorComponentNotInstance(instanceNftId);
|
94
81
|
}
|
95
82
|
|
96
83
|
// initialize AccessManagedUpgradeable
|
97
84
|
__AccessManaged_init($._instance.authority());
|
98
85
|
|
99
|
-
// set
|
100
|
-
|
101
|
-
$.
|
86
|
+
// set component state
|
87
|
+
$._name = name;
|
88
|
+
$._isNftInterceptor = isInterceptor;
|
102
89
|
$._instanceReader = $._instance.getInstanceReader();
|
103
|
-
$._productService = IProductService(getRegistry().getServiceAddress(PRODUCT(), gifVersion));
|
104
|
-
|
105
|
-
// set wallet and token
|
106
90
|
$._wallet = address(this);
|
107
91
|
$._token = IERC20Metadata(token);
|
108
92
|
|
109
93
|
registerInterface(type(IComponent).interfaceId);
|
110
94
|
}
|
111
95
|
|
112
|
-
/// @dev callback function for nft transfers. may only be called by chain nft contract.
|
113
|
-
/// default implementation is empty. overriding functions MUST add onlyChainNft modifier
|
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
96
|
function lock() external onlyOwner override {
|
122
|
-
|
97
|
+
IInstanceService(_getServiceAddress(INSTANCE())).setComponentLocked(true);
|
123
98
|
}
|
124
99
|
|
125
100
|
function unlock() external onlyOwner override {
|
126
|
-
|
127
|
-
}
|
128
|
-
|
129
|
-
// only product service may set product nft id during registration of product setup
|
130
|
-
function setProductNftId(NftId productNftId)
|
131
|
-
external
|
132
|
-
override
|
133
|
-
onlyProductService()
|
134
|
-
{
|
135
|
-
ComponentStorage storage $ = _getComponentStorage();
|
136
|
-
|
137
|
-
if($._productNftId.gtz()) {
|
138
|
-
revert ErrorComponentProductNftAlreadySet();
|
139
|
-
}
|
140
|
-
|
141
|
-
$._productNftId = productNftId;
|
101
|
+
IInstanceService(_getServiceAddress(INSTANCE())).setComponentLocked(false);
|
142
102
|
}
|
143
103
|
|
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
104
|
function setWallet(address newWallet)
|
149
105
|
external
|
150
106
|
override
|
@@ -159,8 +115,9 @@ abstract contract Component is
|
|
159
115
|
if (newWallet == address(0)) {
|
160
116
|
revert ErrorComponentWalletAddressZero();
|
161
117
|
}
|
118
|
+
|
162
119
|
if (newWallet == currentWallet) {
|
163
|
-
revert ErrorComponentWalletAddressIsSameAsCurrent(
|
120
|
+
revert ErrorComponentWalletAddressIsSameAsCurrent();
|
164
121
|
}
|
165
122
|
|
166
123
|
if (currentBalance > 0) {
|
@@ -177,7 +134,7 @@ abstract contract Component is
|
|
177
134
|
|
178
135
|
// effects
|
179
136
|
$._wallet = newWallet;
|
180
|
-
emit LogComponentWalletAddressChanged(newWallet);
|
137
|
+
emit LogComponentWalletAddressChanged(currentWallet, newWallet);
|
181
138
|
|
182
139
|
// interactions
|
183
140
|
if (currentBalance > 0) {
|
@@ -192,11 +149,44 @@ abstract contract Component is
|
|
192
149
|
}
|
193
150
|
}
|
194
151
|
|
195
|
-
function
|
196
|
-
|
197
|
-
view
|
152
|
+
function setProductNftId(NftId productNftId)
|
153
|
+
external
|
198
154
|
override
|
199
|
-
|
155
|
+
{
|
156
|
+
ComponentStorage storage $ = _getComponentStorage();
|
157
|
+
|
158
|
+
// verify caller is product service
|
159
|
+
if(msg.sender != _getServiceAddress(PRODUCT())) {
|
160
|
+
revert ErrorComponentNotProductService(msg.sender);
|
161
|
+
}
|
162
|
+
|
163
|
+
// verify component is not yet linked to a product
|
164
|
+
if($._productNftId.gtz()) {
|
165
|
+
revert ErrorComponentProductNftAlreadySet();
|
166
|
+
}
|
167
|
+
|
168
|
+
$._productNftId = productNftId;
|
169
|
+
}
|
170
|
+
|
171
|
+
function nftMint(address to, uint256 tokenId)
|
172
|
+
external
|
173
|
+
virtual
|
174
|
+
onlyChainNft
|
175
|
+
{}
|
176
|
+
|
177
|
+
/// @dev callback function for nft transfers
|
178
|
+
/// may only be called by chain nft contract.
|
179
|
+
/// do not override this function to implement business logic for handling transfers
|
180
|
+
/// override internal function _nftTransferFrom instead
|
181
|
+
function nftTransferFrom(address from, address to, uint256 tokenId)
|
182
|
+
external
|
183
|
+
virtual
|
184
|
+
onlyChainNft
|
185
|
+
{
|
186
|
+
_nftTransferFrom(from, to, tokenId);
|
187
|
+
}
|
188
|
+
|
189
|
+
function getWallet() public view override returns (address walletAddress)
|
200
190
|
{
|
201
191
|
return _getComponentStorage()._wallet;
|
202
192
|
}
|
@@ -213,10 +203,6 @@ abstract contract Component is
|
|
213
203
|
return _getComponentStorage()._instance;
|
214
204
|
}
|
215
205
|
|
216
|
-
function getInstanceReader() public view returns (InstanceReader reader) {
|
217
|
-
return _getComponentStorage()._instanceReader;
|
218
|
-
}
|
219
|
-
|
220
206
|
function getName() public view override returns(string memory name) {
|
221
207
|
return _getComponentStorage()._name;
|
222
208
|
}
|
@@ -225,12 +211,41 @@ abstract contract Component is
|
|
225
211
|
return _getComponentStorage()._productNftId;
|
226
212
|
}
|
227
213
|
|
228
|
-
function
|
229
|
-
|
214
|
+
function getComponentInfo() public view returns (IComponents.ComponentInfo memory info) {
|
215
|
+
info = _getInstanceReader().getComponentInfo(getNftId());
|
216
|
+
|
217
|
+
// fallback to initial info (wallet is always != address(0))
|
218
|
+
if(info.wallet == address(0)) {
|
219
|
+
info = _getInitialInfo();
|
220
|
+
}
|
230
221
|
}
|
231
222
|
|
232
|
-
|
233
|
-
|
223
|
+
/// @dev defines initial component specification
|
224
|
+
/// overwrite this function according to your use case
|
225
|
+
function _getInitialInfo()
|
226
|
+
internal
|
227
|
+
view
|
228
|
+
virtual
|
229
|
+
returns (IComponents.ComponentInfo memory info)
|
230
|
+
{ }
|
231
|
+
|
232
|
+
|
233
|
+
/// @dev internal function for nft transfers.
|
234
|
+
/// handling logic that deals with nft transfers need to overwrite this function
|
235
|
+
function _nftTransferFrom(address from, address to, uint256 tokenId)
|
236
|
+
internal
|
237
|
+
virtual
|
238
|
+
{ }
|
239
|
+
|
240
|
+
/// @dev returns reader for linked instance
|
241
|
+
function _getInstanceReader() internal view returns (InstanceReader reader) {
|
242
|
+
return _getComponentStorage()._instanceReader;
|
234
243
|
}
|
235
244
|
|
236
|
-
|
245
|
+
/// @dev returns the service address for the specified domain
|
246
|
+
/// gets address via lookup from registry using the major version form the linked instance
|
247
|
+
function _getServiceAddress(ObjectType domain) internal view returns (address service) {
|
248
|
+
VersionPart majorVersion = _getComponentStorage()._instance.getMajorVersion();
|
249
|
+
return getRegistry().getServiceAddress(domain, majorVersion);
|
250
|
+
}
|
251
|
+
}
|
@@ -4,10 +4,11 @@ pragma solidity ^0.8.19;
|
|
4
4
|
import {DISTRIBUTION} from "../types/ObjectType.sol";
|
5
5
|
import {IDistributionService} from "../instance/service/IDistributionService.sol";
|
6
6
|
import {IProductService} from "../instance/service/IProductService.sol";
|
7
|
-
import {NftId, zeroNftId, NftIdLib} from "../types/NftId.sol";
|
7
|
+
import {NftId, zeroNftId, NftIdLib, toNftId} from "../types/NftId.sol";
|
8
8
|
import {ReferralId, ReferralStatus, ReferralLib} from "../types/Referral.sol";
|
9
9
|
import {Fee, FeeLib} from "../types/Fee.sol";
|
10
10
|
import {Component} from "./Component.sol";
|
11
|
+
import {IDistribution} from "../instance/module/IDistribution.sol";
|
11
12
|
import {IDistributionComponent} from "./IDistributionComponent.sol";
|
12
13
|
import {IRegistry} from "../registry/IRegistry.sol";
|
13
14
|
import {IRegisterable} from "../shared/IRegisterable.sol";
|
@@ -17,40 +18,44 @@ import {TokenHandler} from "../shared/TokenHandler.sol";
|
|
17
18
|
import {InstanceReader} from "../instance/InstanceReader.sol";
|
18
19
|
import {UFixed} from "../types/UFixed.sol";
|
19
20
|
import {DistributorType} from "../types/DistributorType.sol";
|
20
|
-
import {Timestamp} from "../types/Timestamp.sol";
|
21
|
+
import {Timestamp, TimestampLib} from "../types/Timestamp.sol";
|
22
|
+
import {ITransferInterceptor} from "../registry/ITransferInterceptor.sol";
|
21
23
|
|
22
24
|
|
23
25
|
abstract contract Distribution is
|
24
26
|
Component,
|
25
27
|
IDistributionComponent
|
26
28
|
{
|
29
|
+
// keccak256(abi.encode(uint256(keccak256("etherisc.storage.Distribution")) - 1)) & ~bytes32(uint256(0xff));
|
30
|
+
bytes32 public constant DISTRIBUTION_STORAGE_LOCATION_V1 = 0xaab7c5ea03d290056d6c060e0833d3ebcbe647f7694616a2ec52738a64b2f900;
|
31
|
+
|
27
32
|
struct DistributionStorage {
|
33
|
+
Fee _minDistributionOwnerFee;
|
28
34
|
Fee _distributionFee;
|
29
35
|
TokenHandler _tokenHandler;
|
30
36
|
IDistributionService _distributionService;
|
31
37
|
mapping(address distributor => NftId distributorNftId) _distributorNftId;
|
32
38
|
}
|
33
39
|
|
34
|
-
// keccak256(abi.encode(uint256(keccak256("etherisc.storage.Distribution")) - 1)) & ~bytes32(uint256(0xff));
|
35
|
-
bytes32 public constant DISTRIBUTION_STORAGE_LOCATION_V1 = 0xaab7c5ea03d290056d6c060e0833d3ebcbe647f7694616a2ec52738a64b2f900;
|
36
|
-
|
37
40
|
function initializeDistribution(
|
38
41
|
address registry,
|
39
42
|
NftId instanceNftId,
|
40
43
|
string memory name,
|
41
44
|
address token,
|
45
|
+
Fee memory minDistributionOwnerFee,
|
42
46
|
Fee memory distributionFee,
|
43
47
|
address initialOwner,
|
44
|
-
bytes memory data
|
48
|
+
bytes memory registryData // writeonly data that will saved in the object info record of the registry
|
45
49
|
)
|
46
50
|
public
|
47
51
|
virtual
|
48
52
|
onlyInitializing()
|
49
53
|
{
|
50
|
-
initializeComponent(registry, instanceNftId, name, token, DISTRIBUTION(), true, initialOwner,
|
54
|
+
initializeComponent(registry, instanceNftId, name, token, DISTRIBUTION(), true, initialOwner, registryData);
|
51
55
|
|
52
56
|
DistributionStorage storage $ = _getDistributionStorage();
|
53
57
|
// TODO add validation
|
58
|
+
$._minDistributionOwnerFee = minDistributionOwnerFee;
|
54
59
|
$._distributionFee = distributionFee;
|
55
60
|
$._tokenHandler = new TokenHandler(token);
|
56
61
|
$._distributionService = getInstance().getDistributionService();
|
@@ -59,6 +64,7 @@ abstract contract Distribution is
|
|
59
64
|
}
|
60
65
|
|
61
66
|
function setFees(
|
67
|
+
Fee memory minDistributionOwnerFee,
|
62
68
|
Fee memory distributionFee
|
63
69
|
)
|
64
70
|
external
|
@@ -66,7 +72,7 @@ abstract contract Distribution is
|
|
66
72
|
onlyOwner
|
67
73
|
restricted()
|
68
74
|
{
|
69
|
-
_getDistributionStorage()._distributionService.setFees(distributionFee);
|
75
|
+
_getDistributionStorage()._distributionService.setFees(minDistributionOwnerFee, distributionFee);
|
70
76
|
}
|
71
77
|
|
72
78
|
function getDistributionFee() external view returns (Fee memory distributionFee) {
|
@@ -140,7 +146,7 @@ abstract contract Distribution is
|
|
140
146
|
* @dev lets distributors create referral codes.
|
141
147
|
* referral codes need to be unique
|
142
148
|
*/
|
143
|
-
function
|
149
|
+
function _createReferral(
|
144
150
|
NftId distributorNftId,
|
145
151
|
string memory code,
|
146
152
|
UFixed discountPercentage,
|
@@ -148,8 +154,7 @@ abstract contract Distribution is
|
|
148
154
|
Timestamp expiryAt,
|
149
155
|
bytes memory data
|
150
156
|
)
|
151
|
-
|
152
|
-
// TODO add authz (only active distributor)
|
157
|
+
internal
|
153
158
|
returns (ReferralId referralId)
|
154
159
|
{
|
155
160
|
DistributionStorage storage $ = _getDistributionStorage();
|
@@ -162,22 +167,6 @@ abstract contract Distribution is
|
|
162
167
|
data);
|
163
168
|
}
|
164
169
|
|
165
|
-
function calculateFeeAmount(
|
166
|
-
ReferralId referralId,
|
167
|
-
uint256 netPremiumAmount
|
168
|
-
)
|
169
|
-
external
|
170
|
-
view
|
171
|
-
virtual override
|
172
|
-
returns (uint256 feeAmount)
|
173
|
-
{
|
174
|
-
ISetup.DistributionSetupInfo memory setupInfo = getSetupInfo();
|
175
|
-
Fee memory fee = setupInfo.distributionFee;
|
176
|
-
(feeAmount,) = FeeLib.calculateFee(fee, netPremiumAmount);
|
177
|
-
// TODO: use this?
|
178
|
-
// return _distributionService.calculateFeeAmount(referralId, premiumAmount);
|
179
|
-
}
|
180
|
-
|
181
170
|
function isDistributor(address candidate)
|
182
171
|
public
|
183
172
|
view
|
@@ -205,7 +194,7 @@ abstract contract Distribution is
|
|
205
194
|
)
|
206
195
|
{
|
207
196
|
ReferralId referralId = getReferralId(referralCode);
|
208
|
-
return
|
197
|
+
return _getInstanceReader().getDiscountPercentage(referralId);
|
209
198
|
}
|
210
199
|
|
211
200
|
|
@@ -234,19 +223,6 @@ abstract contract Distribution is
|
|
234
223
|
return 0 * netPremiumAmount;
|
235
224
|
}
|
236
225
|
|
237
|
-
function processSale(
|
238
|
-
ReferralId referralId,
|
239
|
-
uint256 premiumAmount
|
240
|
-
)
|
241
|
-
external
|
242
|
-
onlyOwner
|
243
|
-
restricted()
|
244
|
-
virtual override
|
245
|
-
{
|
246
|
-
DistributionStorage storage $ = _getDistributionStorage();
|
247
|
-
$._distributionService.processSale(referralId, premiumAmount);
|
248
|
-
}
|
249
|
-
|
250
226
|
function processRenewal(
|
251
227
|
ReferralId referralId,
|
252
228
|
uint256 feeAmount
|
@@ -259,11 +235,6 @@ abstract contract Distribution is
|
|
259
235
|
// default is no action
|
260
236
|
}
|
261
237
|
|
262
|
-
function referralIsValid(ReferralId referralId) external view returns (bool isValid) {
|
263
|
-
// default is invalid
|
264
|
-
return false;
|
265
|
-
}
|
266
|
-
|
267
238
|
function getSetupInfo() public view returns (ISetup.DistributionSetupInfo memory setupInfo) {
|
268
239
|
InstanceReader reader = getInstance().getInstanceReader();
|
269
240
|
setupInfo = reader.getDistributionSetupInfo(getNftId());
|
@@ -279,10 +250,21 @@ abstract contract Distribution is
|
|
279
250
|
return ISetup.DistributionSetupInfo(
|
280
251
|
zeroNftId(),
|
281
252
|
$._tokenHandler,
|
253
|
+
$._minDistributionOwnerFee,
|
282
254
|
$._distributionFee,
|
283
|
-
address(this)
|
255
|
+
address(this),
|
256
|
+
0
|
284
257
|
);
|
285
258
|
}
|
259
|
+
|
260
|
+
|
261
|
+
function _nftTransferFrom(address from, address to, uint256 tokenId) internal virtual override {
|
262
|
+
// keep track of distributor nft owner
|
263
|
+
emit LogDistributorUpdated(to, msg.sender);
|
264
|
+
DistributionStorage storage $ = _getDistributionStorage();
|
265
|
+
$._distributorNftId[from] = zeroNftId();
|
266
|
+
$._distributorNftId[to] = toNftId(tokenId);
|
267
|
+
}
|
286
268
|
|
287
269
|
|
288
270
|
/// @dev returns true iff the component needs to be called when selling/renewing policis
|
@@ -3,48 +3,72 @@ pragma solidity ^0.8.20;
|
|
3
3
|
|
4
4
|
import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
|
5
5
|
|
6
|
-
import {
|
6
|
+
import {IComponents} from "../instance/module/IComponents.sol";
|
7
7
|
import {IInstance} from "../instance/IInstance.sol";
|
8
8
|
import {IInstanceService} from "../instance/IInstanceService.sol";
|
9
9
|
import {IProductService} from "../instance/service/IProductService.sol";
|
10
|
+
import {IRegisterable} from "../shared/IRegisterable.sol";
|
10
11
|
import {ITransferInterceptor} from "../registry/ITransferInterceptor.sol";
|
11
12
|
import {NftId} from "../types/NftId.sol";
|
13
|
+
import {ObjectType} from "../types/ObjectType.sol";
|
12
14
|
|
15
|
+
/// @dev component base class
|
16
|
+
/// component examples are product, distribution, pool and oracle
|
13
17
|
interface IComponent is
|
14
18
|
IRegisterable,
|
15
19
|
ITransferInterceptor
|
16
20
|
{
|
17
|
-
|
18
21
|
error ErrorComponentNotChainNft(address caller);
|
19
22
|
error ErrorComponentNotProductService(address caller);
|
20
|
-
error ErrorComponentNotInstance(NftId instanceNftId
|
23
|
+
error ErrorComponentNotInstance(NftId instanceNftId);
|
21
24
|
error ErrorComponentProductNftAlreadySet();
|
25
|
+
|
22
26
|
error ErrorComponentWalletAddressZero();
|
23
|
-
error ErrorComponentWalletAddressIsSameAsCurrent(
|
27
|
+
error ErrorComponentWalletAddressIsSameAsCurrent();
|
24
28
|
error ErrorComponentWalletAllowanceTooSmall(address oldWallet, address newWallet, uint256 allowance, uint256 balance);
|
25
|
-
error ErrorComponentUnauthorized(address caller, uint64 requiredRoleIdNum);
|
26
29
|
|
27
|
-
event LogComponentWalletAddressChanged(address newWallet);
|
30
|
+
event LogComponentWalletAddressChanged(address oldWallet, address newWallet);
|
28
31
|
event LogComponentWalletTokensTransferred(address from, address to, uint256 amount);
|
29
32
|
|
30
|
-
|
31
|
-
|
32
|
-
// TODO remove and replace with accessmanaged target locking mechanism
|
33
|
+
/// @dev locks component to disable functions that may change state related to this component, the only exception is function "unlock"
|
34
|
+
/// only component owner (nft holder) is authorizes to call this function
|
33
35
|
function lock() external;
|
34
|
-
function unlock() external;
|
35
36
|
|
36
|
-
|
37
|
+
/// @dev unlocks component to (re-)enable functions that may change state related to this component
|
38
|
+
/// only component owner (nft holder) is authorizes to call this function
|
39
|
+
function unlock() external;
|
37
40
|
|
41
|
+
/// @dev sets the wallet address for the component
|
42
|
+
/// if the current wallet has tokens, these will be transferred
|
43
|
+
/// if the new wallet address is externally owned, an approval from the
|
44
|
+
/// owner of the external wallet for the component to move all tokens must exist
|
38
45
|
function setWallet(address walletAddress) external;
|
39
|
-
function getWallet() external view returns (address walletAddress);
|
40
46
|
|
41
|
-
|
47
|
+
/// @dev only product service may set product nft id during registration of product setup
|
48
|
+
function setProductNftId(NftId productNftId) external;
|
49
|
+
|
50
|
+
/// @dev returns the name of this component
|
51
|
+
/// to successfully register the component with an instance the name MUST be unique in the linked instance
|
52
|
+
function getName() external view returns (string memory name);
|
53
|
+
|
54
|
+
/// @dev defines which ERC20 token is used by this component
|
55
|
+
function getToken() external view returns (IERC20Metadata token);
|
42
56
|
|
57
|
+
/// @dev defines the instance to which this component is linked to
|
43
58
|
function getInstance() external view returns (IInstance instance);
|
44
59
|
|
45
|
-
|
60
|
+
/// @dev defines the wallet address used to hold the ERC20 tokens related to this component
|
61
|
+
/// the default address is the component token address
|
62
|
+
function getWallet() external view returns (address walletAddress);
|
63
|
+
|
64
|
+
/// @dev defines the product to which this component is linked to
|
65
|
+
/// this is only relevant for pool and distribution components
|
46
66
|
function getProductNftId() external view returns (NftId productNftId);
|
47
67
|
|
48
|
-
function
|
49
|
-
|
68
|
+
function isNftInterceptor() external view returns(bool isInterceptor);
|
69
|
+
|
70
|
+
/// @dev returns component infos for this pool
|
71
|
+
/// when registered with an instance the info is obtained from the data stored in the instance
|
72
|
+
/// when not registered the function returns the info from the component contract
|
73
|
+
function getComponentInfo() external view returns (IComponents.ComponentInfo memory info);
|
50
74
|
}
|
@@ -17,6 +17,7 @@ interface IDistributionComponent is IComponent {
|
|
17
17
|
function getSetupInfo() external view returns (ISetup.DistributionSetupInfo memory setupInfo);
|
18
18
|
|
19
19
|
function setFees(
|
20
|
+
Fee memory minDistributionOwnerFee,
|
20
21
|
Fee memory distributionFee
|
21
22
|
) external;
|
22
23
|
|
@@ -44,38 +45,11 @@ interface IDistributionComponent is IComponent {
|
|
44
45
|
bytes memory data
|
45
46
|
) external;
|
46
47
|
|
47
|
-
/**
|
48
|
-
* @dev lets distributors create referral codes.
|
49
|
-
* referral codes need to be unique
|
50
|
-
* distributor is identified via msg.sender.
|
51
|
-
*/
|
52
|
-
function createReferral(
|
53
|
-
NftId distributorNftId,
|
54
|
-
string memory code,
|
55
|
-
UFixed discountPercentage,
|
56
|
-
uint32 maxReferrals,
|
57
|
-
Timestamp expiryAt,
|
58
|
-
bytes memory data
|
59
|
-
) external returns (ReferralId referralId);
|
60
|
-
|
61
|
-
function calculateFeeAmount(
|
62
|
-
ReferralId referralId,
|
63
|
-
uint256 netPremiumAmount
|
64
|
-
) external view returns (uint256 feeAmount);
|
65
|
-
|
66
48
|
function calculateRenewalFeeAmount(
|
67
49
|
ReferralId referralId,
|
68
50
|
uint256 netPremiumAmount
|
69
51
|
) external view returns (uint256 feeAmount);
|
70
52
|
|
71
|
-
/// @dev callback from product service when selling a policy for a specific referralId
|
72
|
-
/// the used referral id and the collected fee are provided as parameters
|
73
|
-
/// the component implementation can then process this information accordingly
|
74
|
-
function processSale(
|
75
|
-
ReferralId referralId,
|
76
|
-
uint256 feeAmount
|
77
|
-
) external;
|
78
|
-
|
79
53
|
/// @dev callback from product service when a policy is renews for a specific referralId
|
80
54
|
function processRenewal(
|
81
55
|
ReferralId referralId,
|
@@ -92,9 +66,6 @@ interface IDistributionComponent is IComponent {
|
|
92
66
|
string memory referralCode
|
93
67
|
) external returns (ReferralId referralId);
|
94
68
|
|
95
|
-
/// @dev returns true iff the referral id is valid
|
96
|
-
function referralIsValid(ReferralId referralId) external view returns (bool isValid);
|
97
|
-
|
98
69
|
/// @dev returns true iff the component needs to be called when selling/renewing policis
|
99
70
|
function isVerifying() external view returns (bool verifying);
|
100
71
|
}
|