@etherisc/gif-next 0.0.2-836e6e4-400 → 0.0.2-83d1db6-607
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 +73 -1
- package/artifacts/contracts/components/Component.sol/Component.dbg.json +4 -0
- package/artifacts/contracts/components/Component.sol/Component.json +832 -0
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/components/Distribution.sol/Distribution.json +843 -296
- package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +4 -0
- package/artifacts/contracts/components/{BaseComponent.sol/BaseComponent.json → IComponent.sol/IComponent.json} +149 -113
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +743 -26
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +737 -58
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +582 -9
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/components/Pool.sol/Pool.json +705 -316
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/components/Product.sol/Product.json +519 -245
- package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +1 -1
- package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +15 -15
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +69 -79
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +1 -1
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.json +5 -0
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +1003 -393
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +209 -183
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +1015 -781
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +432 -178
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +120 -263
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +399 -245
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +339 -82
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +1 -1
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +11 -40
- package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.dbg.json +4 -0
- package/artifacts/contracts/instance/base/{ComponentServiceBase.sol/ComponentServiceBase.json → ComponentService.sol/ComponentService.json} +184 -153
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +40 -10
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +36 -11
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +61 -67
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +4 -0
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.json +10 -0
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
- package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +1 -1
- package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.json +968 -0
- package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.json +665 -0
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +436 -266
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +308 -79
- package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.json +754 -0
- package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.json +637 -0
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +1243 -182
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +456 -71
- package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/{IComponentOwnerService.sol/IComponentOwnerService.json → IApplicationService.sol/IApplicationService.json} +275 -185
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.json +199 -238
- package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.dbg.json +4 -0
- package/artifacts/contracts/{components/IBaseComponent.sol/IBaseComponent.json → instance/service/IClaimService.sol/IClaimService.json} +159 -134
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.json +728 -161
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.json +152 -276
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +81 -152
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.json +22 -174
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +381 -331
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +321 -96
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +304 -185
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +313 -76
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +221 -199
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +305 -76
- 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 +117 -5
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +112 -198
- 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 +131 -27
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +18 -18
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +216 -234
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +300 -81
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +70 -69
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +151 -50
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +1 -1
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +41 -3
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +40 -29
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +129 -0
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +21 -34
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/{experiment/inheritance/IB.sol/IB.json → shared/IRegistryLinked.sol/IRegistryLinked.json} +18 -20
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +22 -174
- 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 -27
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +248 -0
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +294 -61
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +129 -51
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +84 -0
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +114 -157
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +2 -2
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +2 -2
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
- package/artifacts/contracts/shared/Versionable.sol/Versionable.json +2 -152
- package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +1 -1
- package/artifacts/contracts/test/TestFee.sol/TestFee.json +2 -2
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +1 -1
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +129 -51
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +1 -1
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +6 -6
- package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +1 -1
- package/artifacts/contracts/test/TestService.sol/TestService.json +135 -214
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +1 -1
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +1 -1
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +2 -2
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +1 -1
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +8 -190
- package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +1 -1
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +2 -2
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.json +100 -0
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.json +2 -2
- package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/types/Fee.sol/FeeLib.json +2 -2
- package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/types/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/NftId.sol/NftIdLib.json +17 -4
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.json +2 -2
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +2 -2
- package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.json +100 -0
- package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +1 -1
- package/artifacts/contracts/types/Referral.sol/ReferralLib.json +23 -4
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.json +2 -2
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +2 -2
- package/artifacts/contracts/types/Seconds.sol/SecondsLib.dbg.json +4 -0
- package/artifacts/contracts/types/Seconds.sol/SecondsLib.json +124 -0
- package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/StateId.sol/StateIdLib.json +2 -2
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +25 -7
- package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +1 -1
- package/artifacts/contracts/types/UFixed.sol/MathLib.json +2 -2
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.json +2 -2
- package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/types/Version.sol/VersionLib.json +2 -2
- package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/types/Version.sol/VersionPartLib.json +2 -2
- package/contracts/components/Component.sol +251 -0
- package/contracts/components/Distribution.sol +200 -83
- package/contracts/components/IComponent.sol +74 -0
- package/contracts/components/IDistributionComponent.sol +44 -17
- package/contracts/components/IPoolComponent.sol +88 -41
- package/contracts/components/IProductComponent.sol +10 -5
- package/contracts/components/Pool.sol +209 -181
- package/contracts/components/Product.sol +125 -124
- package/contracts/instance/AccessManagerUpgradeableInitializeable.sol +2 -12
- package/contracts/instance/BundleManager.sol +14 -16
- package/contracts/instance/Cloneable.sol +7 -2
- package/contracts/instance/IInstance.sol +52 -16
- package/contracts/instance/IInstanceService.sol +39 -5
- package/contracts/instance/Instance.sol +126 -75
- package/contracts/instance/InstanceAccessManager.sol +383 -165
- package/contracts/instance/InstanceReader.sol +9 -34
- package/contracts/instance/InstanceService.sol +296 -101
- package/contracts/instance/InstanceServiceManager.sol +1 -1
- package/contracts/instance/ObjectManager.sol +10 -29
- package/contracts/instance/base/ComponentService.sol +134 -0
- package/contracts/instance/base/KeyValueStore.sol +5 -2
- package/contracts/instance/base/Lifecycle.sol +11 -2
- package/contracts/instance/module/IAccess.sol +23 -17
- package/contracts/instance/module/IBundle.sol +2 -1
- package/contracts/instance/module/IComponents.sol +35 -0
- package/contracts/instance/module/IDistribution.sol +2 -0
- package/contracts/instance/module/IPolicy.sol +30 -3
- package/contracts/instance/module/ISetup.sol +7 -20
- package/contracts/instance/service/ApplicationService.sol +350 -0
- package/contracts/instance/service/ApplicationServiceManager.sol +35 -0
- package/contracts/instance/service/BundleService.sol +111 -35
- package/contracts/instance/service/BundleServiceManager.sol +1 -1
- package/contracts/instance/service/ClaimService.sol +151 -0
- package/contracts/instance/service/ClaimServiceManager.sol +35 -0
- package/contracts/instance/service/DistributionService.sol +395 -42
- package/contracts/instance/service/DistributionServiceManager.sol +1 -1
- package/contracts/instance/service/IApplicationService.sol +82 -0
- package/contracts/instance/service/IBundleService.sol +31 -14
- package/contracts/instance/service/IClaimService.sol +61 -0
- package/contracts/instance/service/IDistributionService.sol +86 -0
- package/contracts/instance/service/IPolicyService.sol +34 -49
- package/contracts/instance/service/IPoolService.sol +17 -2
- package/contracts/instance/service/PolicyService.sol +205 -305
- package/contracts/instance/service/PolicyServiceManager.sol +2 -2
- package/contracts/instance/service/PoolService.sol +138 -40
- package/contracts/instance/service/PoolServiceManager.sol +1 -1
- package/contracts/instance/service/ProductService.sol +107 -34
- package/contracts/instance/service/ProductServiceManager.sol +2 -2
- package/contracts/registry/ChainNft.sol +8 -0
- package/contracts/registry/IRegistry.sol +18 -8
- package/contracts/registry/IRegistryService.sol +19 -10
- package/contracts/registry/ITransferInterceptor.sol +1 -0
- package/contracts/registry/Registry.sol +142 -71
- package/contracts/registry/RegistryAccessManager.sol +31 -25
- package/contracts/registry/RegistryService.sol +94 -134
- package/contracts/registry/RegistryServiceManager.sol +13 -13
- package/contracts/registry/ReleaseManager.sol +94 -120
- package/contracts/registry/TokenRegistry.sol +19 -13
- package/contracts/shared/ERC165.sol +14 -12
- package/contracts/shared/INftOwnable.sol +11 -10
- package/contracts/shared/IPolicyHolder.sol +26 -0
- package/contracts/shared/IRegisterable.sol +4 -6
- package/contracts/shared/IRegistryLinked.sol +12 -0
- package/contracts/shared/IService.sol +2 -0
- package/contracts/shared/IVersionable.sol +4 -47
- package/contracts/shared/NftOwnable.sol +66 -80
- package/contracts/shared/PolicyHolder.sol +81 -0
- package/contracts/shared/ProxyManager.sol +100 -25
- package/contracts/shared/Registerable.sol +16 -32
- package/contracts/shared/RegistryLinked.sol +48 -0
- package/contracts/shared/Service.sol +19 -19
- package/contracts/shared/TokenHandler.sol +11 -5
- package/contracts/shared/Versionable.sol +4 -92
- package/contracts/test/TestRegisterable.sol +1 -1
- package/contracts/test/TestService.sol +1 -1
- package/contracts/types/Blocknumber.sol +1 -0
- package/contracts/types/ClaimId.sol +52 -0
- package/contracts/types/DistributorType.sol +2 -2
- package/contracts/types/Fee.sol +1 -0
- package/contracts/types/NftId.sol +8 -0
- package/contracts/types/ObjectType.sol +10 -5
- package/contracts/types/PayoutId.sol +54 -0
- package/contracts/types/Referral.sol +4 -0
- package/contracts/types/RoleId.sol +18 -11
- package/contracts/types/Seconds.sol +54 -0
- package/contracts/types/StateId.sol +1 -0
- package/contracts/types/Timestamp.sol +13 -13
- package/contracts/types/UFixed.sol +1 -0
- package/contracts/types/Version.sol +1 -0
- package/package.json +3 -3
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.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/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/IInstanceBase.sol/IInstanceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/IInstanceBase.sol/IInstanceBase.json +0 -448
- 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/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 -814
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/shared/RegisterableUpgradable.sol/RegisterableUpgradable.dbg.json +0 -4
- package/artifacts/contracts/shared/RegisterableUpgradable.sol/RegisterableUpgradable.json +0 -442
- package/contracts/components/BaseComponent.sol +0 -148
- package/contracts/components/IBaseComponent.sol +0 -32
- 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/IInstanceBase.sol +0 -26
- package/contracts/instance/InstanceBase.sol +0 -41
- package/contracts/instance/base/ComponentServiceBase.sol +0 -72
- package/contracts/instance/base/IInstanceBase.sol +0 -23
- package/contracts/instance/service/ComponentOwnerService.sol +0 -315
- package/contracts/instance/service/IComponentOwnerService.sol +0 -20
- package/contracts/shared/RegisterableUpgradable.sol +0 -16
@@ -17,6 +17,7 @@ import {StateId} from "../types/StateId.sol";
|
|
17
17
|
|
18
18
|
import {IRegistry} from "../registry/IRegistry.sol";
|
19
19
|
import {IBundle} from "../instance/module/IBundle.sol";
|
20
|
+
import {IComponents} from "../instance/module/IComponents.sol";
|
20
21
|
import {IDistribution} from "../instance/module/IDistribution.sol";
|
21
22
|
import {IInstance} from "./IInstance.sol";
|
22
23
|
import {IKeyValueStore} from "../instance/base/IKeyValueStore.sol";
|
@@ -30,40 +31,18 @@ import {TimestampLib} from "../types/Timestamp.sol";
|
|
30
31
|
contract InstanceReader {
|
31
32
|
bool private _initialized;
|
32
33
|
|
33
|
-
IRegistry internal _registry;
|
34
|
-
NftId internal _instanceNftId;
|
35
34
|
IInstance internal _instance;
|
36
35
|
IKeyValueStore internal _store;
|
37
36
|
|
38
|
-
|
39
|
-
address registry,
|
40
|
-
NftId instanceNftId
|
41
|
-
)
|
42
|
-
{
|
43
|
-
initialize(registry, instanceNftId);
|
44
|
-
}
|
45
|
-
|
46
|
-
function initialize(address registry, NftId instanceNftId) public {
|
37
|
+
function initialize(address instance) public {
|
47
38
|
require(!_initialized, "ERROR:CRD-000:ALREADY_INITIALIZED");
|
48
39
|
|
49
40
|
require(
|
50
|
-
address(
|
51
|
-
"ERROR:CRD-001:
|
52
|
-
|
53
|
-
require(
|
54
|
-
instanceNftId.gtz(),
|
55
|
-
"ERROR:CRD-002:NFT_ID_ZERO");
|
41
|
+
address(instance) != address(0),
|
42
|
+
"ERROR:CRD-001:INSTANCE_ZERO");
|
56
43
|
|
57
|
-
|
58
|
-
|
59
|
-
IRegistry.ObjectInfo memory instanceInfo = _registry.getObjectInfo(_instanceNftId);
|
60
|
-
|
61
|
-
require(
|
62
|
-
instanceInfo.objectType == INSTANCE(),
|
63
|
-
"ERROR:CRD-003:PARENT_NOT_INSTANCE");
|
64
|
-
|
65
|
-
_instance = IInstance(instanceInfo.objectAddress);
|
66
|
-
_store = IKeyValueStore(instanceInfo.objectAddress);
|
44
|
+
_instance = IInstance(instance);
|
45
|
+
_store = IKeyValueStore(instance);
|
67
46
|
|
68
47
|
_initialized = true;
|
69
48
|
}
|
@@ -169,14 +148,14 @@ contract InstanceReader {
|
|
169
148
|
}
|
170
149
|
}
|
171
150
|
|
172
|
-
function
|
151
|
+
function getComponentInfo(NftId poolNftId)
|
173
152
|
public
|
174
153
|
view
|
175
|
-
returns (
|
154
|
+
returns (IComponents.ComponentInfo memory info)
|
176
155
|
{
|
177
156
|
bytes memory data = _store.getData(toPoolKey(poolNftId));
|
178
157
|
if (data.length > 0) {
|
179
|
-
return abi.decode(data, (
|
158
|
+
return abi.decode(data, (IComponents.ComponentInfo));
|
180
159
|
}
|
181
160
|
}
|
182
161
|
|
@@ -301,10 +280,6 @@ contract InstanceReader {
|
|
301
280
|
return _store;
|
302
281
|
}
|
303
282
|
|
304
|
-
function getInstanceNftId() external view returns (NftId nftId) {
|
305
|
-
return _instanceNftId;
|
306
|
-
}
|
307
|
-
|
308
283
|
function toUFixed(uint256 value, int8 exp) public pure returns (UFixed) {
|
309
284
|
return UFixedLib.toUFixed(value, exp);
|
310
285
|
}
|
@@ -2,24 +2,33 @@
|
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
4
|
import {Clones} from "@openzeppelin/contracts/proxy/Clones.sol";
|
5
|
+
import {ShortString, ShortStrings} from "@openzeppelin/contracts/utils/ShortStrings.sol";
|
5
6
|
|
6
7
|
import {Instance} from "./Instance.sol";
|
8
|
+
import {IInstance} from "./IInstance.sol";
|
7
9
|
import {InstanceAccessManager} from "./InstanceAccessManager.sol";
|
8
10
|
import {IInstanceService} from "./IInstanceService.sol";
|
9
11
|
import {InstanceReader} from "./InstanceReader.sol";
|
10
12
|
import {BundleManager} from "./BundleManager.sol";
|
13
|
+
import {AccessManagerUpgradeableInitializeable} from "./AccessManagerUpgradeableInitializeable.sol";
|
11
14
|
import {IRegistry} from "../registry/IRegistry.sol";
|
12
|
-
import {
|
15
|
+
import {IRegistryService} from "../registry/IRegistryService.sol";
|
13
16
|
import {ChainNft} from "../registry/ChainNft.sol";
|
14
17
|
import {Service} from "../../contracts/shared/Service.sol";
|
15
18
|
import {IService} from "../shared/IService.sol";
|
16
19
|
import {NftId} from "../../contracts/types/NftId.sol";
|
17
20
|
import {RoleId} from "../types/RoleId.sol";
|
18
|
-
import {ADMIN_ROLE, INSTANCE_SERVICE_ROLE, DISTRIBUTION_SERVICE_ROLE, POOL_SERVICE_ROLE, PRODUCT_SERVICE_ROLE, POLICY_SERVICE_ROLE, BUNDLE_SERVICE_ROLE} from "../types/RoleId.sol";
|
19
|
-
import {ObjectType,
|
20
|
-
|
21
|
-
|
22
|
-
|
21
|
+
import {ADMIN_ROLE, INSTANCE_OWNER_ROLE, DISTRIBUTION_OWNER_ROLE, POOL_OWNER_ROLE, PRODUCT_OWNER_ROLE, INSTANCE_SERVICE_ROLE, DISTRIBUTION_SERVICE_ROLE, POOL_SERVICE_ROLE, PRODUCT_SERVICE_ROLE, APPLICATION_SERVICE_ROLE, POLICY_SERVICE_ROLE, CLAIM_SERVICE_ROLE, BUNDLE_SERVICE_ROLE, INSTANCE_ROLE} from "../types/RoleId.sol";
|
22
|
+
import {ObjectType, INSTANCE, BUNDLE, APPLICATION, POLICY, CLAIM, PRODUCT, DISTRIBUTION, REGISTRY, POOL} from "../types/ObjectType.sol";
|
23
|
+
import {IDistributionComponent} from "../components/IDistributionComponent.sol";
|
24
|
+
import {IPoolComponent} from "../components/IPoolComponent.sol";
|
25
|
+
import {IProductComponent} from "../components/IProductComponent.sol";
|
26
|
+
|
27
|
+
contract InstanceService is
|
28
|
+
Service,
|
29
|
+
IInstanceService
|
30
|
+
{
|
31
|
+
address internal _masterOzAccessManager;
|
23
32
|
address internal _masterInstanceAccessManager;
|
24
33
|
address internal _masterInstance;
|
25
34
|
address internal _masterInstanceReader;
|
@@ -27,14 +36,25 @@ contract InstanceService is Service, IInstanceService {
|
|
27
36
|
|
28
37
|
// TODO update to real hash when instance is stable
|
29
38
|
bytes32 public constant INSTANCE_CREATION_CODE_HASH = bytes32(0);
|
30
|
-
string public constant NAME = "InstanceService";
|
31
39
|
|
32
|
-
modifier onlyInstanceOwner(NftId instanceNftId) {
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
40
|
+
modifier onlyInstanceOwner(NftId instanceNftId) {
|
41
|
+
if(msg.sender != getRegistry().ownerOf(instanceNftId)) {
|
42
|
+
revert ErrorInstanceServiceRequestUnauhorized(msg.sender);
|
43
|
+
}
|
44
|
+
_;
|
45
|
+
}
|
46
|
+
// TODO check service domain?
|
47
|
+
// TODO check release version?
|
48
|
+
modifier onlyRegisteredService() {
|
49
|
+
if (! getRegistry().isRegisteredService(msg.sender)) {
|
50
|
+
revert ErrorInstanceServiceRequestUnauhorized(msg.sender);
|
51
|
+
}
|
52
|
+
_;
|
53
|
+
}
|
54
|
+
// TODO check release version?
|
55
|
+
modifier onlyComponent() {
|
56
|
+
if (! getRegistry().isRegisteredComponent(msg.sender)) {
|
57
|
+
revert ErrorInstanceServiceRequestUnauhorized(msg.sender);
|
38
58
|
}
|
39
59
|
_;
|
40
60
|
}
|
@@ -42,7 +62,8 @@ contract InstanceService is Service, IInstanceService {
|
|
42
62
|
function createInstanceClone()
|
43
63
|
external
|
44
64
|
returns (
|
45
|
-
|
65
|
+
AccessManagerUpgradeableInitializeable clonedOzAccessManager,
|
66
|
+
InstanceAccessManager clonedInstanceAccessManager,
|
46
67
|
Instance clonedInstance,
|
47
68
|
NftId clonedInstanceNftId,
|
48
69
|
InstanceReader clonedInstanceReader,
|
@@ -54,76 +75,128 @@ contract InstanceService is Service, IInstanceService {
|
|
54
75
|
address registryAddress = address(registry);
|
55
76
|
NftId registryNftId = registry.getNftId(registryAddress);
|
56
77
|
address registryServiceAddress = registry.getServiceAddress(REGISTRY(), getMajorVersion());
|
57
|
-
|
78
|
+
IRegistryService registryService = IRegistryService(registryServiceAddress);
|
79
|
+
|
80
|
+
clonedOzAccessManager = AccessManagerUpgradeableInitializeable(
|
81
|
+
Clones.clone(_masterOzAccessManager));
|
58
82
|
|
59
|
-
// initially
|
60
|
-
// This will allow the instance service to bootstrap the authorizations of the instance
|
61
|
-
//
|
62
|
-
|
63
|
-
|
83
|
+
// initially grants ADMIN_ROLE to this (being the instance service).
|
84
|
+
// This will allow the instance service to bootstrap the authorizations of the instance.
|
85
|
+
// Instance service will not use oz access manager directlly but through instance access manager instead
|
86
|
+
// Instance service will renounce ADMIN_ROLE when bootstraping is finished
|
87
|
+
clonedOzAccessManager.initialize(address(this));
|
64
88
|
|
65
89
|
clonedInstance = Instance(Clones.clone(_masterInstance));
|
66
|
-
clonedInstance.initialize(
|
67
|
-
|
68
|
-
|
90
|
+
clonedInstance.initialize(
|
91
|
+
address(clonedOzAccessManager),
|
92
|
+
registryAddress,
|
93
|
+
instanceOwner);
|
69
94
|
|
70
95
|
clonedInstanceReader = InstanceReader(Clones.clone(address(_masterInstanceReader)));
|
71
|
-
clonedInstanceReader.initialize(
|
96
|
+
clonedInstanceReader.initialize(address(clonedInstance));
|
72
97
|
clonedInstance.setInstanceReader(clonedInstanceReader);
|
73
98
|
|
74
99
|
clonedBundleManager = BundleManager(Clones.clone(_masterInstanceBundleManager));
|
75
|
-
clonedBundleManager.initialize(address(
|
100
|
+
clonedBundleManager.initialize(address(clonedInstance));
|
76
101
|
clonedInstance.setBundleManager(clonedBundleManager);
|
77
102
|
|
103
|
+
clonedInstanceAccessManager = InstanceAccessManager(Clones.clone(_masterInstanceAccessManager));
|
104
|
+
clonedOzAccessManager.grantRole(ADMIN_ROLE().toInt(), address(clonedInstanceAccessManager), 0);
|
105
|
+
clonedInstanceAccessManager.initialize(address(clonedInstance));
|
106
|
+
clonedInstance.setInstanceAccessManager(clonedInstanceAccessManager);
|
107
|
+
|
78
108
|
// TODO amend setters with instance specific , policy manager ...
|
79
109
|
|
80
|
-
_grantInitialAuthorizations(
|
110
|
+
_grantInitialAuthorizations(clonedInstanceAccessManager, clonedInstance, clonedBundleManager, instanceOwner);
|
81
111
|
|
82
|
-
|
83
|
-
// TODO: use a role less powerful than admin, maybe INSTANCE_ADMIN (does not exist yet)
|
84
|
-
clonedAccessManager.grantRole(ADMIN_ROLE(), instanceOwner);
|
85
|
-
clonedAccessManager.revokeRole(ADMIN_ROLE(), address(this));
|
112
|
+
clonedOzAccessManager.renounceRole(ADMIN_ROLE().toInt(), address(this));
|
86
113
|
|
87
|
-
|
114
|
+
IRegistry.ObjectInfo memory info = registryService.registerInstance(clonedInstance, instanceOwner);
|
115
|
+
clonedInstanceNftId = info.nftId;
|
116
|
+
// clonedInstance.linkToRegisteredNftId();
|
117
|
+
|
118
|
+
emit LogInstanceCloned(
|
119
|
+
address(clonedOzAccessManager),
|
120
|
+
address(clonedInstanceAccessManager),
|
121
|
+
address(clonedInstance),
|
122
|
+
address(clonedBundleManager),
|
123
|
+
address(clonedInstanceReader),
|
124
|
+
clonedInstanceNftId);
|
88
125
|
}
|
89
126
|
|
90
|
-
function _grantInitialAuthorizations(
|
91
|
-
|
127
|
+
function _grantInitialAuthorizations(
|
128
|
+
InstanceAccessManager clonedAccessManager,
|
129
|
+
Instance clonedInstance,
|
130
|
+
BundleManager clonedBundleManager,
|
131
|
+
address instanceOwner)
|
132
|
+
internal
|
133
|
+
{
|
134
|
+
_createCoreAndGifRoles(clonedAccessManager);
|
135
|
+
_createCoreTargets(clonedAccessManager, clonedInstance, clonedBundleManager);
|
92
136
|
_grantDistributionServiceAuthorizations(clonedAccessManager, clonedInstance);
|
93
137
|
_grantPoolServiceAuthorizations(clonedAccessManager, clonedInstance);
|
94
138
|
_grantProductServiceAuthorizations(clonedAccessManager, clonedInstance);
|
139
|
+
_grantApplicationServiceAuthorizations(clonedAccessManager, clonedInstance);
|
95
140
|
_grantPolicyServiceAuthorizations(clonedAccessManager, clonedInstance);
|
141
|
+
_grantClaimServiceAuthorizations(clonedAccessManager, clonedInstance);
|
96
142
|
_grantBundleServiceAuthorizations(clonedAccessManager, clonedInstance, clonedBundleManager);
|
97
143
|
_grantInstanceServiceAuthorizations(clonedAccessManager, clonedInstance);
|
144
|
+
_grantInstanceOwnerAuthorizations(clonedAccessManager, instanceOwner);
|
145
|
+
}
|
146
|
+
|
147
|
+
function _createCoreAndGifRoles(InstanceAccessManager clonedAccessManager) internal {
|
148
|
+
// default roles controlled by ADMIN_ROLE -> core roles
|
149
|
+
// all set/granted only once during cloning (the only exception is INSTANCE_OWNER_ROLE, hooked to instance nft)
|
150
|
+
clonedAccessManager.createCoreRole(INSTANCE_SERVICE_ROLE(), "InstanceServiceRole");
|
151
|
+
clonedAccessManager.createCoreRole(DISTRIBUTION_SERVICE_ROLE(), "DistributionServiceRole");
|
152
|
+
clonedAccessManager.createCoreRole(POOL_SERVICE_ROLE(), "PoolServiceRole");
|
153
|
+
clonedAccessManager.createCoreRole(APPLICATION_SERVICE_ROLE(), "ApplicationServiceRole");
|
154
|
+
clonedAccessManager.createCoreRole(PRODUCT_SERVICE_ROLE(), "ProductServiceRole");
|
155
|
+
clonedAccessManager.createCoreRole(CLAIM_SERVICE_ROLE(), "ClaimServiceRole");
|
156
|
+
clonedAccessManager.createCoreRole(POLICY_SERVICE_ROLE(), "PolicyServiceRole");
|
157
|
+
clonedAccessManager.createCoreRole(BUNDLE_SERVICE_ROLE(), "BundleServiceRole");
|
158
|
+
// default roles controlled by INSTANCE_OWNER_ROLE -> gif roles
|
159
|
+
clonedAccessManager.createGifRole(DISTRIBUTION_OWNER_ROLE(), "DistributionOwnerRole", INSTANCE_OWNER_ROLE());
|
160
|
+
clonedAccessManager.createGifRole(POOL_OWNER_ROLE(), "PoolOwnerRole", INSTANCE_OWNER_ROLE());
|
161
|
+
clonedAccessManager.createGifRole(PRODUCT_OWNER_ROLE(), "ProductOwnerRole", INSTANCE_OWNER_ROLE());
|
98
162
|
}
|
99
163
|
|
100
|
-
function
|
101
|
-
clonedAccessManager.
|
102
|
-
clonedAccessManager.
|
164
|
+
function _createCoreTargets(InstanceAccessManager clonedAccessManager, Instance clonedInstance, BundleManager clonedBundleManager) internal {
|
165
|
+
clonedAccessManager.createCoreTarget(address(clonedAccessManager), "InstanceAccessManager");
|
166
|
+
clonedAccessManager.createCoreTarget(address(clonedInstance), "Instance");
|
167
|
+
clonedAccessManager.createCoreTarget(address(clonedBundleManager), "BundleManager");
|
103
168
|
}
|
104
169
|
|
105
170
|
function _grantDistributionServiceAuthorizations(InstanceAccessManager clonedAccessManager, Instance clonedInstance) internal {
|
106
171
|
// configure authorization for distribution service on instance
|
107
|
-
|
108
|
-
address distributionServiceAddress = registry.getServiceAddress(DISTRIBUTION(), getMajorVersion());
|
172
|
+
address distributionServiceAddress = getRegistry().getServiceAddress(DISTRIBUTION(), getMajorVersion());
|
109
173
|
clonedAccessManager.grantRole(DISTRIBUTION_SERVICE_ROLE(), distributionServiceAddress);
|
110
|
-
bytes4[] memory instanceDistributionServiceSelectors = new bytes4[](
|
174
|
+
bytes4[] memory instanceDistributionServiceSelectors = new bytes4[](11);
|
111
175
|
instanceDistributionServiceSelectors[0] = clonedInstance.createDistributionSetup.selector;
|
112
176
|
instanceDistributionServiceSelectors[1] = clonedInstance.updateDistributionSetup.selector;
|
113
|
-
|
177
|
+
instanceDistributionServiceSelectors[2] = clonedInstance.createDistributorType.selector;
|
178
|
+
instanceDistributionServiceSelectors[3] = clonedInstance.updateDistributorType.selector;
|
179
|
+
instanceDistributionServiceSelectors[4] = clonedInstance.updateDistributorTypeState.selector;
|
180
|
+
instanceDistributionServiceSelectors[5] = clonedInstance.createDistributor.selector;
|
181
|
+
instanceDistributionServiceSelectors[6] = clonedInstance.updateDistributor.selector;
|
182
|
+
instanceDistributionServiceSelectors[7] = clonedInstance.updateDistributorState.selector;
|
183
|
+
instanceDistributionServiceSelectors[8] = clonedInstance.createReferral.selector;
|
184
|
+
instanceDistributionServiceSelectors[9] = clonedInstance.updateReferral.selector;
|
185
|
+
instanceDistributionServiceSelectors[10] = clonedInstance.updateReferralState.selector;
|
186
|
+
clonedAccessManager.setCoreTargetFunctionRole(
|
114
187
|
"Instance",
|
115
188
|
instanceDistributionServiceSelectors,
|
116
|
-
DISTRIBUTION_SERVICE_ROLE());
|
189
|
+
DISTRIBUTION_SERVICE_ROLE());
|
117
190
|
}
|
118
191
|
|
119
192
|
function _grantPoolServiceAuthorizations(InstanceAccessManager clonedAccessManager, Instance clonedInstance) internal {
|
120
193
|
// configure authorization for pool service on instance
|
121
|
-
address poolServiceAddress =
|
194
|
+
address poolServiceAddress = getRegistry().getServiceAddress(POOL(), getMajorVersion());
|
122
195
|
clonedAccessManager.grantRole(POOL_SERVICE_ROLE(), address(poolServiceAddress));
|
123
196
|
bytes4[] memory instancePoolServiceSelectors = new bytes4[](4);
|
124
197
|
instancePoolServiceSelectors[0] = clonedInstance.createPoolSetup.selector;
|
125
198
|
instancePoolServiceSelectors[1] = clonedInstance.updatePoolSetup.selector;
|
126
|
-
clonedAccessManager.
|
199
|
+
clonedAccessManager.setCoreTargetFunctionRole(
|
127
200
|
"Instance",
|
128
201
|
instancePoolServiceSelectors,
|
129
202
|
POOL_SERVICE_ROLE());
|
@@ -131,7 +204,7 @@ contract InstanceService is Service, IInstanceService {
|
|
131
204
|
|
132
205
|
function _grantProductServiceAuthorizations(InstanceAccessManager clonedAccessManager, Instance clonedInstance) internal {
|
133
206
|
// configure authorization for product service on instance
|
134
|
-
address productServiceAddress =
|
207
|
+
address productServiceAddress = getRegistry().getServiceAddress(PRODUCT(), getMajorVersion());
|
135
208
|
clonedAccessManager.grantRole(PRODUCT_SERVICE_ROLE(), address(productServiceAddress));
|
136
209
|
bytes4[] memory instanceProductServiceSelectors = new bytes4[](5);
|
137
210
|
instanceProductServiceSelectors[0] = clonedInstance.createProductSetup.selector;
|
@@ -139,34 +212,62 @@ contract InstanceService is Service, IInstanceService {
|
|
139
212
|
instanceProductServiceSelectors[2] = clonedInstance.createRisk.selector;
|
140
213
|
instanceProductServiceSelectors[3] = clonedInstance.updateRisk.selector;
|
141
214
|
instanceProductServiceSelectors[4] = clonedInstance.updateRiskState.selector;
|
142
|
-
clonedAccessManager.
|
215
|
+
clonedAccessManager.setCoreTargetFunctionRole(
|
143
216
|
"Instance",
|
144
217
|
instanceProductServiceSelectors,
|
145
218
|
PRODUCT_SERVICE_ROLE());
|
146
219
|
}
|
147
220
|
|
221
|
+
function _grantApplicationServiceAuthorizations(InstanceAccessManager clonedAccessManager, Instance clonedInstance) internal {
|
222
|
+
// configure authorization for application services on instance
|
223
|
+
address applicationServiceAddress = getRegistry().getServiceAddress(APPLICATION(), getMajorVersion());
|
224
|
+
clonedAccessManager.grantRole(APPLICATION_SERVICE_ROLE(), applicationServiceAddress);
|
225
|
+
bytes4[] memory instanceApplicationServiceSelectors = new bytes4[](3);
|
226
|
+
instanceApplicationServiceSelectors[0] = clonedInstance.createApplication.selector;
|
227
|
+
instanceApplicationServiceSelectors[1] = clonedInstance.updateApplication.selector;
|
228
|
+
instanceApplicationServiceSelectors[2] = clonedInstance.updateApplicationState.selector;
|
229
|
+
clonedAccessManager.setCoreTargetFunctionRole(
|
230
|
+
"Instance",
|
231
|
+
instanceApplicationServiceSelectors,
|
232
|
+
APPLICATION_SERVICE_ROLE());
|
233
|
+
}
|
234
|
+
|
148
235
|
function _grantPolicyServiceAuthorizations(InstanceAccessManager clonedAccessManager, Instance clonedInstance) internal {
|
149
|
-
// configure authorization for policy
|
150
|
-
address policyServiceAddress =
|
151
|
-
clonedAccessManager.grantRole(POLICY_SERVICE_ROLE(),
|
152
|
-
bytes4[] memory instancePolicyServiceSelectors = new bytes4[](
|
153
|
-
instancePolicyServiceSelectors[0] = clonedInstance.
|
154
|
-
instancePolicyServiceSelectors[1] = clonedInstance.
|
155
|
-
|
156
|
-
clonedAccessManager.setTargetFunctionRole(
|
236
|
+
// configure authorization for policy services on instance
|
237
|
+
address policyServiceAddress = getRegistry().getServiceAddress(POLICY(), getMajorVersion());
|
238
|
+
clonedAccessManager.grantRole(POLICY_SERVICE_ROLE(), policyServiceAddress);
|
239
|
+
bytes4[] memory instancePolicyServiceSelectors = new bytes4[](2);
|
240
|
+
instancePolicyServiceSelectors[0] = clonedInstance.updatePolicy.selector;
|
241
|
+
instancePolicyServiceSelectors[1] = clonedInstance.updatePolicyState.selector;
|
242
|
+
clonedAccessManager.setCoreTargetFunctionRole(
|
157
243
|
"Instance",
|
158
244
|
instancePolicyServiceSelectors,
|
159
245
|
POLICY_SERVICE_ROLE());
|
160
246
|
}
|
161
247
|
|
248
|
+
function _grantClaimServiceAuthorizations(InstanceAccessManager clonedAccessManager, Instance clonedInstance) internal {
|
249
|
+
// configure authorization for claim/payout services on instance
|
250
|
+
address claimServiceAddress = getRegistry().getServiceAddress(CLAIM(), getMajorVersion());
|
251
|
+
clonedAccessManager.grantRole(POLICY_SERVICE_ROLE(), claimServiceAddress);
|
252
|
+
// TODO add claims function authz
|
253
|
+
bytes4[] memory instanceClaimServiceSelectors = new bytes4[](0);
|
254
|
+
// instanceClaimServiceSelectors[0] = clonedInstance.updatePolicy.selector;
|
255
|
+
// instanceClaimServiceSelectors[1] = clonedInstance.updatePolicyState.selector;
|
256
|
+
clonedAccessManager.setCoreTargetFunctionRole(
|
257
|
+
"Instance",
|
258
|
+
instanceClaimServiceSelectors,
|
259
|
+
CLAIM_SERVICE_ROLE());
|
260
|
+
}
|
261
|
+
|
162
262
|
function _grantBundleServiceAuthorizations(InstanceAccessManager clonedAccessManager, Instance clonedInstance, BundleManager clonedBundleManager) internal {
|
163
263
|
// configure authorization for bundle service on instance
|
164
|
-
address bundleServiceAddress =
|
264
|
+
address bundleServiceAddress = getRegistry().getServiceAddress(BUNDLE(), getMajorVersion());
|
165
265
|
clonedAccessManager.grantRole(BUNDLE_SERVICE_ROLE(), address(bundleServiceAddress));
|
166
|
-
bytes4[] memory instanceBundleServiceSelectors = new bytes4[](
|
266
|
+
bytes4[] memory instanceBundleServiceSelectors = new bytes4[](3);
|
167
267
|
instanceBundleServiceSelectors[0] = clonedInstance.createBundle.selector;
|
168
268
|
instanceBundleServiceSelectors[1] = clonedInstance.updateBundle.selector;
|
169
|
-
|
269
|
+
instanceBundleServiceSelectors[2] = clonedInstance.updateBundleState.selector;
|
270
|
+
clonedAccessManager.setCoreTargetFunctionRole(
|
170
271
|
"Instance",
|
171
272
|
instanceBundleServiceSelectors,
|
172
273
|
BUNDLE_SERVICE_ROLE());
|
@@ -178,71 +279,115 @@ contract InstanceService is Service, IInstanceService {
|
|
178
279
|
bundleManagerBundleServiceSelectors[2] = clonedBundleManager.add.selector;
|
179
280
|
bundleManagerBundleServiceSelectors[3] = clonedBundleManager.lock.selector;
|
180
281
|
bundleManagerBundleServiceSelectors[4] = clonedBundleManager.unlock.selector;
|
181
|
-
clonedAccessManager.
|
282
|
+
clonedAccessManager.setCoreTargetFunctionRole(
|
182
283
|
"BundleManager",
|
183
284
|
bundleManagerBundleServiceSelectors,
|
184
285
|
BUNDLE_SERVICE_ROLE());
|
185
286
|
}
|
186
287
|
|
187
288
|
function _grantInstanceServiceAuthorizations(InstanceAccessManager clonedAccessManager, Instance clonedInstance) internal {
|
188
|
-
// configure authorization for instance service on instance
|
189
|
-
address instanceServiceAddress =
|
289
|
+
// configure authorization for instance service on instance
|
290
|
+
address instanceServiceAddress = getRegistry().getServiceAddress(INSTANCE(), getMajorVersion());
|
190
291
|
clonedAccessManager.grantRole(INSTANCE_SERVICE_ROLE(), instanceServiceAddress);
|
191
292
|
bytes4[] memory instanceInstanceServiceSelectors = new bytes4[](1);
|
192
293
|
instanceInstanceServiceSelectors[0] = clonedInstance.setInstanceReader.selector;
|
193
|
-
clonedAccessManager.
|
294
|
+
clonedAccessManager.setCoreTargetFunctionRole(
|
194
295
|
"Instance",
|
195
296
|
instanceInstanceServiceSelectors,
|
196
297
|
INSTANCE_SERVICE_ROLE());
|
197
|
-
}
|
198
298
|
|
199
|
-
|
200
|
-
|
201
|
-
|
202
|
-
|
299
|
+
// configure authorizations for instance service on instance access manager
|
300
|
+
bytes4[] memory accessManagerInstanceServiceSelectors = new bytes4[](3);
|
301
|
+
accessManagerInstanceServiceSelectors[0] = clonedAccessManager.createGifTarget.selector;
|
302
|
+
accessManagerInstanceServiceSelectors[1] = clonedAccessManager.setTargetLocked.selector;
|
303
|
+
accessManagerInstanceServiceSelectors[2] = clonedAccessManager.setCoreTargetFunctionRole.selector;
|
304
|
+
clonedAccessManager.setCoreTargetFunctionRole(
|
305
|
+
"InstanceAccessManager",
|
306
|
+
accessManagerInstanceServiceSelectors,
|
307
|
+
INSTANCE_SERVICE_ROLE());
|
308
|
+
}
|
203
309
|
|
204
|
-
|
205
|
-
|
206
|
-
|
207
|
-
|
310
|
+
function _grantInstanceOwnerAuthorizations(InstanceAccessManager clonedAccessManager, address instanceOwner) internal {
|
311
|
+
// configure authorization for instance owner on instance access manager
|
312
|
+
// instance owner role is granted/revoked ONLY by INSTANCE_ROLE
|
313
|
+
bytes4[] memory accessManagerInstanceOwnerSelectors = new bytes4[](3);
|
314
|
+
accessManagerInstanceOwnerSelectors[0] = clonedAccessManager.createRole.selector;
|
315
|
+
accessManagerInstanceOwnerSelectors[1] = clonedAccessManager.createTarget.selector;
|
316
|
+
accessManagerInstanceOwnerSelectors[2] = clonedAccessManager.setTargetFunctionRole.selector;
|
317
|
+
clonedAccessManager.setCoreTargetFunctionRole(
|
318
|
+
"InstanceAccessManager",
|
319
|
+
accessManagerInstanceOwnerSelectors,
|
320
|
+
INSTANCE_OWNER_ROLE());
|
321
|
+
}
|
208
322
|
|
209
|
-
Instance instance = Instance(instanceAddress);
|
210
|
-
InstanceReader instanceReader = InstanceReader(instanceReaderAddress);
|
211
|
-
BundleManager bundleManager = BundleManager(bundleManagerAddress);
|
212
323
|
|
213
|
-
|
214
|
-
|
215
|
-
|
324
|
+
function setAndRegisterMasterInstance(address instanceAddress)
|
325
|
+
external
|
326
|
+
onlyOwner
|
327
|
+
returns(NftId masterInstanceNftId)
|
328
|
+
{
|
329
|
+
if(_masterInstance != address(0)) { revert ErrorInstanceServiceMasterInstanceAlreadySet(); }
|
330
|
+
if(_masterOzAccessManager != address(0)) { revert ErrorInstanceServiceMasterOzAccessManagerAlreadySet(); }
|
331
|
+
if(_masterInstanceAccessManager != address(0)) { revert ErrorInstanceServiceMasterInstanceAccessManagerAlreadySet(); }
|
332
|
+
if(_masterInstanceBundleManager != address(0)) { revert ErrorInstanceServiceMasterBundleManagerAlreadySet(); }
|
333
|
+
|
334
|
+
if(instanceAddress == address(0)) { revert ErrorInstanceServiceInstanceAddressZero(); }
|
335
|
+
|
336
|
+
IInstance instance = IInstance(instanceAddress);
|
337
|
+
AccessManagerUpgradeableInitializeable ozAccessManager = AccessManagerUpgradeableInitializeable(instance.authority());
|
338
|
+
address ozAccessManagerAddress = address(ozAccessManager);
|
339
|
+
InstanceAccessManager instanceAccessManager = instance.getInstanceAccessManager();
|
340
|
+
address instanceAccessManagerAddress = address(instanceAccessManager);
|
341
|
+
InstanceReader instanceReader = instance.getInstanceReader();
|
342
|
+
address instanceReaderAddress = address(instanceReader);
|
343
|
+
BundleManager bundleManager = instance.getBundleManager();
|
344
|
+
address bundleManagerAddress = address(bundleManager);
|
345
|
+
|
346
|
+
if(ozAccessManagerAddress == address(0)) { revert ErrorInstanceServiceOzAccessManagerZero();}
|
347
|
+
if(instanceAccessManagerAddress == address(0)) { revert ErrorInstanceServiceInstanceAccessManagerZero(); }
|
348
|
+
if(instanceReaderAddress == address(0)) { revert ErrorInstanceServiceInstanceReaderZero(); }
|
349
|
+
if(bundleManagerAddress == address(0)) { revert ErrorInstanceServiceBundleManagerZero(); }
|
350
|
+
|
351
|
+
if(instance.authority() != instanceAccessManager.authority()) { revert ErrorInstanceServiceInstanceAuthorityMismatch(); }
|
352
|
+
if(bundleManager.authority() != instanceAccessManager.authority()) { revert ErrorInstanceServiceBundleManagerAuthorityMismatch(); }
|
353
|
+
if(instanceReader.getInstance() != instance) { revert ErrorInstanceServiceInstanceReaderInstanceMismatch2(); }
|
354
|
+
if(bundleManager.getInstance() != instance) { revert ErrorInstanceServiceBundleMangerInstanceMismatch(); }
|
216
355
|
|
217
|
-
|
356
|
+
_masterOzAccessManager = ozAccessManagerAddress;
|
357
|
+
_masterInstanceAccessManager = instanceAccessManagerAddress;
|
218
358
|
_masterInstance = instanceAddress;
|
219
359
|
_masterInstanceReader = instanceReaderAddress;
|
220
360
|
_masterInstanceBundleManager = bundleManagerAddress;
|
361
|
+
|
362
|
+
IRegistryService registryService = IRegistryService(getRegistry().getServiceAddress(REGISTRY(), getMajorVersion()));
|
363
|
+
IInstance masterInstance = IInstance(_masterInstance);
|
364
|
+
IRegistry.ObjectInfo memory info = registryService.registerInstance(masterInstance, getOwner());
|
365
|
+
masterInstanceNftId = info.nftId;
|
366
|
+
|
367
|
+
// masterInstance.linkToRegisteredNftId();
|
221
368
|
}
|
222
369
|
|
223
370
|
function setMasterInstanceReader(address instanceReaderAddress) external onlyOwner {
|
224
|
-
|
225
|
-
|
226
|
-
|
371
|
+
if(_masterInstanceReader == address(0)) { revert ErrorInstanceServiceMasterInstanceReaderNotSet(); }
|
372
|
+
if(instanceReaderAddress == address(0)) { revert ErrorInstanceServiceInstanceReaderAddressZero(); }
|
373
|
+
if(instanceReaderAddress == _masterInstanceReader) { revert ErrorInstanceServiceInstanceReaderSameAsMasterInstanceReader(); }
|
227
374
|
|
228
375
|
InstanceReader instanceReader = InstanceReader(instanceReaderAddress);
|
229
|
-
|
376
|
+
if(instanceReader.getInstance() != IInstance(_masterInstance)) { revert ErrorInstanceServiceInstanceReaderInstanceMismatch(); }
|
230
377
|
|
231
378
|
_masterInstanceReader = instanceReaderAddress;
|
232
379
|
}
|
233
380
|
|
234
|
-
function upgradeInstanceReader(NftId instanceNftId)
|
381
|
+
function upgradeInstanceReader(NftId instanceNftId)
|
382
|
+
external
|
383
|
+
onlyInstanceOwner(instanceNftId)
|
384
|
+
{
|
235
385
|
IRegistry registry = getRegistry();
|
236
386
|
IRegistry.ObjectInfo memory instanceInfo = registry.getObjectInfo(instanceNftId);
|
237
387
|
Instance instance = Instance(instanceInfo.objectAddress);
|
238
|
-
address owner = instance.getOwner();
|
239
|
-
|
240
|
-
if (msg.sender != owner) {
|
241
|
-
revert ErrorInstanceServiceRequestUnauhorized(msg.sender);
|
242
|
-
}
|
243
388
|
|
244
389
|
InstanceReader upgradedInstanceReaderClone = InstanceReader(Clones.clone(address(_masterInstanceReader)));
|
245
|
-
upgradedInstanceReaderClone.initialize(address(
|
390
|
+
upgradedInstanceReaderClone.initialize(address(instance));
|
246
391
|
instance.setInstanceReader(upgradedInstanceReaderClone);
|
247
392
|
}
|
248
393
|
|
@@ -268,10 +413,6 @@ contract InstanceService is Service, IInstanceService {
|
|
268
413
|
}
|
269
414
|
|
270
415
|
/// @dev top level initializer
|
271
|
-
// 1) registry is non upgradeable -> don't need a proxy and uses constructor !
|
272
|
-
// 2) deploy registry service first -> from its initialization func it is easier to deploy registry then vice versa
|
273
|
-
// 3) deploy registry -> pass registry service address as constructor argument
|
274
|
-
// registry is getting instantiated and locked to registry service address forever
|
275
416
|
function _initialize(
|
276
417
|
address owner,
|
277
418
|
bytes memory data
|
@@ -280,21 +421,75 @@ contract InstanceService is Service, IInstanceService {
|
|
280
421
|
initializer
|
281
422
|
virtual override
|
282
423
|
{
|
283
|
-
address initialOwner
|
284
|
-
address registryAddress
|
424
|
+
address initialOwner;
|
425
|
+
address registryAddress;
|
285
426
|
(registryAddress, initialOwner) = abi.decode(data, (address, address));
|
286
427
|
// TODO while InstanceService is not deployed in InstanceServiceManager constructor
|
287
428
|
// owner is InstanceServiceManager deployer
|
288
|
-
|
289
|
-
|
290
|
-
|
291
|
-
|
429
|
+
initializeService(registryAddress, owner);
|
430
|
+
registerInterface(type(IInstanceService).interfaceId);
|
431
|
+
}
|
432
|
+
|
433
|
+
// all gif targets MUST be childs of instanceNftId
|
434
|
+
function createGifTarget(
|
435
|
+
NftId instanceNftId,
|
436
|
+
address targetAddress,
|
437
|
+
string memory targetName,
|
438
|
+
bytes4[][] memory selectors,
|
439
|
+
RoleId[] memory roles
|
440
|
+
)
|
441
|
+
external
|
442
|
+
onlyRegisteredService
|
443
|
+
{
|
444
|
+
(
|
445
|
+
IInstance instance, // or instanceInfo
|
446
|
+
NftId targetNftId // or targetInfo
|
447
|
+
) = _validateInstanceAndComponent(instanceNftId, targetAddress);
|
448
|
+
|
449
|
+
InstanceAccessManager accessManager = instance.getInstanceAccessManager();
|
450
|
+
accessManager.createGifTarget(targetAddress, targetName);
|
451
|
+
// set proposed target config
|
452
|
+
// TODO restriction: for gif targets can set only once and only here?
|
453
|
+
// assume config is a mix of gif and custom roles and no further configuration by INSTANCE_OWNER_ROLE is ever needed?
|
454
|
+
for(uint roleIdx = 0; roleIdx < roles.length; roleIdx++)
|
455
|
+
{
|
456
|
+
accessManager.setCoreTargetFunctionRole(targetName, selectors[roleIdx], roles[roleIdx]);
|
457
|
+
}
|
292
458
|
}
|
293
459
|
|
294
|
-
|
295
|
-
|
460
|
+
// TODO called by component, but target can be component helper...so needs target name
|
461
|
+
// TODO check that targetName associated with component...how???
|
462
|
+
//function setTargetLocked(string memory targetName, bool locked) onlyComponent external {
|
463
|
+
function setComponentLocked(bool locked) onlyComponent external {
|
464
|
+
address componentAddress = msg.sender;
|
465
|
+
IRegistry registry = getRegistry();
|
466
|
+
NftId instanceNftId = registry.getObjectInfo(componentAddress).parentNftId;
|
467
|
+
address instanceAddress = registry.getObjectInfo(instanceNftId).objectAddress;
|
468
|
+
IInstance instance = IInstance(instanceAddress);
|
469
|
+
|
296
470
|
InstanceAccessManager accessManager = instance.getInstanceAccessManager();
|
297
|
-
|
471
|
+
// TODO setLocked by target address?
|
472
|
+
string memory componentName = ShortStrings.toString(accessManager.getTargetInfo(componentAddress).name);
|
473
|
+
accessManager.setTargetLocked(componentName, locked);
|
298
474
|
}
|
299
|
-
}
|
300
475
|
|
476
|
+
function _validateInstanceAndComponent(NftId instanceNftId, address componentAddress)
|
477
|
+
internal
|
478
|
+
view
|
479
|
+
returns (IInstance instance, NftId componentNftId)
|
480
|
+
{
|
481
|
+
IRegistry registry = getRegistry();
|
482
|
+
IRegistry.ObjectInfo memory instanceInfo = registry.getObjectInfo(instanceNftId);
|
483
|
+
if(instanceInfo.objectType != INSTANCE()) {
|
484
|
+
revert ErrorInstanceServiceNotInstance(instanceNftId);
|
485
|
+
}
|
486
|
+
|
487
|
+
IRegistry.ObjectInfo memory componentInfo = registry.getObjectInfo(componentAddress);
|
488
|
+
if(componentInfo.parentNftId != instanceNftId) {
|
489
|
+
revert ErrorInstanceServiceInstanceComponentMismatch(instanceNftId, componentInfo.nftId);
|
490
|
+
}
|
491
|
+
|
492
|
+
instance = Instance(instanceInfo.objectAddress);
|
493
|
+
componentNftId = componentInfo.nftId;
|
494
|
+
}
|
495
|
+
}
|