@etherisc/gif-next 0.0.2-bf75dbb-287 → 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 +10 -14
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +4 -0
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +1395 -0
- 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/distribution/IDistributionComponent.sol/IDistributionComponent.json +1000 -0
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +4 -0
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +840 -0
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +73 -83
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +307 -1339
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +305 -185
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +438 -3004
- 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 +432 -280
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +443 -468
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +347 -152
- 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 +30 -112
- 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/IProductService.sol/IProductService.json → pool/IBundleService.sol/IBundleService.json} +322 -347
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +1095 -0
- 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/pool/Pool.sol/Pool.json +1426 -0
- 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/IComponentOwnerService.sol/IComponentOwnerService.json → product/IApplicationService.sol/IApplicationService.json} +231 -204
- 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/product/IPolicyService.sol/IPolicyService.json +651 -0
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +4 -0
- package/artifacts/contracts/{shared/RegisterableUpgradable.sol/RegisterableUpgradable.json → product/IPricingService.sol/IPricingService.json} +245 -177
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +4 -0
- package/artifacts/contracts/{instance/service/IPoolService.sol/IPoolService.json → product/IProductComponent.sol/IProductComponent.json} +463 -330
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service/IDistributionService.sol/IDistributionService.json → product/IProductService.sol/IProductService.json} +162 -166
- 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/product/Product.sol/Product.json +1217 -0
- 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 +323 -127
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +277 -253
- 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 +343 -228
- 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 +328 -339
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +340 -139
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +1058 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +138 -65
- package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.dbg.json +4 -0
- package/artifacts/contracts/{instance/IAccessManagerSimple.sol/IAccessManagerSimple.json → shared/AccessManagerCustom.sol/AccessManagerCustom.json} +122 -11
- 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/shared/Component.sol/Component.json +892 -0
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +650 -0
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +41 -3
- 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/BaseComponent.sol/BaseComponent.json → shared/IComponent.sol/IComponent.json} +257 -74
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +27 -29
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +189 -0
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +8 -34
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/{experiment/inheritance/IA.sol/ISharedA.json → shared/IRegistryLinked.sol/IRegistryLinked.json} +15 -17
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +84 -178
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +2 -152
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +120 -47
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +302 -0
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +342 -61
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +137 -53
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +71 -0
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +201 -162
- 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 +2 -152
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +4 -0
- package/artifacts/contracts/{instance/base/ComponentServiceBase.sol/ComponentServiceBase.json → staking/IStakingService.sol/IStakingService.json} +202 -219
- 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/distribution/Distribution.sol +285 -0
- package/contracts/distribution/DistributionService.sol +351 -0
- package/contracts/distribution/DistributionServiceManager.sol +42 -0
- package/contracts/distribution/IDistributionComponent.sol +71 -0
- package/contracts/distribution/IDistributionService.sol +87 -0
- package/contracts/instance/BundleManager.sol +22 -25
- package/contracts/instance/IInstance.sol +58 -35
- package/contracts/instance/IInstanceService.sol +53 -15
- package/contracts/instance/Instance.sol +150 -370
- package/contracts/instance/InstanceAdmin.sol +330 -0
- package/contracts/instance/InstanceAuthorizationsLib.sol +320 -0
- package/contracts/instance/InstanceReader.sol +102 -49
- package/contracts/instance/InstanceService.sol +231 -196
- package/contracts/instance/InstanceServiceManager.sol +12 -25
- 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} +16 -35
- package/contracts/instance/module/IAccess.sol +29 -21
- 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 -22
- 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/product/IApplicationService.sol +62 -0
- package/contracts/product/IClaimService.sol +93 -0
- package/contracts/product/IPolicyService.sol +80 -0
- package/contracts/product/IPricingService.sol +37 -0
- package/contracts/product/IProductComponent.sol +41 -0
- package/contracts/product/IProductService.sol +40 -0
- 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/product/Product.sol +379 -0
- package/contracts/product/ProductService.sol +212 -0
- package/contracts/product/ProductServiceManager.sol +42 -0
- package/contracts/registry/ChainNft.sol +9 -1
- package/contracts/registry/IRegistry.sol +60 -28
- package/contracts/registry/IRegistryService.sol +37 -28
- package/contracts/registry/ITransferInterceptor.sol +1 -0
- package/contracts/registry/Registry.sol +258 -241
- package/contracts/registry/RegistryAdmin.sol +141 -0
- package/contracts/registry/RegistryService.sol +84 -210
- package/contracts/registry/RegistryServiceManager.sol +25 -45
- package/contracts/registry/ReleaseManager.sol +462 -0
- package/contracts/registry/TokenRegistry.sol +24 -17
- 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/shared/Component.sol +271 -0
- package/contracts/shared/ComponentService.sol +142 -0
- package/contracts/shared/ERC165.sol +14 -12
- 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 +12 -11
- package/contracts/shared/IPolicyHolder.sol +40 -0
- package/contracts/shared/IRegisterable.sol +4 -6
- package/contracts/shared/IRegistryLinked.sol +11 -0
- package/contracts/shared/IService.sol +7 -4
- package/contracts/shared/IVersionable.sol +5 -48
- package/contracts/shared/NftOwnable.sol +68 -85
- package/contracts/shared/PolicyHolder.sol +94 -0
- package/contracts/shared/ProxyManager.sol +131 -25
- package/contracts/shared/Registerable.sol +26 -41
- package/contracts/shared/RegistryLinked.sol +43 -0
- package/contracts/shared/Service.sol +41 -24
- package/contracts/shared/TokenHandler.sol +14 -6
- package/contracts/shared/Versionable.sol +4 -92
- 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}/DistributorType.sol +2 -2
- 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 +17 -7
- package/contracts/type/PayoutId.sol +82 -0
- package/contracts/{types → type}/Referral.sol +4 -0
- package/contracts/type/RoleId.sol +139 -0
- 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 +3 -3
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +0 -4
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +0 -4
- package/artifacts/contracts/components/Distribution.sol/Distribution.json +0 -744
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.json +0 -368
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +0 -152
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +0 -275
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +0 -157
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +0 -4
- package/artifacts/contracts/components/Pool.sol/Pool.json +0 -939
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +0 -4
- package/artifacts/contracts/components/Product.sol/Product.json +0 -855
- 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/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/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +0 -4
- package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +0 -1206
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +0 -4
- package/artifacts/contracts/instance/IAccessManagerSimple.sol/IAccessManagerSimple.dbg.json +0 -4
- package/artifacts/contracts/instance/IInstanceBase.sol/IInstanceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/IInstanceBase.sol/IInstanceBase.json +0 -448
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +0 -4
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +0 -940
- package/artifacts/contracts/instance/InstanceBase.sol/InstanceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/InstanceBase.sol/InstanceBase.json +0 -763
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +0 -4
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +0 -285
- package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.json +0 -113
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +0 -827
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +0 -716
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +0 -444
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.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/PoolService.sol/PoolService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +0 -1049
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +0 -464
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +0 -1147
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +0 -488
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +0 -4
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +0 -107
- package/artifacts/contracts/shared/RegisterableUpgradable.sol/RegisterableUpgradable.dbg.json +0 -4
- 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 -305
- 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 -600
- 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/BaseComponent.sol +0 -132
- package/contracts/components/Distribution.sol +0 -163
- package/contracts/components/IBaseComponent.sol +0 -31
- package/contracts/components/IDistributionComponent.sol +0 -44
- package/contracts/components/IPoolComponent.sol +0 -66
- package/contracts/components/IProductComponent.sol +0 -35
- package/contracts/components/Pool.sol +0 -267
- package/contracts/components/Product.sol +0 -289
- 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/AccessManagerUpgradeableInitializeable.sol +0 -23
- package/contracts/instance/IAccessManagerSimple.sol +0 -391
- package/contracts/instance/IInstanceBase.sol +0 -26
- package/contracts/instance/InstanceAccessManager.sol +0 -288
- package/contracts/instance/InstanceBase.sol +0 -41
- package/contracts/instance/base/ComponentServiceBase.sol +0 -134
- package/contracts/instance/base/IInstanceBase.sol +0 -23
- package/contracts/instance/service/ComponentOwnerService.sol +0 -317
- package/contracts/instance/service/DistributionService.sol +0 -88
- package/contracts/instance/service/DistributionServiceManager.sol +0 -54
- package/contracts/instance/service/IComponentOwnerService.sol +0 -20
- package/contracts/instance/service/IDistributionService.sol +0 -12
- package/contracts/instance/service/IPoolService.sol +0 -51
- package/contracts/instance/service/IProductService.sol +0 -110
- package/contracts/instance/service/PoolService.sol +0 -287
- package/contracts/instance/service/PoolServiceManager.sol +0 -54
- package/contracts/instance/service/ProductService.sol +0 -570
- package/contracts/instance/service/ProductServiceManager.sol +0 -54
- package/contracts/shared/ContractDeployerLib.sol +0 -72
- package/contracts/shared/RegisterableUpgradable.sol +0 -16
- 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 -24
- 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/RoleId.sol +0 -90
- /package/contracts/{types → type}/AddressSet.sol +0 -0
- /package/contracts/{types → type}/Key32.sol +0 -0
- /package/contracts/{types → type}/RiskId.sol +0 -0
@@ -1,454 +1,234 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
-
import {EnumerableSet} from "@openzeppelin/contracts/utils/structs/EnumerableSet.sol";
|
5
|
-
import {ShortString, ShortStrings} from "@openzeppelin/contracts/utils/ShortStrings.sol";
|
6
|
-
import {Initializable} from "@openzeppelin/contracts/proxy/utils/Initializable.sol";
|
7
4
|
import {AccessManagedUpgradeable} from "@openzeppelin/contracts-upgradeable/access/manager/AccessManagedUpgradeable.sol";
|
8
|
-
import {AccessManagerUpgradeable} from "@openzeppelin/contracts-upgradeable/access/manager/AccessManagerUpgradeable.sol";
|
9
5
|
|
10
|
-
import {
|
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
|
+
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";
|
22
|
+
|
23
|
+
import {IInstance} from "./IInstance.sol";
|
24
|
+
import {InstanceReader} from "./InstanceReader.sol";
|
25
|
+
import {InstanceAdmin} from "./InstanceAdmin.sol";
|
26
|
+
import {BundleManager} from "./BundleManager.sol";
|
27
|
+
import {InstanceStore} from "./InstanceStore.sol";
|
28
|
+
|
11
29
|
import {IBundle} from "./module/IBundle.sol";
|
30
|
+
import {IComponents} from "./module/IComponents.sol";
|
31
|
+
import {IDistribution} from "./module/IDistribution.sol";
|
12
32
|
import {IPolicy} from "./module/IPolicy.sol";
|
13
33
|
import {IRisk} from "./module/IRisk.sol";
|
14
34
|
import {ISetup} from "./module/ISetup.sol";
|
15
|
-
|
16
|
-
import {
|
17
|
-
import {
|
18
|
-
import {
|
19
|
-
import {
|
20
|
-
import {
|
21
|
-
import {NumberId} from "../types/NumberId.sol";
|
22
|
-
import {ObjectType, BUNDLE, DISTRIBUTION, INSTANCE, POLICY, POOL, ROLE, PRODUCT, TARGET} from "../types/ObjectType.sol";
|
23
|
-
import {RiskId, RiskIdLib} from "../types/RiskId.sol";
|
24
|
-
import {RoleId, RoleIdLib} from "../types/RoleId.sol";
|
25
|
-
import {StateId, ACTIVE} from "../types/StateId.sol";
|
26
|
-
import {ERC165} from "../shared/ERC165.sol";
|
27
|
-
import {Registerable} from "../shared/Registerable.sol";
|
28
|
-
import {ComponentOwnerService} from "./service/ComponentOwnerService.sol";
|
29
|
-
import {IComponentOwnerService} from "./service/IComponentOwnerService.sol";
|
30
|
-
import {IDistributionService} from "./service/IDistributionService.sol";
|
31
|
-
import {IPoolService} from "./service/IPoolService.sol";
|
32
|
-
import {IProductService} from "./service/IProductService.sol";
|
33
|
-
import {VersionPart} from "../types/Version.sol";
|
34
|
-
import {InstanceBase} from "./InstanceBase.sol";
|
35
|
+
|
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";
|
35
41
|
|
36
42
|
contract Instance is
|
37
|
-
AccessManagedUpgradeable,
|
38
43
|
IInstance,
|
39
|
-
|
40
|
-
|
44
|
+
AccessManagedUpgradeable,
|
45
|
+
Registerable
|
41
46
|
{
|
42
|
-
|
43
|
-
uint64 public constant ADMIN_ROLE = type(uint64).min;
|
44
|
-
uint64 public constant PUBLIC_ROLE = type(uint64).max;
|
45
|
-
uint64 public constant CUSTOM_ROLE_ID_MIN = 10000;
|
46
|
-
|
47
|
-
uint32 public constant EXECUTION_DELAY = 0;
|
47
|
+
uint256 public constant GIF_MAJOR_VERSION = 3;
|
48
48
|
|
49
49
|
bool private _initialized;
|
50
50
|
|
51
|
-
|
52
|
-
mapping(RoleId roleId => EnumerableSet.AddressSet roleMembers) internal _roleMembers;
|
53
|
-
RoleId [] internal _roles;
|
54
|
-
|
55
|
-
mapping(ShortString name => address target) internal _target;
|
56
|
-
|
57
|
-
AccessManagerUpgradeable internal _accessManager;
|
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
|
-
require(!_initialized, "Contract instance has already been initialized");
|
66
|
-
|
67
|
-
__AccessManaged_init(accessManagerAddress);
|
68
|
-
|
69
|
-
_accessManager = AccessManagerUpgradeable(accessManagerAddress);
|
70
|
-
_createRole(RoleIdLib.toRoleId(ADMIN_ROLE), "AdminRole", false, false);
|
71
|
-
_createRole(RoleIdLib.toRoleId(PUBLIC_ROLE), "PublicRole", false, false);
|
72
|
-
|
73
|
-
_initializeRegisterable(registryAddress, registryNftId, INSTANCE(), false, initialOwner, "");
|
74
|
-
|
75
|
-
_registerInterface(type(IInstance).interfaceId);
|
76
|
-
_initialized = true;
|
77
|
-
}
|
78
|
-
|
79
|
-
//--- Role ------------------------------------------------------//
|
80
|
-
function createStandardRole(RoleId roleId, string memory name) external restricted() {
|
81
|
-
_createRole(roleId, name, false, true);
|
82
|
-
}
|
83
|
-
|
84
|
-
function createCustomRole(RoleId roleId, string memory name) external restricted() {
|
85
|
-
_createRole(roleId, name, true, true);
|
86
|
-
}
|
87
|
-
|
88
|
-
function updateRole(RoleId roleId, string memory name, StateId newState) external restricted() {
|
89
|
-
(bool isCustom,) = _validateRoleParameters(roleId, name, false);
|
90
|
-
IAccess.RoleInfo memory role = _toRole(roleId, name, isCustom);
|
91
|
-
update(toRoleKey32(roleId), abi.encode(role), newState);
|
92
|
-
}
|
93
|
-
|
94
|
-
function updateRoleState(RoleId roleId, StateId newState) external restricted() {
|
95
|
-
updateState(toRoleKey32(roleId), newState);
|
96
|
-
}
|
97
|
-
|
98
|
-
function grantRole(RoleId roleId, address member) external restricted() returns (bool granted) {
|
99
|
-
Key32 roleKey = toRoleKey32(roleId);
|
100
|
-
|
101
|
-
if (!exists(roleKey)) {
|
102
|
-
revert IAccess.ErrorGrantNonexstentRole(roleId);
|
103
|
-
}
|
104
|
-
|
105
|
-
if (getState(roleKey) != ACTIVE()) {
|
106
|
-
revert IAccess.ErrorRoleIdNotActive(roleId);
|
107
|
-
}
|
108
|
-
|
109
|
-
if (!EnumerableSet.contains(_roleMembers[roleId], member)) {
|
110
|
-
_accessManager.grantRole(roleId.toInt(), member, EXECUTION_DELAY);
|
111
|
-
EnumerableSet.add(_roleMembers[roleId], member);
|
112
|
-
return true;
|
113
|
-
}
|
114
|
-
|
115
|
-
return false;
|
116
|
-
}
|
117
|
-
|
118
|
-
function revokeRole(RoleId roleId, address member) external restricted() returns (bool revoked) {
|
119
|
-
Key32 roleKey = toRoleKey32(roleId);
|
120
|
-
|
121
|
-
if (!exists(roleKey)) {
|
122
|
-
revert IAccess.ErrorRevokeNonexstentRole(roleId);
|
123
|
-
}
|
124
|
-
|
125
|
-
if (EnumerableSet.contains(_roleMembers[roleId], member)) {
|
126
|
-
_accessManager.revokeRole(roleId.toInt(), member);
|
127
|
-
EnumerableSet.remove(_roleMembers[roleId], member);
|
128
|
-
return true;
|
129
|
-
}
|
130
|
-
|
131
|
-
return false;
|
132
|
-
}
|
133
|
-
|
134
|
-
/// @dev not restricted function by intention
|
135
|
-
/// the restriction to role members is already enforced by the call to the access manger
|
136
|
-
function renounceRole(RoleId roleId) external returns (bool revoked) {
|
137
|
-
address member = msg.sender;
|
138
|
-
Key32 roleKey = toRoleKey32(roleId);
|
139
|
-
|
140
|
-
if (!exists(roleKey)) {
|
141
|
-
revert IAccess.ErrorRenounceNonexstentRole(roleId);
|
142
|
-
}
|
143
|
-
|
144
|
-
if (EnumerableSet.contains(_roleMembers[roleId], member)) {
|
145
|
-
_accessManager.renounceRole(roleId.toInt(), member);
|
146
|
-
EnumerableSet.remove(_roleMembers[roleId], member);
|
147
|
-
return true;
|
56
|
+
modifier onlyChainNft() {
|
57
|
+
if(msg.sender != getRegistry().getChainNftAddress()) {
|
58
|
+
revert();
|
148
59
|
}
|
149
|
-
|
150
|
-
return false;
|
151
|
-
}
|
152
|
-
|
153
|
-
function roles() external view returns (uint256 numberOfRoles) {
|
154
|
-
return _roles.length;
|
155
|
-
}
|
156
|
-
|
157
|
-
function getRoleId(uint256 idx) external view returns (RoleId roleId) {
|
158
|
-
return _roles[idx];
|
159
|
-
}
|
160
|
-
|
161
|
-
function getRole(RoleId roleId) external view returns (IAccess.RoleInfo memory role) {
|
162
|
-
return abi.decode(getData(roleId.toKey32()), (IAccess.RoleInfo));
|
60
|
+
_;
|
163
61
|
}
|
164
62
|
|
165
|
-
function
|
166
|
-
|
167
|
-
|
168
|
-
|
169
|
-
|
170
|
-
|
171
|
-
}
|
172
|
-
|
173
|
-
function _createRole(RoleId roleId, string memory name, bool isCustom, bool validateParameters) internal {
|
174
|
-
if (validateParameters) {
|
175
|
-
_validateRoleParameters(roleId, name, isCustom);
|
176
|
-
}
|
177
|
-
|
178
|
-
IAccess.RoleInfo memory role = _toRole(roleId, name, isCustom);
|
179
|
-
_role[role.name] = roleId;
|
180
|
-
_roles.push(roleId);
|
181
|
-
|
182
|
-
create(toRoleKey32(roleId), abi.encode(role));
|
183
|
-
}
|
184
|
-
|
185
|
-
//--- Target ------------------------------------------------------//
|
186
|
-
function createTarget(address target, IAccess.TargetInfo memory targetInfo) external restricted() {
|
187
|
-
_validateTargetParameters(target, targetInfo);
|
188
|
-
create(toTargetKey32(target), abi.encode(targetInfo));
|
189
|
-
}
|
190
|
-
|
191
|
-
function setTargetClosed(address target, bool closed) external restricted() {
|
192
|
-
if (!exists(toTargetKey32(target))) {
|
193
|
-
revert IAccess.ErrorTargetDoesNotExist(target);
|
63
|
+
function initialize(address authority, address registryAddress, address initialOwner)
|
64
|
+
external
|
65
|
+
initializer()
|
66
|
+
{
|
67
|
+
if(authority == address(0)) {
|
68
|
+
revert ErrorInstanceInstanceAdminZero();
|
194
69
|
}
|
195
70
|
|
196
|
-
|
197
|
-
|
71
|
+
__AccessManaged_init(authority);
|
72
|
+
|
73
|
+
IRegistry registry = IRegistry(registryAddress);
|
74
|
+
initializeRegisterable(registryAddress, registry.getNftId(), INSTANCE(), true, initialOwner, "");
|
198
75
|
|
199
|
-
|
200
|
-
function createProductSetup(NftId productNftId, ISetup.ProductSetupInfo memory setup) external restricted() {
|
201
|
-
create(_toNftKey32(productNftId, PRODUCT()), abi.encode(setup));
|
76
|
+
registerInterface(type(IInstance).interfaceId);
|
202
77
|
}
|
203
78
|
|
204
|
-
|
205
|
-
update(_toNftKey32(productNftId, PRODUCT()), abi.encode(setup), newState);
|
206
|
-
}
|
79
|
+
//--- Roles ------------------------------------------------------------//
|
207
80
|
|
208
|
-
function
|
209
|
-
|
210
|
-
|
211
|
-
|
212
|
-
|
213
|
-
|
214
|
-
create(_toNftKey32(distributionNftId, DISTRIBUTION()), abi.encode(setup));
|
215
|
-
}
|
216
|
-
|
217
|
-
function updateDistributionSetup(NftId distributionNftId, ISetup.DistributionSetupInfo memory setup, StateId newState) external restricted() {
|
218
|
-
update(_toNftKey32(distributionNftId, DISTRIBUTION()), abi.encode(setup), newState);
|
219
|
-
}
|
220
|
-
|
221
|
-
function updateDistributionSetupState(NftId distributionNftId, StateId newState) external restricted() {
|
222
|
-
updateState(_toNftKey32(distributionNftId, DISTRIBUTION()), newState);
|
223
|
-
}
|
224
|
-
|
225
|
-
//--- PoolSetup ------------------------------------------------------//
|
226
|
-
function createPoolSetup(NftId poolNftId, ISetup.PoolSetupInfo memory setup) external restricted() {
|
227
|
-
create(_toNftKey32(poolNftId, POOL()), abi.encode(setup));
|
228
|
-
}
|
229
|
-
|
230
|
-
function updatePoolSetup(NftId poolNftId, ISetup.PoolSetupInfo memory setup, StateId newState) external restricted() {
|
231
|
-
update(_toNftKey32(poolNftId, POOL()), abi.encode(setup), newState);
|
232
|
-
}
|
233
|
-
|
234
|
-
function updatePoolSetupState(NftId poolNftId, StateId newState) external restricted() {
|
235
|
-
updateState(_toNftKey32(poolNftId, POOL()), newState);
|
236
|
-
}
|
237
|
-
|
238
|
-
//--- DistributorType ---------------------------------------------------//
|
239
|
-
function createDistributorType(NftId policyNftId, NumberId payoutId, IPolicy.PayoutInfo memory payout) external restricted() {
|
240
|
-
create(toPolicyKey32(policyNftId), abi.encode(payout));
|
241
|
-
}
|
242
|
-
|
243
|
-
function updateDistributorType(NftId policyNftId, NumberId payoutId, IPolicy.PayoutInfo memory payout, StateId newState) external restricted() {
|
244
|
-
update(toPolicyKey32(policyNftId), abi.encode(payout), newState);
|
245
|
-
}
|
246
|
-
|
247
|
-
function updateDistributorTypeState(NftId policyNftId, StateId newState) external restricted() {
|
248
|
-
updateState(toPolicyKey32(policyNftId), newState);
|
249
|
-
}
|
250
|
-
|
251
|
-
//--- Distributor -------------------------------------------------------//
|
252
|
-
function createDistributor(NftId policyNftId, NumberId payoutId, IPolicy.PayoutInfo memory payout) external restricted() {
|
253
|
-
create(toPolicyKey32(policyNftId), abi.encode(payout));
|
254
|
-
}
|
255
|
-
|
256
|
-
function updateDistributor(NftId policyNftId, NumberId payoutId, IPolicy.PayoutInfo memory payout, StateId newState) external restricted() {
|
257
|
-
update(toPolicyKey32(policyNftId), abi.encode(payout), newState);
|
258
|
-
}
|
259
|
-
|
260
|
-
function updateDistributorState(NftId policyNftId, StateId newState) external restricted() {
|
261
|
-
updateState(toPolicyKey32(policyNftId), newState);
|
262
|
-
}
|
263
|
-
|
264
|
-
//--- Referral ----------------------------------------------------------//
|
265
|
-
function createReferral(NftId policyNftId, NumberId payoutId, IPolicy.PayoutInfo memory payout) external restricted() {
|
266
|
-
create(toPolicyKey32(policyNftId), abi.encode(payout));
|
267
|
-
}
|
268
|
-
|
269
|
-
function updateReferral(NftId policyNftId, NumberId payoutId, IPolicy.PayoutInfo memory payout, StateId newState) external restricted() {
|
270
|
-
update(toPolicyKey32(policyNftId), abi.encode(payout), newState);
|
271
|
-
}
|
272
|
-
|
273
|
-
function updateReferralState(NftId policyNftId, StateId newState) external restricted() {
|
274
|
-
updateState(toPolicyKey32(policyNftId), newState);
|
275
|
-
}
|
276
|
-
|
277
|
-
//--- Bundle ------------------------------------------------------------//
|
278
|
-
function createBundle(NftId bundleNftId, IBundle.BundleInfo memory bundle) external restricted() {
|
279
|
-
create(toBundleKey32(bundleNftId), abi.encode(bundle));
|
280
|
-
}
|
281
|
-
|
282
|
-
function updateBundle(NftId bundleNftId, IBundle.BundleInfo memory bundle, StateId newState) external restricted() {
|
283
|
-
update(toBundleKey32(bundleNftId), abi.encode(bundle), newState);
|
284
|
-
}
|
285
|
-
|
286
|
-
function updateBundleState(NftId bundleNftId, StateId newState) external restricted() {
|
287
|
-
updateState(toBundleKey32(bundleNftId), newState);
|
288
|
-
}
|
289
|
-
|
290
|
-
//--- Risk --------------------------------------------------------------//
|
291
|
-
function createRisk(RiskId riskId, IRisk.RiskInfo memory risk) external restricted() {
|
292
|
-
create(riskId.toKey32(), abi.encode(risk));
|
293
|
-
}
|
294
|
-
|
295
|
-
function updateRisk(RiskId riskId, IRisk.RiskInfo memory risk, StateId newState) external restricted() {
|
296
|
-
update(riskId.toKey32(), abi.encode(risk), newState);
|
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);
|
297
87
|
}
|
298
88
|
|
299
|
-
function
|
300
|
-
|
89
|
+
function grantRole(RoleId roleId, address account)
|
90
|
+
external
|
91
|
+
restricted // INSTANCE_OWNER_ROLE
|
92
|
+
{
|
93
|
+
AccessManagerExtendedInitializeable(authority()).grantRole(roleId.toInt(), account, 0);
|
301
94
|
}
|
302
95
|
|
303
|
-
|
304
|
-
|
305
|
-
|
96
|
+
function revokeRole(RoleId roleId, address account)
|
97
|
+
external
|
98
|
+
restricted // INSTANCE_OWNER_ROLE
|
99
|
+
{
|
100
|
+
AccessManagerExtendedInitializeable(authority()).revokeRole(roleId.toInt(), account);
|
306
101
|
}
|
307
102
|
|
308
|
-
|
309
|
-
update(toPolicyKey32(policyNftId), abi.encode(policy), newState);
|
310
|
-
}
|
103
|
+
//--- Targets ------------------------------------------------------------//
|
311
104
|
|
312
|
-
function
|
313
|
-
|
105
|
+
function createTarget(address target, string memory name)
|
106
|
+
external
|
107
|
+
restricted // INSTANCE_OWNER_ROLE
|
108
|
+
{
|
109
|
+
_instanceAdmin.createTarget(target, name);
|
314
110
|
}
|
315
111
|
|
316
|
-
|
317
|
-
|
318
|
-
|
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);
|
319
121
|
}
|
320
122
|
|
321
|
-
function
|
322
|
-
|
123
|
+
function setTargetLocked(address target, bool locked)
|
124
|
+
external
|
125
|
+
restricted // INSTANCE_OWNER_ROLE
|
126
|
+
{
|
127
|
+
_instanceAdmin.setTargetLockedByInstance(target, locked);
|
323
128
|
}
|
324
129
|
|
325
|
-
|
326
|
-
|
130
|
+
//--- ITransferInterceptor ------------------------------------------------------------//
|
131
|
+
// TODO interception of child components nfts
|
132
|
+
function nftMint(address to, uint256 tokenId) external onlyChainNft {
|
133
|
+
_instanceAdmin.transferInstanceOwnerRole(address(0), to);
|
327
134
|
}
|
328
135
|
|
329
|
-
|
330
|
-
|
331
|
-
create(toPolicyKey32(policyNftId), abi.encode(payout));
|
136
|
+
function nftTransferFrom(address from, address to, uint256 tokenId) external onlyChainNft {
|
137
|
+
_instanceAdmin.transferInstanceOwnerRole(from, to);
|
332
138
|
}
|
333
139
|
|
334
|
-
function
|
335
|
-
|
336
|
-
}
|
140
|
+
//function nftBurn(address from, uint256 tokenId) external onlyChainNft {
|
141
|
+
//_instanceAdmin.transferInstanceOwnerRole(from, address(0));
|
142
|
+
//}
|
337
143
|
|
338
|
-
|
339
|
-
updateState(toPolicyKey32(policyNftId), newState);
|
340
|
-
}
|
144
|
+
//--- initial setup functions -------------------------------------------//
|
341
145
|
|
342
|
-
|
343
|
-
|
344
|
-
|
345
|
-
|
346
|
-
|
347
|
-
|
348
|
-
|
349
|
-
|
350
|
-
isCustom);
|
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;
|
351
154
|
}
|
352
|
-
|
353
|
-
function
|
354
|
-
|
355
|
-
|
356
|
-
bool isCustom
|
357
|
-
)
|
358
|
-
internal
|
359
|
-
view
|
360
|
-
returns (
|
361
|
-
bool roleExists,
|
362
|
-
bool roleIsCustom
|
363
|
-
)
|
364
|
-
{
|
365
|
-
Key32 roleKey = toRoleKey32(roleId);
|
366
|
-
roleExists = exists(roleKey);
|
367
|
-
if (roleExists) {
|
368
|
-
roleIsCustom = abi.decode(getData(roleKey), (IAccess.RoleInfo)).isCustom;
|
369
|
-
} else {
|
370
|
-
roleIsCustom = isCustom;
|
155
|
+
|
156
|
+
function setBundleManager(BundleManager bundleManager) external restricted() {
|
157
|
+
if(address(_bundleManager) != address(0)) {
|
158
|
+
revert ErrorInstanceBundleManagerAlreadySet(address(_bundleManager));
|
371
159
|
}
|
372
|
-
|
373
|
-
|
374
|
-
uint64 roleIdInt = RoleId.unwrap(roleId);
|
375
|
-
if(roleIdInt == ADMIN_ROLE || roleIdInt == PUBLIC_ROLE) {
|
376
|
-
revert IAccess.ErrorRoleIdInvalid(roleId);
|
160
|
+
if(bundleManager.getInstance() != Instance(this)) {
|
161
|
+
revert ErrorInstanceBundleManagerInstanceMismatch(address(this));
|
377
162
|
}
|
378
|
-
|
379
|
-
|
380
|
-
revert IAccess.ErrorRoleIdTooSmall(roleId);
|
381
|
-
} else if (roleIsCustom && roleIdInt >= CUSTOM_ROLE_ID_MIN) {
|
382
|
-
revert IAccess.ErrorRoleIdTooBig(roleId);
|
163
|
+
if(bundleManager.authority() != authority()) {
|
164
|
+
revert ErrorInstanceBundleManagerAuthorityMismatch(authority());
|
383
165
|
}
|
166
|
+
_bundleManager = bundleManager;
|
167
|
+
}
|
384
168
|
|
385
|
-
|
386
|
-
|
387
|
-
|
388
|
-
revert IAccess.ErrorRoleNameEmpty(roleId);
|
169
|
+
function setInstanceReader(InstanceReader instanceReader) external restricted() {
|
170
|
+
if(instanceReader.getInstance() != Instance(this)) {
|
171
|
+
revert ErrorInstanceInstanceReaderInstanceMismatch(address(this));
|
389
172
|
}
|
390
173
|
|
391
|
-
|
392
|
-
revert IAccess.ErrorRoleNameNotUnique(_role[nameShort], nameShort);
|
393
|
-
}
|
174
|
+
_instanceReader = instanceReader;
|
394
175
|
}
|
395
176
|
|
396
|
-
|
177
|
+
//--- external view functions -------------------------------------------//
|
397
178
|
|
179
|
+
function getInstanceReader() external view returns (InstanceReader) {
|
180
|
+
return _instanceReader;
|
398
181
|
}
|
399
182
|
|
400
|
-
function
|
401
|
-
return
|
183
|
+
function getBundleManager() external view returns (BundleManager) {
|
184
|
+
return _bundleManager;
|
402
185
|
}
|
403
186
|
|
404
|
-
function
|
405
|
-
return
|
187
|
+
function getInstanceAdmin() external view returns (InstanceAdmin) {
|
188
|
+
return _instanceAdmin;
|
406
189
|
}
|
407
190
|
|
408
|
-
function
|
409
|
-
return
|
191
|
+
function getInstanceAccessManager() external view returns (AccessManagerExtendedInitializeable) {
|
192
|
+
return AccessManagerExtendedInitializeable(authority());
|
410
193
|
}
|
411
194
|
|
412
|
-
function
|
413
|
-
|
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;
|
414
203
|
}
|
415
204
|
|
416
|
-
function
|
417
|
-
return
|
205
|
+
function getInstanceStore() external view returns (InstanceStore) {
|
206
|
+
return _instanceStore;
|
418
207
|
}
|
419
208
|
|
420
|
-
function
|
421
|
-
return
|
209
|
+
function getMajorVersion() external pure returns (VersionPart majorVersion) {
|
210
|
+
return VersionPartLib.toVersionPart(GIF_MAJOR_VERSION);
|
422
211
|
}
|
423
212
|
|
424
213
|
function getDistributionService() external view returns (IDistributionService) {
|
425
|
-
return IDistributionService(
|
214
|
+
return IDistributionService(getRegistry().getServiceAddress(DISTRIBUTION(), VersionPart.wrap(3)));
|
426
215
|
}
|
427
216
|
|
428
217
|
function getProductService() external view returns (IProductService) {
|
429
|
-
return IProductService(
|
218
|
+
return IProductService(getRegistry().getServiceAddress(PRODUCT(), VersionPart.wrap(3)));
|
430
219
|
}
|
431
220
|
|
432
221
|
function getPoolService() external view returns (IPoolService) {
|
433
|
-
return IPoolService(
|
222
|
+
return IPoolService(getRegistry().getServiceAddress(POOL(), VersionPart.wrap(3)));
|
434
223
|
}
|
435
224
|
|
436
|
-
function
|
437
|
-
|
438
|
-
_instanceReader = instanceReader;
|
225
|
+
function getPolicyService() external view returns (IPolicyService) {
|
226
|
+
return IPolicyService(getRegistry().getServiceAddress(POLICY(), VersionPart.wrap(3)));
|
439
227
|
}
|
440
228
|
|
441
|
-
function
|
442
|
-
return
|
443
|
-
}
|
444
|
-
|
445
|
-
function setBundleManager(BundleManager bundleManager) external restricted() {
|
446
|
-
require(address(_bundleManager) == address(0), "BundleManager is set");
|
447
|
-
require(bundleManager.getInstanceNftId() == getNftId(), "NFT ID of BundleManager does not match");
|
448
|
-
_bundleManager = bundleManager;
|
229
|
+
function getBundleService() external view returns (IBundleService) {
|
230
|
+
return IBundleService(getRegistry().getServiceAddress(BUNDLE(), VersionPart.wrap(3)));
|
449
231
|
}
|
450
232
|
|
451
|
-
|
452
|
-
|
453
|
-
}
|
454
|
-
}
|
233
|
+
//--- internal view/pure functions --------------------------------------//
|
234
|
+
}
|