@etherisc/gif-next 0.0.2-a6faeb6-912 → 0.0.2-a733491-751
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 +853 -0
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/components/Distribution.sol/Distribution.json +887 -242
- package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +4 -0
- package/artifacts/contracts/components/{BaseComponent.sol/BaseComponent.json → IComponent.sol/IComponent.json} +160 -100
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +791 -0
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +655 -43
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +654 -5
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/components/Pool.sol/Pool.json +600 -217
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/components/Product.sol/Product.json +543 -152
- 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 +38 -62
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +908 -109
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +201 -167
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +814 -956
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +465 -184
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +61 -97
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +375 -369
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +295 -126
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +1 -1
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +8 -32
- 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} +180 -179
- 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 +2 -2
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +2 -2
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +65 -44
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
- 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 +858 -0
- package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.json +657 -0
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +1085 -0
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +661 -0
- package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.json +743 -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 +441 -214
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +317 -80
- 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} +200 -204
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.json +622 -0
- 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} +154 -124
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.json +197 -163
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.json +572 -0
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +24 -416
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.json +30 -417
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +1109 -0
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +717 -0
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +179 -504
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +294 -105
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +189 -570
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +286 -125
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +2 -2
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +244 -133
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +149 -217
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +257 -235
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +285 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +195 -322
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +298 -145
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +547 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +141 -53
- 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 +23 -186
- 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 +119 -173
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- 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/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 +140 -230
- 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/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/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/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 +2 -2
- 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 +2 -2
- 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/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +1 -1
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +1 -1
- package/contracts/components/Component.sol +241 -0
- package/contracts/components/Distribution.sol +209 -64
- package/contracts/components/IComponent.sol +54 -0
- package/contracts/components/IDistributionComponent.sol +59 -3
- package/contracts/components/IPoolComponent.sol +50 -29
- package/contracts/components/IProductComponent.sol +7 -3
- package/contracts/components/Pool.sol +136 -149
- package/contracts/components/Product.sol +115 -119
- package/contracts/instance/AccessManagerUpgradeableInitializeable.sol +2 -12
- package/contracts/instance/BundleManager.sol +7 -11
- package/contracts/instance/IInstance.sol +48 -10
- package/contracts/instance/IInstanceService.sol +35 -4
- package/contracts/instance/Instance.sol +102 -260
- package/contracts/instance/InstanceAccessManager.sol +463 -171
- package/contracts/instance/InstanceReader.sol +3 -25
- package/contracts/instance/InstanceService.sol +328 -114
- package/contracts/instance/InstanceServiceManager.sol +6 -9
- package/contracts/instance/ObjectManager.sol +7 -24
- package/contracts/instance/base/ComponentService.sol +134 -0
- package/contracts/instance/module/IAccess.sol +36 -20
- package/contracts/instance/module/IPolicy.sol +4 -2
- package/contracts/instance/module/ISetup.sol +5 -4
- package/contracts/instance/service/ApplicationService.sol +268 -0
- package/contracts/instance/service/ApplicationServiceManager.sol +35 -0
- package/contracts/instance/service/BundleService.sol +298 -0
- package/contracts/instance/service/BundleServiceManager.sol +51 -0
- package/contracts/instance/service/ClaimService.sol +151 -0
- package/contracts/instance/service/ClaimServiceManager.sol +35 -0
- package/contracts/instance/service/DistributionService.sol +235 -28
- package/contracts/instance/service/DistributionServiceManager.sol +7 -10
- package/contracts/instance/service/IApplicationService.sol +82 -0
- package/contracts/instance/service/IBundleService.sol +54 -0
- package/contracts/instance/service/IClaimService.sol +61 -0
- package/contracts/instance/service/IDistributionService.sol +53 -0
- package/contracts/instance/service/IPolicyService.sol +89 -0
- package/contracts/instance/service/IPoolService.sol +2 -33
- package/contracts/instance/service/IProductService.sol +2 -72
- package/contracts/instance/service/PolicyService.sol +474 -0
- package/contracts/instance/service/PolicyServiceManager.sol +54 -0
- package/contracts/instance/service/PoolService.sol +51 -213
- package/contracts/instance/service/PoolServiceManager.sol +6 -9
- package/contracts/instance/service/ProductService.sol +131 -460
- package/contracts/instance/service/ProductServiceManager.sol +2 -2
- package/contracts/registry/ChainNft.sol +1 -1
- package/contracts/registry/IRegistry.sol +39 -19
- package/contracts/registry/IRegistryService.sol +30 -13
- package/contracts/registry/Registry.sol +246 -225
- package/contracts/registry/RegistryAccessManager.sol +216 -0
- package/contracts/registry/RegistryService.sol +96 -171
- package/contracts/registry/RegistryServiceManager.sol +21 -39
- package/contracts/registry/ReleaseManager.sol +322 -0
- package/contracts/registry/TokenRegistry.sol +22 -17
- 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 -1
- 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 +14 -30
- package/contracts/shared/RegistryLinked.sol +48 -0
- package/contracts/shared/Service.sol +25 -22
- package/contracts/shared/Versionable.sol +4 -92
- package/contracts/test/TestRegisterable.sol +1 -1
- package/contracts/test/TestService.sol +4 -3
- package/contracts/types/ClaimId.sol +52 -0
- package/contracts/types/DistributorType.sol +2 -2
- package/contracts/types/ObjectType.sol +9 -5
- package/contracts/types/PayoutId.sol +54 -0
- package/contracts/types/RoleId.sol +22 -19
- 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/IAccessManagerSimple.sol/IAccessManagerSimple.dbg.json +0 -4
- package/artifacts/contracts/instance/IAccessManagerSimple.sol/IAccessManagerSimple.json +0 -1082
- 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 -827
- 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 -132
- package/contracts/components/IBaseComponent.sol +0 -31
- 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/IAccessManagerSimple.sol +0 -391
- package/contracts/instance/IInstanceBase.sol +0 -26
- 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/IComponentOwnerService.sol +0 -20
- package/contracts/shared/RegisterableUpgradable.sol +0 -16
@@ -31,39 +31,21 @@ contract InstanceReader {
|
|
31
31
|
bool private _initialized;
|
32
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 registry, address instance) public {
|
47
38
|
require(!_initialized, "ERROR:CRD-000:ALREADY_INITIALIZED");
|
48
39
|
|
49
40
|
require(
|
50
41
|
address(registry) != address(0),
|
51
42
|
"ERROR:CRD-001:REGISTRY_ZERO");
|
52
43
|
|
53
|
-
require(
|
54
|
-
instanceNftId.gtz(),
|
55
|
-
"ERROR:CRD-002:NFT_ID_ZERO");
|
56
44
|
|
57
45
|
_registry = IRegistry(registry);
|
58
|
-
_instanceNftId = instanceNftId;
|
59
|
-
IRegistry.ObjectInfo memory instanceInfo = _registry.getObjectInfo(_instanceNftId);
|
60
46
|
|
61
|
-
|
62
|
-
|
63
|
-
"ERROR:CRD-003:PARENT_NOT_INSTANCE");
|
64
|
-
|
65
|
-
_instance = IInstance(instanceInfo.objectAddress);
|
66
|
-
_store = IKeyValueStore(instanceInfo.objectAddress);
|
47
|
+
_instance = IInstance(instance);
|
48
|
+
_store = IKeyValueStore(instance);
|
67
49
|
|
68
50
|
_initialized = true;
|
69
51
|
}
|
@@ -301,10 +283,6 @@ contract InstanceReader {
|
|
301
283
|
return _store;
|
302
284
|
}
|
303
285
|
|
304
|
-
function getInstanceNftId() external view returns (NftId nftId) {
|
305
|
-
return _instanceNftId;
|
306
|
-
}
|
307
|
-
|
308
286
|
function toUFixed(uint256 value, int8 exp) public pure returns (UFixed) {
|
309
287
|
return UFixedLib.toUFixed(value, exp);
|
310
288
|
}
|
@@ -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 {
|
5
|
+
import {ShortString, ShortStrings} from "@openzeppelin/contracts/utils/ShortStrings.sol";
|
6
6
|
|
7
|
-
import {AccessManagerUpgradeableInitializeable} from "./AccessManagerUpgradeableInitializeable.sol";
|
8
7
|
import {Instance} from "./Instance.sol";
|
8
|
+
import {IInstance} from "./IInstance.sol";
|
9
|
+
import {InstanceAccessManager} from "./InstanceAccessManager.sol";
|
9
10
|
import {IInstanceService} from "./IInstanceService.sol";
|
10
11
|
import {InstanceReader} from "./InstanceReader.sol";
|
11
12
|
import {BundleManager} from "./BundleManager.sol";
|
13
|
+
import {AccessManagerUpgradeableInitializeable} from "./AccessManagerUpgradeableInitializeable.sol";
|
12
14
|
import {IRegistry} from "../registry/IRegistry.sol";
|
13
|
-
import {
|
15
|
+
import {IRegistryService} from "../registry/IRegistryService.sol";
|
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 {
|
19
|
-
import {
|
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} 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,12 +36,34 @@ 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
|
-
|
39
|
+
|
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);
|
58
|
+
}
|
59
|
+
_;
|
60
|
+
}
|
31
61
|
|
32
62
|
function createInstanceClone()
|
33
63
|
external
|
34
64
|
returns (
|
35
|
-
AccessManagerUpgradeableInitializeable
|
65
|
+
AccessManagerUpgradeableInitializeable clonedOzAccessManager,
|
66
|
+
InstanceAccessManager clonedInstanceAccessManager,
|
36
67
|
Instance clonedInstance,
|
37
68
|
NftId clonedInstanceNftId,
|
38
69
|
InstanceReader clonedInstanceReader,
|
@@ -43,153 +74,312 @@ contract InstanceService is Service, IInstanceService {
|
|
43
74
|
IRegistry registry = getRegistry();
|
44
75
|
address registryAddress = address(registry);
|
45
76
|
NftId registryNftId = registry.getNftId(registryAddress);
|
46
|
-
address registryServiceAddress = registry.getServiceAddress(
|
47
|
-
|
77
|
+
address registryServiceAddress = registry.getServiceAddress(REGISTRY(), getMajorVersion());
|
78
|
+
IRegistryService registryService = IRegistryService(registryServiceAddress);
|
48
79
|
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
80
|
+
clonedOzAccessManager = AccessManagerUpgradeableInitializeable(
|
81
|
+
Clones.clone(_masterOzAccessManager));
|
82
|
+
|
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));
|
88
|
+
|
89
|
+
clonedInstanceAccessManager = InstanceAccessManager(Clones.clone(_masterInstanceAccessManager));
|
90
|
+
clonedOzAccessManager.grantRole(ADMIN_ROLE().toInt(), address(clonedInstanceAccessManager), 0);
|
91
|
+
clonedInstanceAccessManager.initialize(address(clonedOzAccessManager), registryAddress);
|
54
92
|
|
55
93
|
clonedInstance = Instance(Clones.clone(_masterInstance));
|
56
|
-
clonedInstance.initialize(address(
|
57
|
-
( IRegistry.ObjectInfo memory info, ) = registryService.registerInstance(clonedInstance);
|
58
|
-
clonedInstanceNftId = info.nftId;
|
94
|
+
clonedInstance.initialize(address(clonedInstanceAccessManager), registryAddress, registryNftId, instanceOwner);
|
59
95
|
|
60
96
|
clonedInstanceReader = InstanceReader(Clones.clone(address(_masterInstanceReader)));
|
61
|
-
clonedInstanceReader.initialize(registryAddress,
|
97
|
+
clonedInstanceReader.initialize(registryAddress, address(clonedInstance));
|
62
98
|
clonedInstance.setInstanceReader(clonedInstanceReader);
|
63
99
|
|
64
100
|
clonedBundleManager = BundleManager(Clones.clone(_masterInstanceBundleManager));
|
65
|
-
clonedBundleManager.initialize(
|
101
|
+
clonedBundleManager.initialize(clonedInstanceAccessManager.authority(), registryAddress, address(clonedInstance));
|
66
102
|
clonedInstance.setBundleManager(clonedBundleManager);
|
67
103
|
|
68
104
|
// TODO amend setters with instance specific , policy manager ...
|
69
105
|
|
70
|
-
_grantInitialAuthorizations(
|
106
|
+
_grantInitialAuthorizations(clonedInstanceAccessManager, clonedInstance, clonedBundleManager, instanceOwner);
|
107
|
+
|
108
|
+
clonedOzAccessManager.renounceRole(ADMIN_ROLE().toInt(), address(this));
|
71
109
|
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
clonedAccessManager.revokeRole(ADMIN_ROLE().toInt(), address(this));
|
110
|
+
IRegistry.ObjectInfo memory info = registryService.registerInstance(clonedInstance, instanceOwner);
|
111
|
+
clonedInstanceNftId = info.nftId;
|
112
|
+
// clonedInstance.linkToRegisteredNftId();
|
76
113
|
|
77
|
-
emit LogInstanceCloned(address(
|
114
|
+
emit LogInstanceCloned(address(clonedOzAccessManager), address(clonedInstanceAccessManager), address(clonedInstance), address(clonedInstanceReader), clonedInstanceNftId);
|
78
115
|
}
|
79
116
|
|
80
|
-
function _grantInitialAuthorizations(
|
117
|
+
function _grantInitialAuthorizations(
|
118
|
+
InstanceAccessManager clonedAccessManager,
|
119
|
+
Instance clonedInstance,
|
120
|
+
BundleManager clonedBundleManager,
|
121
|
+
address instanceOwner)
|
122
|
+
internal
|
123
|
+
{
|
124
|
+
_createCoreAndGifRoles(clonedAccessManager);
|
125
|
+
_createCoreTargets(clonedAccessManager, clonedInstance, clonedBundleManager);
|
126
|
+
_grantDistributionServiceAuthorizations(clonedAccessManager, clonedInstance);
|
127
|
+
_grantPoolServiceAuthorizations(clonedAccessManager, clonedInstance);
|
128
|
+
_grantProductServiceAuthorizations(clonedAccessManager, clonedInstance);
|
129
|
+
_grantApplicationServiceAuthorizations(clonedAccessManager, clonedInstance);
|
130
|
+
_grantPolicyServiceAuthorizations(clonedAccessManager, clonedInstance);
|
131
|
+
_grantClaimServiceAuthorizations(clonedAccessManager, clonedInstance);
|
132
|
+
_grantBundleServiceAuthorizations(clonedAccessManager, clonedInstance, clonedBundleManager);
|
133
|
+
_grantInstanceServiceAuthorizations(clonedAccessManager, clonedInstance);
|
134
|
+
_grantInstanceOwnerAuthorizations(clonedAccessManager, instanceOwner);
|
135
|
+
}
|
136
|
+
|
137
|
+
function _createCoreAndGifRoles(InstanceAccessManager clonedAccessManager) internal {
|
138
|
+
// default roles controlled by INSTANCE_OWNER_ROLE -> gif roles
|
139
|
+
clonedAccessManager.createGifRole(INSTANCE_OWNER_ROLE(), "InstanceOwnerRole", ADMIN_ROLE());
|
140
|
+
clonedAccessManager.createGifRole(DISTRIBUTION_OWNER_ROLE(), "DistributionOwnerRole", INSTANCE_OWNER_ROLE());
|
141
|
+
clonedAccessManager.createGifRole(POOL_OWNER_ROLE(), "PoolOwnerRole", INSTANCE_OWNER_ROLE());
|
142
|
+
clonedAccessManager.createGifRole(PRODUCT_OWNER_ROLE(), "ProductOwnerRole", INSTANCE_OWNER_ROLE());
|
143
|
+
// default roles controlled by ADMIN_ROLE -> core roles, all set/granted only once during cloning
|
144
|
+
clonedAccessManager.createCoreRole(INSTANCE_SERVICE_ROLE(), "InstanceServiceRole");
|
145
|
+
clonedAccessManager.createCoreRole(DISTRIBUTION_SERVICE_ROLE(), "DistributionServiceRole");
|
146
|
+
clonedAccessManager.createCoreRole(POOL_SERVICE_ROLE(), "PoolServiceRole");
|
147
|
+
clonedAccessManager.createCoreRole(APPLICATION_SERVICE_ROLE(), "ApplicationServiceRole");
|
148
|
+
clonedAccessManager.createCoreRole(PRODUCT_SERVICE_ROLE(), "ProductServiceRole");
|
149
|
+
clonedAccessManager.createCoreRole(CLAIM_SERVICE_ROLE(), "ClaimServiceRole");
|
150
|
+
clonedAccessManager.createCoreRole(POLICY_SERVICE_ROLE(), "PolicyServiceRole");
|
151
|
+
clonedAccessManager.createCoreRole(BUNDLE_SERVICE_ROLE(), "BundleServiceRole");
|
152
|
+
}
|
153
|
+
|
154
|
+
function _createCoreTargets(InstanceAccessManager clonedAccessManager, Instance clonedInstance, BundleManager clonedBundleManager) internal {
|
155
|
+
clonedAccessManager.createCoreTarget(address(clonedAccessManager), "InstanceAccessManager");
|
156
|
+
clonedAccessManager.createCoreTarget(address(clonedInstance), "Instance");
|
157
|
+
clonedAccessManager.createCoreTarget(address(clonedBundleManager), "BundleManager");
|
158
|
+
}
|
159
|
+
|
160
|
+
function _grantDistributionServiceAuthorizations(InstanceAccessManager clonedAccessManager, Instance clonedInstance) internal {
|
81
161
|
// configure authorization for distribution service on instance
|
82
162
|
IRegistry registry = getRegistry();
|
83
|
-
address distributionServiceAddress = registry.getServiceAddress(
|
84
|
-
clonedAccessManager.grantRole(DISTRIBUTION_SERVICE_ROLE()
|
85
|
-
bytes4[] memory instanceDistributionServiceSelectors = new bytes4[](
|
163
|
+
address distributionServiceAddress = registry.getServiceAddress(DISTRIBUTION(), getMajorVersion());
|
164
|
+
clonedAccessManager.grantRole(DISTRIBUTION_SERVICE_ROLE(), distributionServiceAddress);
|
165
|
+
bytes4[] memory instanceDistributionServiceSelectors = new bytes4[](11);
|
86
166
|
instanceDistributionServiceSelectors[0] = clonedInstance.createDistributionSetup.selector;
|
87
167
|
instanceDistributionServiceSelectors[1] = clonedInstance.updateDistributionSetup.selector;
|
168
|
+
instanceDistributionServiceSelectors[2] = clonedInstance.createDistributorType.selector;
|
169
|
+
instanceDistributionServiceSelectors[3] = clonedInstance.updateDistributorType.selector;
|
170
|
+
instanceDistributionServiceSelectors[4] = clonedInstance.updateDistributorTypeState.selector;
|
171
|
+
instanceDistributionServiceSelectors[5] = clonedInstance.createDistributor.selector;
|
172
|
+
instanceDistributionServiceSelectors[6] = clonedInstance.updateDistributor.selector;
|
173
|
+
instanceDistributionServiceSelectors[7] = clonedInstance.updateDistributorState.selector;
|
174
|
+
instanceDistributionServiceSelectors[8] = clonedInstance.createReferral.selector;
|
175
|
+
instanceDistributionServiceSelectors[9] = clonedInstance.updateReferral.selector;
|
176
|
+
instanceDistributionServiceSelectors[10] = clonedInstance.updateReferralState.selector;
|
88
177
|
clonedAccessManager.setTargetFunctionRole(
|
89
|
-
|
178
|
+
"Instance",
|
90
179
|
instanceDistributionServiceSelectors,
|
91
|
-
DISTRIBUTION_SERVICE_ROLE()
|
180
|
+
DISTRIBUTION_SERVICE_ROLE());
|
181
|
+
}
|
92
182
|
|
183
|
+
function _grantPoolServiceAuthorizations(InstanceAccessManager clonedAccessManager, Instance clonedInstance) internal {
|
93
184
|
// configure authorization for pool service on instance
|
94
|
-
address poolServiceAddress =
|
95
|
-
clonedAccessManager.grantRole(POOL_SERVICE_ROLE()
|
185
|
+
address poolServiceAddress = getRegistry().getServiceAddress(POOL(), getMajorVersion());
|
186
|
+
clonedAccessManager.grantRole(POOL_SERVICE_ROLE(), address(poolServiceAddress));
|
96
187
|
bytes4[] memory instancePoolServiceSelectors = new bytes4[](4);
|
97
188
|
instancePoolServiceSelectors[0] = clonedInstance.createPoolSetup.selector;
|
98
189
|
instancePoolServiceSelectors[1] = clonedInstance.updatePoolSetup.selector;
|
99
|
-
instancePoolServiceSelectors[2] = clonedInstance.createBundle.selector;
|
100
|
-
instancePoolServiceSelectors[3] = clonedInstance.updateBundle.selector;
|
101
190
|
clonedAccessManager.setTargetFunctionRole(
|
102
|
-
|
191
|
+
"Instance",
|
103
192
|
instancePoolServiceSelectors,
|
104
|
-
POOL_SERVICE_ROLE()
|
105
|
-
|
106
|
-
// configure authorization for pool service on bundle manager
|
107
|
-
bytes4[] memory bundleManagerPoolServiceSelectors = new bytes4[](5);
|
108
|
-
bundleManagerPoolServiceSelectors[0] = clonedBundleManager.linkPolicy.selector;
|
109
|
-
bundleManagerPoolServiceSelectors[1] = clonedBundleManager.unlinkPolicy.selector;
|
110
|
-
bundleManagerPoolServiceSelectors[2] = clonedBundleManager.add.selector;
|
111
|
-
bundleManagerPoolServiceSelectors[3] = clonedBundleManager.lock.selector;
|
112
|
-
bundleManagerPoolServiceSelectors[4] = clonedBundleManager.unlock.selector;
|
113
|
-
clonedAccessManager.setTargetFunctionRole(
|
114
|
-
address(clonedBundleManager),
|
115
|
-
bundleManagerPoolServiceSelectors,
|
116
|
-
POOL_SERVICE_ROLE().toInt());
|
193
|
+
POOL_SERVICE_ROLE());
|
194
|
+
}
|
117
195
|
|
196
|
+
function _grantProductServiceAuthorizations(InstanceAccessManager clonedAccessManager, Instance clonedInstance) internal {
|
118
197
|
// configure authorization for product service on instance
|
119
|
-
address productServiceAddress =
|
120
|
-
clonedAccessManager.grantRole(PRODUCT_SERVICE_ROLE()
|
121
|
-
bytes4[] memory instanceProductServiceSelectors = new bytes4[](
|
198
|
+
address productServiceAddress = getRegistry().getServiceAddress(PRODUCT(), getMajorVersion());
|
199
|
+
clonedAccessManager.grantRole(PRODUCT_SERVICE_ROLE(), address(productServiceAddress));
|
200
|
+
bytes4[] memory instanceProductServiceSelectors = new bytes4[](5);
|
122
201
|
instanceProductServiceSelectors[0] = clonedInstance.createProductSetup.selector;
|
123
202
|
instanceProductServiceSelectors[1] = clonedInstance.updateProductSetup.selector;
|
124
203
|
instanceProductServiceSelectors[2] = clonedInstance.createRisk.selector;
|
125
204
|
instanceProductServiceSelectors[3] = clonedInstance.updateRisk.selector;
|
126
205
|
instanceProductServiceSelectors[4] = clonedInstance.updateRiskState.selector;
|
127
|
-
instanceProductServiceSelectors[5] = clonedInstance.createPolicy.selector;
|
128
|
-
instanceProductServiceSelectors[6] = clonedInstance.updatePolicy.selector;
|
129
|
-
instanceProductServiceSelectors[7] = clonedInstance.updatePolicyState.selector;
|
130
206
|
clonedAccessManager.setTargetFunctionRole(
|
131
|
-
|
207
|
+
"Instance",
|
132
208
|
instanceProductServiceSelectors,
|
133
|
-
PRODUCT_SERVICE_ROLE()
|
209
|
+
PRODUCT_SERVICE_ROLE());
|
210
|
+
}
|
211
|
+
|
212
|
+
function _grantApplicationServiceAuthorizations(InstanceAccessManager clonedAccessManager, Instance clonedInstance) internal {
|
213
|
+
// configure authorization for application services on instance
|
214
|
+
address applicationServiceAddress = getRegistry().getServiceAddress(APPLICATION(), getMajorVersion());
|
215
|
+
clonedAccessManager.grantRole(APPLICATION_SERVICE_ROLE(), applicationServiceAddress);
|
216
|
+
bytes4[] memory instanceApplicationServiceSelectors = new bytes4[](3);
|
217
|
+
instanceApplicationServiceSelectors[0] = clonedInstance.createApplication.selector;
|
218
|
+
instanceApplicationServiceSelectors[1] = clonedInstance.updateApplication.selector;
|
219
|
+
instanceApplicationServiceSelectors[2] = clonedInstance.updateApplicationState.selector;
|
220
|
+
clonedAccessManager.setTargetFunctionRole(
|
221
|
+
"Instance",
|
222
|
+
instanceApplicationServiceSelectors,
|
223
|
+
APPLICATION_SERVICE_ROLE());
|
224
|
+
}
|
225
|
+
|
226
|
+
function _grantPolicyServiceAuthorizations(InstanceAccessManager clonedAccessManager, Instance clonedInstance) internal {
|
227
|
+
// configure authorization for policy services on instance
|
228
|
+
address policyServiceAddress = getRegistry().getServiceAddress(POLICY(), getMajorVersion());
|
229
|
+
clonedAccessManager.grantRole(POLICY_SERVICE_ROLE(), policyServiceAddress);
|
230
|
+
bytes4[] memory instancePolicyServiceSelectors = new bytes4[](2);
|
231
|
+
instancePolicyServiceSelectors[0] = clonedInstance.updatePolicy.selector;
|
232
|
+
instancePolicyServiceSelectors[1] = clonedInstance.updatePolicyState.selector;
|
233
|
+
clonedAccessManager.setTargetFunctionRole(
|
234
|
+
"Instance",
|
235
|
+
instancePolicyServiceSelectors,
|
236
|
+
POLICY_SERVICE_ROLE());
|
237
|
+
}
|
134
238
|
|
239
|
+
function _grantClaimServiceAuthorizations(InstanceAccessManager clonedAccessManager, Instance clonedInstance) internal {
|
240
|
+
// configure authorization for claim/payout services on instance
|
241
|
+
address claimServiceAddress = getRegistry().getServiceAddress(CLAIM(), getMajorVersion());
|
242
|
+
clonedAccessManager.grantRole(POLICY_SERVICE_ROLE(), claimServiceAddress);
|
243
|
+
// TODO add claims function authz
|
244
|
+
bytes4[] memory instanceClaimServiceSelectors = new bytes4[](0);
|
245
|
+
// instanceClaimServiceSelectors[0] = clonedInstance.updatePolicy.selector;
|
246
|
+
// instanceClaimServiceSelectors[1] = clonedInstance.updatePolicyState.selector;
|
247
|
+
clonedAccessManager.setTargetFunctionRole(
|
248
|
+
"Instance",
|
249
|
+
instanceClaimServiceSelectors,
|
250
|
+
CLAIM_SERVICE_ROLE());
|
251
|
+
}
|
252
|
+
|
253
|
+
function _grantBundleServiceAuthorizations(InstanceAccessManager clonedAccessManager, Instance clonedInstance, BundleManager clonedBundleManager) internal {
|
254
|
+
// configure authorization for bundle service on instance
|
255
|
+
address bundleServiceAddress = getRegistry().getServiceAddress(BUNDLE(), getMajorVersion());
|
256
|
+
clonedAccessManager.grantRole(BUNDLE_SERVICE_ROLE(), address(bundleServiceAddress));
|
257
|
+
bytes4[] memory instanceBundleServiceSelectors = new bytes4[](2);
|
258
|
+
instanceBundleServiceSelectors[0] = clonedInstance.createBundle.selector;
|
259
|
+
instanceBundleServiceSelectors[1] = clonedInstance.updateBundle.selector;
|
260
|
+
clonedAccessManager.setTargetFunctionRole(
|
261
|
+
"Instance",
|
262
|
+
instanceBundleServiceSelectors,
|
263
|
+
BUNDLE_SERVICE_ROLE());
|
264
|
+
|
265
|
+
// configure authorization for bundle service on bundle manager
|
266
|
+
bytes4[] memory bundleManagerBundleServiceSelectors = new bytes4[](5);
|
267
|
+
bundleManagerBundleServiceSelectors[0] = clonedBundleManager.linkPolicy.selector;
|
268
|
+
bundleManagerBundleServiceSelectors[1] = clonedBundleManager.unlinkPolicy.selector;
|
269
|
+
bundleManagerBundleServiceSelectors[2] = clonedBundleManager.add.selector;
|
270
|
+
bundleManagerBundleServiceSelectors[3] = clonedBundleManager.lock.selector;
|
271
|
+
bundleManagerBundleServiceSelectors[4] = clonedBundleManager.unlock.selector;
|
272
|
+
clonedAccessManager.setTargetFunctionRole(
|
273
|
+
"BundleManager",
|
274
|
+
bundleManagerBundleServiceSelectors,
|
275
|
+
BUNDLE_SERVICE_ROLE());
|
276
|
+
}
|
277
|
+
|
278
|
+
function _grantInstanceServiceAuthorizations(InstanceAccessManager clonedAccessManager, Instance clonedInstance) internal {
|
135
279
|
// configure authorization for instance service on instance
|
136
|
-
address instanceServiceAddress =
|
137
|
-
clonedAccessManager.grantRole(INSTANCE_SERVICE_ROLE()
|
280
|
+
address instanceServiceAddress = getRegistry().getServiceAddress(INSTANCE(), getMajorVersion());
|
281
|
+
clonedAccessManager.grantRole(INSTANCE_SERVICE_ROLE(), instanceServiceAddress);
|
138
282
|
bytes4[] memory instanceInstanceServiceSelectors = new bytes4[](1);
|
139
283
|
instanceInstanceServiceSelectors[0] = clonedInstance.setInstanceReader.selector;
|
140
284
|
clonedAccessManager.setTargetFunctionRole(
|
141
|
-
|
285
|
+
"Instance",
|
142
286
|
instanceInstanceServiceSelectors,
|
143
|
-
INSTANCE_SERVICE_ROLE()
|
287
|
+
INSTANCE_SERVICE_ROLE());
|
288
|
+
|
289
|
+
// configure authorizations for instance service on instance access manager
|
290
|
+
bytes4[] memory accessManagerInstanceServiceSelectors = new bytes4[](4);
|
291
|
+
accessManagerInstanceServiceSelectors[0] = clonedAccessManager.createCoreTarget.selector;
|
292
|
+
accessManagerInstanceServiceSelectors[1] = clonedAccessManager.createGifTarget.selector;
|
293
|
+
accessManagerInstanceServiceSelectors[2] = clonedAccessManager.setTargetLocked.selector;
|
294
|
+
accessManagerInstanceServiceSelectors[3] = clonedAccessManager.setTargetFunctionRole.selector;
|
295
|
+
clonedAccessManager.setTargetFunctionRole(
|
296
|
+
"InstanceAccessManager",
|
297
|
+
accessManagerInstanceServiceSelectors,
|
298
|
+
INSTANCE_SERVICE_ROLE());
|
144
299
|
}
|
145
300
|
|
146
|
-
function
|
147
|
-
|
148
|
-
|
149
|
-
|
150
|
-
|
151
|
-
|
152
|
-
|
153
|
-
|
154
|
-
|
155
|
-
|
156
|
-
|
157
|
-
|
158
|
-
|
301
|
+
function _grantInstanceOwnerAuthorizations(InstanceAccessManager clonedAccessManager, address instanceOwner) internal {
|
302
|
+
// configure authorization for instance owner on instance access manager
|
303
|
+
clonedAccessManager.grantRole(INSTANCE_OWNER_ROLE(), instanceOwner);
|
304
|
+
// INSTANCE_OWNER_ROLE administrates itself
|
305
|
+
clonedAccessManager.setRoleAdmin(INSTANCE_OWNER_ROLE(), INSTANCE_OWNER_ROLE());
|
306
|
+
bytes4[] memory accessManagerInstanceOwnerSelectors = new bytes4[](3);
|
307
|
+
accessManagerInstanceOwnerSelectors[0] = clonedAccessManager.createCustomRole.selector;
|
308
|
+
accessManagerInstanceOwnerSelectors[1] = clonedAccessManager.createCustomTarget.selector;
|
309
|
+
accessManagerInstanceOwnerSelectors[2] = clonedAccessManager.setTargetFunctionCustomRole.selector;
|
310
|
+
clonedAccessManager.setTargetFunctionRole(
|
311
|
+
"InstanceAccessManager",
|
312
|
+
accessManagerInstanceOwnerSelectors,
|
313
|
+
INSTANCE_OWNER_ROLE());
|
314
|
+
}
|
159
315
|
|
160
|
-
|
161
|
-
|
162
|
-
|
316
|
+
function setAndRegisterMasterInstance(address instanceAddress)
|
317
|
+
external
|
318
|
+
onlyOwner
|
319
|
+
returns(NftId masterInstanceNftId)
|
320
|
+
{
|
321
|
+
if(_masterInstance != address(0)) { revert ErrorInstanceServiceMasterInstanceAlreadySet(); }
|
322
|
+
if(_masterOzAccessManager != address(0)) { revert ErrorInstanceServiceMasterOzAccessManagerAlreadySet(); }
|
323
|
+
if(_masterInstanceAccessManager != address(0)) { revert ErrorInstanceServiceMasterInstanceAccessManagerAlreadySet(); }
|
324
|
+
if(_masterInstanceBundleManager != address(0)) { revert ErrorInstanceServiceMasterBundleManagerAlreadySet(); }
|
325
|
+
|
326
|
+
if(instanceAddress == address(0)) { revert ErrorInstanceServiceInstanceAddressZero(); }
|
327
|
+
|
328
|
+
IInstance instance = IInstance(instanceAddress);
|
329
|
+
AccessManagerUpgradeableInitializeable ozAccessManager = AccessManagerUpgradeableInitializeable(instance.authority());
|
330
|
+
address ozAccessManagerAddress = address(ozAccessManager);
|
331
|
+
InstanceAccessManager instanceAccessManager = instance.getInstanceAccessManager();
|
332
|
+
address instanceAccessManagerAddress = address(instanceAccessManager);
|
333
|
+
InstanceReader instanceReader = instance.getInstanceReader();
|
334
|
+
address instanceReaderAddress = address(instanceReader);
|
335
|
+
BundleManager bundleManager = instance.getBundleManager();
|
336
|
+
address bundleManagerAddress = address(bundleManager);
|
337
|
+
|
338
|
+
if(ozAccessManagerAddress == address(0)) { revert ErrorInstanceServiceOzAccessManagerZero();}
|
339
|
+
if(instanceAccessManagerAddress == address(0)) { revert ErrorInstanceServiceInstanceAccessManagerZero(); }
|
340
|
+
if(instanceReaderAddress == address(0)) { revert ErrorInstanceServiceInstanceReaderZero(); }
|
341
|
+
if(bundleManagerAddress == address(0)) { revert ErrorInstanceServiceBundleManagerZero(); }
|
342
|
+
|
343
|
+
if(instance.authority() != instanceAccessManager.authority()) { revert ErrorInstanceServiceInstanceAuthorityMismatch(); }
|
344
|
+
if(bundleManager.authority() != instanceAccessManager.authority()) { revert ErrorInstanceServiceBundleManagerAuthorityMismatch(); }
|
345
|
+
if(instanceReader.getInstance() != instance) { revert ErrorInstanceServiceInstanceReaderInstanceMismatch2(); }
|
346
|
+
if(bundleManager.getInstance() != instance) { revert ErrorInstanceServiceBundleMangerInstanceMismatch(); }
|
163
347
|
|
164
|
-
|
348
|
+
_masterOzAccessManager = ozAccessManagerAddress;
|
349
|
+
_masterInstanceAccessManager = instanceAccessManagerAddress;
|
165
350
|
_masterInstance = instanceAddress;
|
166
351
|
_masterInstanceReader = instanceReaderAddress;
|
167
352
|
_masterInstanceBundleManager = bundleManagerAddress;
|
353
|
+
|
354
|
+
IRegistryService registryService = IRegistryService(getRegistry().getServiceAddress(REGISTRY(), getMajorVersion()));
|
355
|
+
IInstance masterInstance = IInstance(_masterInstance);
|
356
|
+
IRegistry.ObjectInfo memory info = registryService.registerInstance(masterInstance, getOwner());
|
357
|
+
masterInstanceNftId = info.nftId;
|
358
|
+
|
359
|
+
// masterInstance.linkToRegisteredNftId();
|
168
360
|
}
|
169
361
|
|
170
362
|
function setMasterInstanceReader(address instanceReaderAddress) external onlyOwner {
|
171
|
-
|
172
|
-
|
173
|
-
|
363
|
+
if(_masterInstanceReader == address(0)) { revert ErrorInstanceServiceMasterInstanceReaderNotSet(); }
|
364
|
+
if(instanceReaderAddress == address(0)) { revert ErrorInstanceServiceInstanceReaderAddressZero(); }
|
365
|
+
if(instanceReaderAddress == _masterInstanceReader) { revert ErrorInstanceServiceInstanceReaderSameAsMasterInstanceReader(); }
|
174
366
|
|
175
367
|
InstanceReader instanceReader = InstanceReader(instanceReaderAddress);
|
176
|
-
|
368
|
+
if(instanceReader.getInstance() != IInstance(_masterInstance)) { revert ErrorInstanceServiceInstanceReaderInstanceMismatch(); }
|
177
369
|
|
178
370
|
_masterInstanceReader = instanceReaderAddress;
|
179
371
|
}
|
180
372
|
|
181
|
-
function upgradeInstanceReader(NftId instanceNftId)
|
373
|
+
function upgradeInstanceReader(NftId instanceNftId)
|
374
|
+
external
|
375
|
+
onlyInstanceOwner(instanceNftId)
|
376
|
+
{
|
182
377
|
IRegistry registry = getRegistry();
|
183
378
|
IRegistry.ObjectInfo memory instanceInfo = registry.getObjectInfo(instanceNftId);
|
184
379
|
Instance instance = Instance(instanceInfo.objectAddress);
|
185
|
-
address owner = instance.getOwner();
|
186
|
-
|
187
|
-
if (msg.sender != owner) {
|
188
|
-
revert ErrorInstanceServiceRequestUnauhorized(msg.sender);
|
189
|
-
}
|
190
380
|
|
191
381
|
InstanceReader upgradedInstanceReaderClone = InstanceReader(Clones.clone(address(_masterInstanceReader)));
|
192
|
-
upgradedInstanceReaderClone.initialize(address(registry),
|
382
|
+
upgradedInstanceReaderClone.initialize(address(registry), address(instance));
|
193
383
|
instance.setInstanceReader(upgradedInstanceReaderClone);
|
194
384
|
}
|
195
385
|
|
@@ -210,15 +400,11 @@ contract InstanceService is Service, IInstanceService {
|
|
210
400
|
}
|
211
401
|
|
212
402
|
// From IService
|
213
|
-
function
|
214
|
-
return
|
403
|
+
function getDomain() public pure override(Service, IService) returns(ObjectType) {
|
404
|
+
return INSTANCE();
|
215
405
|
}
|
216
406
|
|
217
407
|
/// @dev top level initializer
|
218
|
-
// 1) registry is non upgradeable -> don't need a proxy and uses constructor !
|
219
|
-
// 2) deploy registry service first -> from its initialization func it is easier to deploy registry then vice versa
|
220
|
-
// 3) deploy registry -> pass registry service address as constructor argument
|
221
|
-
// registry is getting instantiated and locked to registry service address forever
|
222
408
|
function _initialize(
|
223
409
|
address owner,
|
224
410
|
bytes memory data
|
@@ -227,27 +413,55 @@ contract InstanceService is Service, IInstanceService {
|
|
227
413
|
initializer
|
228
414
|
virtual override
|
229
415
|
{
|
230
|
-
address initialOwner
|
231
|
-
address registryAddress
|
416
|
+
address initialOwner;
|
417
|
+
address registryAddress;
|
232
418
|
(registryAddress, initialOwner) = abi.decode(data, (address, address));
|
233
419
|
// TODO while InstanceService is not deployed in InstanceServiceManager constructor
|
234
420
|
// owner is InstanceServiceManager deployer
|
235
|
-
|
236
|
-
|
237
|
-
_registerInterface(type(IService).interfaceId);
|
238
|
-
_registerInterface(type(IInstanceService).interfaceId);
|
421
|
+
initializeService(registryAddress, owner);
|
422
|
+
registerInterface(type(IInstanceService).interfaceId);
|
239
423
|
}
|
240
424
|
|
241
|
-
|
242
|
-
|
243
|
-
address instanceAddress = instanceObjectInfo.objectAddress;
|
425
|
+
// TODO call instance access manager directlly and delete this function?
|
426
|
+
function hasRole(address account, RoleId role, address instanceAddress) public view returns (bool) {
|
244
427
|
Instance instance = Instance(instanceAddress);
|
245
|
-
|
246
|
-
|
247
|
-
|
248
|
-
|
249
|
-
|
250
|
-
|
428
|
+
InstanceAccessManager accessManager = InstanceAccessManager(instance.authority());
|
429
|
+
return accessManager.hasRole(role, account);
|
430
|
+
}
|
431
|
+
// creates gif targets only -> they have INSTANCE as parent
|
432
|
+
function createGifTarget(NftId instanceNftId, address targetAddress, string memory targetName, bytes4[][] memory selectors, RoleId[] memory roles)
|
433
|
+
external
|
434
|
+
onlyRegisteredService
|
435
|
+
{
|
436
|
+
IRegistry registry = getRegistry();
|
437
|
+
IRegistry.ObjectInfo memory instanceInfo = registry.getObjectInfo(instanceNftId);
|
438
|
+
if(instanceInfo.objectType != INSTANCE()) {
|
439
|
+
revert ErrorInstanceServiceNotInstance(instanceNftId);
|
440
|
+
}
|
441
|
+
|
442
|
+
Instance instance = Instance(instanceInfo.objectAddress);
|
443
|
+
InstanceAccessManager accessManager = instance.getInstanceAccessManager();
|
444
|
+
accessManager.createGifTarget(targetAddress, targetName);
|
445
|
+
for(uint roleIdx = 0; roleIdx < roles.length; roleIdx++)
|
446
|
+
{
|
447
|
+
accessManager.setTargetFunctionRole(targetName, selectors[roleIdx], roles[roleIdx]);
|
448
|
+
}
|
449
|
+
|
251
450
|
}
|
252
|
-
}
|
253
451
|
|
452
|
+
// TODO called by component, but target can be component helper...so needs target name
|
453
|
+
// TODO check that targetName associated with component...how???
|
454
|
+
//function setTargetLocked(string memory targetName, bool locked) onlyComponent external {
|
455
|
+
function setComponentLocked(bool locked) onlyComponent external {
|
456
|
+
address componentAddress = msg.sender;
|
457
|
+
IRegistry registry = getRegistry();
|
458
|
+
NftId instanceNftId = registry.getObjectInfo(componentAddress).parentNftId;
|
459
|
+
address instanceAddress = registry.getObjectInfo(instanceNftId).objectAddress;
|
460
|
+
IInstance instance = IInstance(instanceAddress);
|
461
|
+
|
462
|
+
InstanceAccessManager accessManager = instance.getInstanceAccessManager();
|
463
|
+
// TODO setLocked by target address?
|
464
|
+
string memory componentName = ShortStrings.toString(accessManager.getTargetInfo(componentAddress).name);
|
465
|
+
accessManager.setTargetLocked(componentName, locked);
|
466
|
+
}
|
467
|
+
}
|