@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
@@ -3,84 +3,77 @@ pragma solidity ^0.8.20;
|
|
3
3
|
|
4
4
|
import {IAccessManaged} from "@openzeppelin/contracts/access/manager/IAccessManaged.sol";
|
5
5
|
|
6
|
-
import {
|
7
|
-
import {
|
8
|
-
import {
|
9
|
-
|
6
|
+
import {ClaimId} from "../type/ClaimId.sol";
|
7
|
+
import {DistributorType} from "../type/DistributorType.sol";
|
8
|
+
import {PayoutId} from "../type/PayoutId.sol";
|
9
|
+
import {NftId} from "../type/NftId.sol";
|
10
|
+
import {StateId} from "../type/StateId.sol";
|
11
|
+
import {ReferralId} from "../type/Referral.sol";
|
12
|
+
import {RiskId} from "../type/RiskId.sol";
|
13
|
+
import {VersionPart} from "../type/Version.sol";
|
14
|
+
import {Key32} from "../type/Key32.sol";
|
15
|
+
import {RoleId} from "../type/RoleId.sol";
|
16
|
+
|
17
|
+
import {AccessManagerExtendedInitializeable} from "../shared/AccessManagerExtendedInitializeable.sol";
|
10
18
|
import {IRegisterable} from "../shared/IRegisterable.sol";
|
11
19
|
|
12
|
-
import {
|
20
|
+
import {ITransferInterceptor} from "../registry/ITransferInterceptor.sol";
|
21
|
+
|
22
|
+
import {InstanceAdmin} from "./InstanceAdmin.sol";
|
13
23
|
import {BundleManager} from "./BundleManager.sol";
|
14
24
|
import {InstanceReader} from "./InstanceReader.sol";
|
25
|
+
import {InstanceStore} from "./InstanceStore.sol";
|
15
26
|
|
16
|
-
import {IBundle} from "./module/IBundle.sol";
|
17
|
-
import {IBundleService} from "./service/IBundleService.sol";
|
18
|
-
import {IDistributionService} from "./service/IDistributionService.sol";
|
19
|
-
import {InstanceAccessManager} from "./InstanceAccessManager.sol";
|
20
27
|
import {IKeyValueStore} from "./base/IKeyValueStore.sol";
|
21
|
-
import {IPolicy} from "./module/IPolicy.sol";
|
22
|
-
import {IDistribution} from "./module/IDistribution.sol";
|
23
|
-
import {IPolicyService} from "./service/IPolicyService.sol";
|
24
|
-
import {IPoolService} from "./service/IPoolService.sol";
|
25
|
-
import {IProductService} from "./service/IProductService.sol";
|
26
|
-
import {IPolicyService} from "./service/IPolicyService.sol";
|
27
|
-
import {IBundleService} from "./service/IBundleService.sol";
|
28
|
-
import {IRisk} from "./module/IRisk.sol";
|
29
|
-
import {ISetup} from "./module/ISetup.sol";
|
30
|
-
import {NftId} from "../types/NftId.sol";
|
31
|
-
import {RiskId} from "../types/RiskId.sol";
|
32
|
-
import {StateId} from "../types/StateId.sol";
|
33
|
-
import {VersionPart} from "../types/Version.sol";
|
34
|
-
import {Key32} from "../types/Key32.sol";
|
35
28
|
|
29
|
+
import {IAccess} from "./module/IAccess.sol";
|
36
30
|
|
31
|
+
import {IBundleService} from "../pool/IBundleService.sol";
|
32
|
+
import {IDistributionService} from "../distribution/IDistributionService.sol";
|
33
|
+
import {IPolicyService} from "../product/IPolicyService.sol";
|
34
|
+
import {IPoolService} from "../pool/IPoolService.sol";
|
35
|
+
import {IProductService} from "../product/IProductService.sol";
|
36
|
+
import {IPolicyService} from "../product/IPolicyService.sol";
|
37
|
+
import {IBundleService} from "../pool/IBundleService.sol";
|
37
38
|
|
38
39
|
|
39
|
-
interface IInstance is IRegisterable, IKeyValueStore, IAccessManaged {
|
40
|
-
|
41
|
-
function getDistributionService() external view returns (IDistributionService);
|
42
|
-
function getProductService() external view returns (IProductService);
|
43
|
-
function getPoolService() external view returns (IPoolService);
|
44
|
-
function getPolicyService() external view returns (IPolicyService);
|
45
|
-
function getBundleService() external view returns (IBundleService);
|
46
40
|
|
47
|
-
|
48
|
-
|
49
|
-
|
41
|
+
interface IInstance is
|
42
|
+
IRegisterable,
|
43
|
+
ITransferInterceptor,
|
44
|
+
IAccessManaged
|
45
|
+
{
|
46
|
+
error ErrorInstanceInstanceAdminZero();
|
47
|
+
error ErrorInstanceInstanceAdminAlreadySet(address InstanceAdmin);
|
48
|
+
error ErrorInstanceInstanceAdminAuthorityMismatch(address instanceAuthority);
|
50
49
|
|
51
|
-
|
52
|
-
|
53
|
-
|
50
|
+
error ErrorInstanceBundleManagerAlreadySet(address instanceBundleManager);
|
51
|
+
error ErrorInstanceBundleManagerInstanceMismatch(address instance);
|
52
|
+
error ErrorInstanceBundleManagerAuthorityMismatch(address instanceAuthority);
|
54
53
|
|
55
|
-
|
56
|
-
function updateBundle(NftId bundleNftId, IBundle.BundleInfo memory bundle, StateId newState) external;
|
57
|
-
function updateBundleState(NftId bundleNftId, StateId newState) external;
|
54
|
+
error ErrorInstanceInstanceReaderInstanceMismatch(address instanceAuthority);
|
58
55
|
|
59
|
-
|
60
|
-
|
61
|
-
function updateProductSetupState(NftId productNftId, StateId newState) external;
|
56
|
+
error ErrorInstanceInstanceStoreAlreadySet(address instanceStore);
|
57
|
+
error ErrorInstanceInstanceStoreAuthorityMismatch(address instanceAuthority);
|
62
58
|
|
63
|
-
function
|
64
|
-
function
|
65
|
-
function
|
59
|
+
function createRole(string memory roleName, string memory adminName) external returns (RoleId roleId, RoleId admin);
|
60
|
+
function grantRole(RoleId roleId, address account) external;
|
61
|
+
function revokeRole(RoleId roleId, address account) external;
|
66
62
|
|
67
|
-
function
|
68
|
-
function
|
69
|
-
function
|
63
|
+
function createTarget(address target, string memory name) external;
|
64
|
+
function setTargetFunctionRole(string memory targetName, bytes4[] calldata selectors, RoleId roleId) external;
|
65
|
+
function setTargetLocked(address target, bool locked) external;
|
70
66
|
|
71
|
-
function
|
72
|
-
function
|
73
|
-
function
|
74
|
-
|
75
|
-
function
|
76
|
-
function updateRisk(RiskId riskId, IRisk.RiskInfo memory risk, StateId newState) external;
|
77
|
-
function updateRiskState(RiskId riskId, StateId newState) external;
|
78
|
-
|
79
|
-
function createPolicy(NftId policyNftId, IPolicy.PolicyInfo memory policy) external;
|
80
|
-
function updatePolicy(NftId policyNftId, IPolicy.PolicyInfo memory policy, StateId newState) external;
|
81
|
-
function updatePolicyState(NftId policyNftId, StateId newState) external;
|
67
|
+
function getDistributionService() external view returns (IDistributionService);
|
68
|
+
function getProductService() external view returns (IProductService);
|
69
|
+
function getPoolService() external view returns (IPoolService);
|
70
|
+
function getPolicyService() external view returns (IPolicyService);
|
71
|
+
function getBundleService() external view returns (IBundleService);
|
82
72
|
|
83
73
|
function getMajorVersion() external pure returns (VersionPart majorVersion);
|
84
74
|
function getInstanceReader() external view returns (InstanceReader);
|
85
75
|
function getBundleManager() external view returns (BundleManager);
|
76
|
+
function getInstanceAdmin() external view returns (InstanceAdmin);
|
77
|
+
function getInstanceStore() external view returns (InstanceStore);
|
78
|
+
function getInstanceAccessManager() external view returns (AccessManagerExtendedInitializeable);
|
86
79
|
}
|
@@ -1,24 +1,22 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
-
import {NftId} from "../
|
5
|
-
import {ObjectType} from "../
|
6
|
-
import {RoleId} from "../
|
4
|
+
import {NftId} from "../type/NftId.sol";
|
5
|
+
import {ObjectType} from "../type/ObjectType.sol";
|
6
|
+
import {RoleId} from "../type/RoleId.sol";
|
7
7
|
import {IService} from "../shared/IService.sol";
|
8
|
-
import {IRegistry} from "../registry/IRegistry.sol";
|
9
8
|
|
10
|
-
import {
|
11
|
-
import {IComponent} from "../components/IComponent.sol";
|
12
|
-
|
13
|
-
import {InstanceAccessManager} from "./InstanceAccessManager.sol";
|
9
|
+
import {InstanceAdmin} from "./InstanceAdmin.sol";
|
14
10
|
import {Instance} from "./Instance.sol";
|
15
11
|
import {InstanceReader} from "./InstanceReader.sol";
|
16
12
|
import {BundleManager} from "./BundleManager.sol";
|
13
|
+
import {InstanceStore} from "./InstanceStore.sol";
|
17
14
|
|
18
15
|
interface IInstanceService is IService {
|
19
16
|
|
20
17
|
error ErrorInstanceServiceMasterInstanceAlreadySet();
|
21
|
-
error
|
18
|
+
error ErrorInstanceServiceMasterOzAccessManagerAlreadySet();
|
19
|
+
error ErrorInstanceServiceMasterInstanceAdminAlreadySet();
|
22
20
|
error ErrorInstanceServiceMasterBundleManagerAlreadySet();
|
23
21
|
error ErrorInstanceServiceInstanceAddressZero();
|
24
22
|
|
@@ -27,33 +25,48 @@ interface IInstanceService is IService {
|
|
27
25
|
error ErrorInstanceServiceInstanceReaderSameAsMasterInstanceReader();
|
28
26
|
error ErrorInstanceServiceInstanceReaderInstanceMismatch();
|
29
27
|
|
30
|
-
error
|
28
|
+
error ErrorInstanceServiceInstanceAdminZero();
|
31
29
|
error ErrorInstanceServiceInstanceReaderZero();
|
32
30
|
error ErrorInstanceServiceBundleManagerZero();
|
31
|
+
error ErrorInstanceServiceInstanceStoreZero();
|
33
32
|
|
34
33
|
error ErrorInstanceServiceInstanceAuthorityMismatch();
|
34
|
+
error ErrorInstanceServiceBundleManagerAuthorityMismatch();
|
35
35
|
error ErrorInstanceServiceInstanceReaderInstanceMismatch2();
|
36
36
|
error ErrorInstanceServiceBundleMangerInstanceMismatch();
|
37
|
+
error ErrorInstanceServiceInstanceStoreAuthorityMismatch();
|
37
38
|
|
38
39
|
error ErrorInstanceServiceRequestUnauhorized(address caller);
|
39
40
|
error ErrorInstanceServiceNotInstanceOwner(address caller, NftId instanceNftId);
|
41
|
+
error ErrorInstanceServiceNotInstance(NftId nftId);
|
40
42
|
error ErrorInstanceServiceComponentNotRegistered(address componentAddress);
|
43
|
+
error ErrorInstanceServiceInstanceComponentMismatch(NftId instanceNftId, NftId componentNftId);
|
41
44
|
error ErrorInstanceServiceInvalidComponentType(address componentAddress, ObjectType expectedType, ObjectType componentType);
|
42
45
|
|
43
|
-
event LogInstanceCloned(
|
46
|
+
event LogInstanceCloned(
|
47
|
+
address clonedOzAccessManager,
|
48
|
+
address clonedInstanceAccessManager,
|
49
|
+
address clonedInstance,
|
50
|
+
address clonedInstanceStore,
|
51
|
+
address clonedBundleManager,
|
52
|
+
address clonedInstanceReader,
|
53
|
+
NftId clonedInstanceNftId
|
54
|
+
);
|
44
55
|
|
45
56
|
function createInstanceClone()
|
46
57
|
external
|
47
58
|
returns (
|
48
|
-
InstanceAccessManager clonedAccessManager,
|
49
59
|
Instance clonedInstance,
|
50
|
-
NftId instanceNftId
|
51
|
-
InstanceReader clonedInstanceReader,
|
52
|
-
BundleManager clonedBundleManager
|
60
|
+
NftId instanceNftId
|
53
61
|
);
|
54
62
|
|
55
|
-
function
|
56
|
-
|
57
|
-
|
58
|
-
|
63
|
+
function createGifTarget(
|
64
|
+
NftId instanceNftId,
|
65
|
+
address targetAddress,
|
66
|
+
string memory targetName,
|
67
|
+
bytes4[][] memory selectors,
|
68
|
+
RoleId[] memory roles
|
69
|
+
) external;
|
59
70
|
|
71
|
+
function setComponentLocked(bool locked) external;
|
72
|
+
}
|
@@ -3,239 +3,213 @@ pragma solidity ^0.8.20;
|
|
3
3
|
|
4
4
|
import {AccessManagedUpgradeable} from "@openzeppelin/contracts-upgradeable/access/manager/AccessManagedUpgradeable.sol";
|
5
5
|
|
6
|
-
import {Key32
|
7
|
-
import {NftId} from "../
|
8
|
-
import {
|
9
|
-
import {ObjectType, BUNDLE, DISTRIBUTION, INSTANCE, POLICY, POOL, ROLE, PRODUCT, TARGET, COMPONENT, DISTRIBUTOR, DISTRIBUTOR_TYPE} from "../
|
10
|
-
import {
|
11
|
-
import {
|
12
|
-
import {
|
13
|
-
import {
|
14
|
-
import {
|
15
|
-
|
16
|
-
|
6
|
+
import {Key32} from "../type/Key32.sol";
|
7
|
+
import {NftId} from "../type/NftId.sol";
|
8
|
+
import {RiskId} from "../type/RiskId.sol";
|
9
|
+
import {ObjectType, BUNDLE, DISTRIBUTION, INSTANCE, POLICY, POOL, ROLE, PRODUCT, TARGET, COMPONENT, DISTRIBUTOR, DISTRIBUTOR_TYPE} from "../type/ObjectType.sol";
|
10
|
+
import {RoleId, RoleIdLib, eqRoleId, ADMIN_ROLE, INSTANCE_ROLE, INSTANCE_OWNER_ROLE} from "../type/RoleId.sol";
|
11
|
+
import {VersionPart, VersionPartLib} from "../type/Version.sol";
|
12
|
+
import {ClaimId} from "../type/ClaimId.sol";
|
13
|
+
import {ReferralId} from "../type/Referral.sol";
|
14
|
+
import {PayoutId} from "../type/PayoutId.sol";
|
15
|
+
import {DistributorType} from "../type/DistributorType.sol";
|
16
|
+
|
17
17
|
import {Registerable} from "../shared/Registerable.sol";
|
18
|
+
import {TokenHandler} from "../shared/TokenHandler.sol";
|
19
|
+
import {AccessManagerExtendedInitializeable} from "../shared/AccessManagerExtendedInitializeable.sol";
|
20
|
+
|
21
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
18
22
|
|
19
23
|
import {IInstance} from "./IInstance.sol";
|
20
24
|
import {InstanceReader} from "./InstanceReader.sol";
|
21
|
-
import {
|
25
|
+
import {InstanceAdmin} from "./InstanceAdmin.sol";
|
22
26
|
import {BundleManager} from "./BundleManager.sol";
|
27
|
+
import {InstanceStore} from "./InstanceStore.sol";
|
23
28
|
|
24
|
-
import {KeyValueStore} from "./base/KeyValueStore.sol";
|
25
|
-
|
26
|
-
import {IAccess} from "./module/IAccess.sol";
|
27
29
|
import {IBundle} from "./module/IBundle.sol";
|
30
|
+
import {IComponents} from "./module/IComponents.sol";
|
28
31
|
import {IDistribution} from "./module/IDistribution.sol";
|
29
32
|
import {IPolicy} from "./module/IPolicy.sol";
|
30
33
|
import {IRisk} from "./module/IRisk.sol";
|
31
34
|
import {ISetup} from "./module/ISetup.sol";
|
32
35
|
|
33
|
-
import {IDistributionService} from "
|
34
|
-
import {IPoolService} from "
|
35
|
-
import {IProductService} from "
|
36
|
-
import {IPolicyService} from "
|
37
|
-
import {IBundleService} from "
|
38
|
-
import {VersionPart, VersionPartLib} from "../types/Version.sol";
|
36
|
+
import {IDistributionService} from "../distribution/IDistributionService.sol";
|
37
|
+
import {IPoolService} from "../pool/IPoolService.sol";
|
38
|
+
import {IProductService} from "../product/IProductService.sol";
|
39
|
+
import {IPolicyService} from "../product/IPolicyService.sol";
|
40
|
+
import {IBundleService} from "../pool/IBundleService.sol";
|
39
41
|
|
40
42
|
contract Instance is
|
41
43
|
IInstance,
|
42
44
|
AccessManagedUpgradeable,
|
43
|
-
Registerable
|
44
|
-
KeyValueStore
|
45
|
+
Registerable
|
45
46
|
{
|
46
|
-
|
47
47
|
uint256 public constant GIF_MAJOR_VERSION = 3;
|
48
48
|
|
49
|
-
uint64 public constant ADMIN_ROLE = type(uint64).min;
|
50
|
-
uint64 public constant PUBLIC_ROLE = type(uint64).max;
|
51
|
-
uint64 public constant CUSTOM_ROLE_ID_MIN = 10000;
|
52
|
-
|
53
|
-
uint32 public constant EXECUTION_DELAY = 0;
|
54
|
-
|
55
49
|
bool private _initialized;
|
56
50
|
|
57
|
-
|
51
|
+
InstanceAdmin internal _instanceAdmin;
|
58
52
|
InstanceReader internal _instanceReader;
|
59
53
|
BundleManager internal _bundleManager;
|
54
|
+
InstanceStore internal _instanceStore;
|
60
55
|
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
initializeRegisterable(registryAddress, registryNftId, INSTANCE(), false, initialOwner, "");
|
68
|
-
registerInterface(type(IInstance).interfaceId);
|
69
|
-
}
|
70
|
-
|
71
|
-
//--- ProductSetup ------------------------------------------------------//
|
72
|
-
function createProductSetup(NftId productNftId, ISetup.ProductSetupInfo memory setup) external restricted() {
|
73
|
-
create(_toNftKey32(productNftId, PRODUCT()), abi.encode(setup));
|
74
|
-
}
|
75
|
-
|
76
|
-
function updateProductSetup(NftId productNftId, ISetup.ProductSetupInfo memory setup, StateId newState) external restricted() {
|
77
|
-
update(_toNftKey32(productNftId, PRODUCT()), abi.encode(setup), newState);
|
78
|
-
}
|
79
|
-
|
80
|
-
function updateProductSetupState(NftId productNftId, StateId newState) external restricted() {
|
81
|
-
updateState(_toNftKey32(productNftId, PRODUCT()), newState);
|
82
|
-
}
|
83
|
-
|
84
|
-
//--- DistributionSetup ------------------------------------------------------//
|
85
|
-
function createDistributionSetup(NftId distributionNftId, ISetup.DistributionSetupInfo memory setup) external restricted() {
|
86
|
-
create(_toNftKey32(distributionNftId, DISTRIBUTION()), abi.encode(setup));
|
87
|
-
}
|
88
|
-
|
89
|
-
function updateDistributionSetup(NftId distributionNftId, ISetup.DistributionSetupInfo memory setup, StateId newState) external restricted() {
|
90
|
-
update(_toNftKey32(distributionNftId, DISTRIBUTION()), abi.encode(setup), newState);
|
91
|
-
}
|
92
|
-
|
93
|
-
function updateDistributionSetupState(NftId distributionNftId, StateId newState) external restricted() {
|
94
|
-
updateState(_toNftKey32(distributionNftId, DISTRIBUTION()), newState);
|
56
|
+
modifier onlyChainNft() {
|
57
|
+
if(msg.sender != getRegistry().getChainNftAddress()) {
|
58
|
+
revert();
|
59
|
+
}
|
60
|
+
_;
|
95
61
|
}
|
96
62
|
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
}
|
105
|
-
|
106
|
-
function updatePoolSetupState(NftId poolNftId, StateId newState) external restricted() {
|
107
|
-
updateState(_toNftKey32(poolNftId, POOL()), newState);
|
108
|
-
}
|
109
|
-
|
110
|
-
//--- DistributorType -------------------------------------------------------//
|
111
|
-
function createDistributorType(Key32 distributorKey, IDistribution.DistributorTypeInfo memory info) external restricted() {
|
112
|
-
create(distributorKey, abi.encode(info));
|
113
|
-
}
|
114
|
-
|
115
|
-
function updateDistributorType(Key32 distributorKey, IDistribution.DistributorTypeInfo memory info, StateId newState) external restricted() {
|
116
|
-
update(distributorKey, abi.encode(info), newState);
|
117
|
-
}
|
118
|
-
|
119
|
-
function updateDistributorTypeState(Key32 distributorKey, StateId newState) external restricted() {
|
120
|
-
updateState(distributorKey, newState);
|
121
|
-
}
|
63
|
+
function initialize(address authority, address registryAddress, address initialOwner)
|
64
|
+
external
|
65
|
+
initializer()
|
66
|
+
{
|
67
|
+
if(authority == address(0)) {
|
68
|
+
revert ErrorInstanceInstanceAdminZero();
|
69
|
+
}
|
122
70
|
|
123
|
-
|
124
|
-
|
125
|
-
|
126
|
-
|
71
|
+
__AccessManaged_init(authority);
|
72
|
+
|
73
|
+
IRegistry registry = IRegistry(registryAddress);
|
74
|
+
initializeRegisterable(registryAddress, registry.getNftId(), INSTANCE(), true, initialOwner, "");
|
127
75
|
|
128
|
-
|
129
|
-
update(toDistributorKey32(nftId), abi.encode(info), newState);
|
76
|
+
registerInterface(type(IInstance).interfaceId);
|
130
77
|
}
|
131
78
|
|
132
|
-
|
133
|
-
updateState(toDistributorKey32(nftId), newState);
|
134
|
-
}
|
79
|
+
//--- Roles ------------------------------------------------------------//
|
135
80
|
|
136
|
-
|
137
|
-
|
138
|
-
|
81
|
+
function createRole(string memory roleName, string memory adminName)
|
82
|
+
external
|
83
|
+
restricted // INSTANCE_OWNER_ROLE
|
84
|
+
returns (RoleId roleId, RoleId admin)
|
85
|
+
{
|
86
|
+
(roleId, admin) = _instanceAdmin.createRole(roleName, adminName);
|
139
87
|
}
|
140
88
|
|
141
|
-
function
|
142
|
-
|
89
|
+
function grantRole(RoleId roleId, address account)
|
90
|
+
external
|
91
|
+
restricted // INSTANCE_OWNER_ROLE
|
92
|
+
{
|
93
|
+
AccessManagerExtendedInitializeable(authority()).grantRole(roleId.toInt(), account, 0);
|
143
94
|
}
|
144
95
|
|
145
|
-
function
|
146
|
-
|
96
|
+
function revokeRole(RoleId roleId, address account)
|
97
|
+
external
|
98
|
+
restricted // INSTANCE_OWNER_ROLE
|
99
|
+
{
|
100
|
+
AccessManagerExtendedInitializeable(authority()).revokeRole(roleId.toInt(), account);
|
147
101
|
}
|
148
102
|
|
149
|
-
//---
|
150
|
-
function createBundle(NftId bundleNftId, IBundle.BundleInfo memory bundle) external restricted() {
|
151
|
-
create(toBundleKey32(bundleNftId), abi.encode(bundle));
|
152
|
-
}
|
103
|
+
//--- Targets ------------------------------------------------------------//
|
153
104
|
|
154
|
-
function
|
155
|
-
|
105
|
+
function createTarget(address target, string memory name)
|
106
|
+
external
|
107
|
+
restricted // INSTANCE_OWNER_ROLE
|
108
|
+
{
|
109
|
+
_instanceAdmin.createTarget(target, name);
|
156
110
|
}
|
157
111
|
|
158
|
-
function
|
159
|
-
|
112
|
+
function setTargetFunctionRole(
|
113
|
+
string memory targetName,
|
114
|
+
bytes4[] calldata selectors,
|
115
|
+
RoleId roleId
|
116
|
+
)
|
117
|
+
external
|
118
|
+
restricted // INSTANCE_OWNER_ROLE
|
119
|
+
{
|
120
|
+
_instanceAdmin.setTargetFunctionRoleByInstance(targetName, selectors, roleId);
|
160
121
|
}
|
161
122
|
|
162
|
-
|
163
|
-
|
164
|
-
|
123
|
+
function setTargetLocked(address target, bool locked)
|
124
|
+
external
|
125
|
+
restricted // INSTANCE_OWNER_ROLE
|
126
|
+
{
|
127
|
+
_instanceAdmin.setTargetLockedByInstance(target, locked);
|
165
128
|
}
|
166
129
|
|
167
|
-
|
168
|
-
|
130
|
+
//--- ITransferInterceptor ------------------------------------------------------------//
|
131
|
+
// TODO interception of child components nfts
|
132
|
+
function nftMint(address to, uint256 tokenId) external onlyChainNft {
|
133
|
+
_instanceAdmin.transferInstanceOwnerRole(address(0), to);
|
169
134
|
}
|
170
135
|
|
171
|
-
function
|
172
|
-
|
136
|
+
function nftTransferFrom(address from, address to, uint256 tokenId) external onlyChainNft {
|
137
|
+
_instanceAdmin.transferInstanceOwnerRole(from, to);
|
173
138
|
}
|
174
139
|
|
175
|
-
|
176
|
-
|
177
|
-
|
178
|
-
}
|
140
|
+
//function nftBurn(address from, uint256 tokenId) external onlyChainNft {
|
141
|
+
//_instanceAdmin.transferInstanceOwnerRole(from, address(0));
|
142
|
+
//}
|
179
143
|
|
180
|
-
|
181
|
-
update(toPolicyKey32(policyNftId), abi.encode(policy), newState);
|
182
|
-
}
|
144
|
+
//--- initial setup functions -------------------------------------------//
|
183
145
|
|
184
|
-
function
|
185
|
-
|
146
|
+
function setInstanceAdmin(InstanceAdmin accessManager) external restricted {
|
147
|
+
if(address(_instanceAdmin) != address(0)) {
|
148
|
+
revert ErrorInstanceInstanceAdminAlreadySet(address(_instanceAdmin));
|
149
|
+
}
|
150
|
+
if(accessManager.authority() != authority()) {
|
151
|
+
revert ErrorInstanceInstanceAdminAuthorityMismatch(authority());
|
152
|
+
}
|
153
|
+
_instanceAdmin = accessManager;
|
186
154
|
}
|
187
|
-
|
188
|
-
|
189
|
-
|
190
|
-
|
155
|
+
|
156
|
+
function setBundleManager(BundleManager bundleManager) external restricted() {
|
157
|
+
if(address(_bundleManager) != address(0)) {
|
158
|
+
revert ErrorInstanceBundleManagerAlreadySet(address(_bundleManager));
|
159
|
+
}
|
160
|
+
if(bundleManager.getInstance() != Instance(this)) {
|
161
|
+
revert ErrorInstanceBundleManagerInstanceMismatch(address(this));
|
162
|
+
}
|
163
|
+
if(bundleManager.authority() != authority()) {
|
164
|
+
revert ErrorInstanceBundleManagerAuthorityMismatch(authority());
|
165
|
+
}
|
166
|
+
_bundleManager = bundleManager;
|
191
167
|
}
|
192
168
|
|
193
|
-
function
|
194
|
-
|
195
|
-
|
169
|
+
function setInstanceReader(InstanceReader instanceReader) external restricted() {
|
170
|
+
if(instanceReader.getInstance() != Instance(this)) {
|
171
|
+
revert ErrorInstanceInstanceReaderInstanceMismatch(address(this));
|
172
|
+
}
|
196
173
|
|
197
|
-
|
198
|
-
updateState(toPolicyKey32(policyNftId), newState);
|
174
|
+
_instanceReader = instanceReader;
|
199
175
|
}
|
200
176
|
|
201
|
-
//---
|
202
|
-
function createPayout(NftId policyNftId, NumberId payoutId, IPolicy.PayoutInfo memory payout) external restricted() {
|
203
|
-
create(toPolicyKey32(policyNftId), abi.encode(payout));
|
204
|
-
}
|
177
|
+
//--- external view functions -------------------------------------------//
|
205
178
|
|
206
|
-
function
|
207
|
-
|
179
|
+
function getInstanceReader() external view returns (InstanceReader) {
|
180
|
+
return _instanceReader;
|
208
181
|
}
|
209
182
|
|
210
|
-
function
|
211
|
-
|
183
|
+
function getBundleManager() external view returns (BundleManager) {
|
184
|
+
return _bundleManager;
|
212
185
|
}
|
213
186
|
|
214
|
-
|
215
|
-
|
216
|
-
return nftId.toKey32(objectType);
|
187
|
+
function getInstanceAdmin() external view returns (InstanceAdmin) {
|
188
|
+
return _instanceAdmin;
|
217
189
|
}
|
218
190
|
|
219
|
-
function
|
220
|
-
return
|
191
|
+
function getInstanceAccessManager() external view returns (AccessManagerExtendedInitializeable) {
|
192
|
+
return AccessManagerExtendedInitializeable(authority());
|
221
193
|
}
|
222
194
|
|
223
|
-
function
|
224
|
-
|
195
|
+
function setInstanceStore(InstanceStore instanceStore) external restricted {
|
196
|
+
if(address(_instanceStore) != address(0)) {
|
197
|
+
revert ErrorInstanceInstanceStoreAlreadySet(address(_instanceStore));
|
198
|
+
}
|
199
|
+
if(instanceStore.authority() != authority()) {
|
200
|
+
revert ErrorInstanceInstanceStoreAuthorityMismatch(authority());
|
201
|
+
}
|
202
|
+
_instanceStore = instanceStore;
|
225
203
|
}
|
226
204
|
|
227
|
-
function
|
228
|
-
return
|
205
|
+
function getInstanceStore() external view returns (InstanceStore) {
|
206
|
+
return _instanceStore;
|
229
207
|
}
|
230
208
|
|
231
|
-
function
|
232
|
-
return
|
209
|
+
function getMajorVersion() external pure returns (VersionPart majorVersion) {
|
210
|
+
return VersionPartLib.toVersionPart(GIF_MAJOR_VERSION);
|
233
211
|
}
|
234
212
|
|
235
|
-
function toDistributorKey32(NftId distNftId) public pure returns (Key32) {
|
236
|
-
return distNftId.toKey32(DISTRIBUTOR());
|
237
|
-
}
|
238
|
-
|
239
213
|
function getDistributionService() external view returns (IDistributionService) {
|
240
214
|
return IDistributionService(getRegistry().getServiceAddress(DISTRIBUTION(), VersionPart.wrap(3)));
|
241
215
|
}
|
@@ -256,26 +230,5 @@ contract Instance is
|
|
256
230
|
return IBundleService(getRegistry().getServiceAddress(BUNDLE(), VersionPart.wrap(3)));
|
257
231
|
}
|
258
232
|
|
259
|
-
|
260
|
-
|
261
|
-
_instanceReader = instanceReader;
|
262
|
-
}
|
263
|
-
|
264
|
-
function getMajorVersion() external pure returns (VersionPart majorVersion) {
|
265
|
-
return VersionPartLib.toVersionPart(GIF_MAJOR_VERSION);
|
266
|
-
}
|
267
|
-
|
268
|
-
function getInstanceReader() external view returns (InstanceReader) {
|
269
|
-
return _instanceReader;
|
270
|
-
}
|
271
|
-
|
272
|
-
function setBundleManager(BundleManager bundleManager) external restricted() {
|
273
|
-
require(address(_bundleManager) == address(0), "BundleManager is set");
|
274
|
-
require(bundleManager.getInstance() == Instance(this), "BundleManager instance mismatch");
|
275
|
-
_bundleManager = bundleManager;
|
276
|
-
}
|
277
|
-
|
278
|
-
function getBundleManager() external view returns (BundleManager) {
|
279
|
-
return _bundleManager;
|
280
|
-
}
|
281
|
-
}
|
233
|
+
//--- internal view/pure functions --------------------------------------//
|
234
|
+
}
|